All Downloads are FREE. Search and download functionalities are using the official Maven repository.

thredds.inventory.CollectionSpecParser Maven / Gradle / Ivy

Go to download

The NetCDF-Java Library is a Java interface to NetCDF files, as well as to many other types of scientific data formats.

There is a newer version: 4.3.22
Show newest version
/*
 * Copyright (c) 1998 - 2009. University Corporation for Atmospheric Research/Unidata
 * Portions of this software were developed by the Unidata Program at the
 * University Corporation for Atmospheric Research.
 *
 * Access and use of this software shall impose the following obligations
 * and understandings on the user. The user is granted the right, without
 * any fee or cost, to use, copy, modify, alter, enhance and distribute
 * this software, and any derivative works thereof, and its supporting
 * documentation for any purpose whatsoever, provided that this entire
 * notice appears in all copies of the software, derivative works and
 * supporting documentation.  Further, UCAR requests that the user credit
 * UCAR/Unidata in any publications that result from the use of this
 * software or in any product that includes this software. The names UCAR
 * and/or Unidata, however, may not be used in any advertising or publicity
 * to endorse or promote any products or commercial entity unless specific
 * written permission is obtained from UCAR/Unidata. The user also
 * understands that UCAR/Unidata is not obligated to provide the user with
 * any support, consulting, training or assistance of any kind with regard
 * to the use, operation and performance of this software nor to provide
 * the user with any updates, revisions, new versions or "bug fixes."
 *
 * THIS SOFTWARE IS PROVIDED BY UCAR/UNIDATA "AS IS" AND ANY EXPRESS OR
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL UCAR/UNIDATA BE LIABLE FOR ANY SPECIAL,
 * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING
 * FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,
 * NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
 * WITH THE ACCESS, USE OR PERFORMANCE OF THIS SOFTWARE.
 */
package thredds.inventory;

import java.util.*;
import java.util.regex.Pattern;
import java.io.File;

import net.jcip.annotations.ThreadSafe;
import ucar.unidata.util.StringUtil;

/**
 * Parses the collection specification string.
 * 

the idea is that one copies the full path of an example dataset, then edits it

*

Example: "/data/ldm/pub/native/grid/NCEP/GFS/Alaska_191km/** /GFS_Alaska_191km_#yyyyMMdd_HHmm#.grib1"

  • rootDir ="/data/ldm/pub/native/grid/NCEP/GFS/Alaska_191km"/
  • subdirs=yes (because ** is present)
  • dateFormatMark="GFS_Alaska_191km_#yyyyMMdd_HHmm"
  • onName=yes
  • regexp= "GFS_Alaska_191km.........\.grib1"
*

Example: "Q:/grid/grib/grib1/data/agg/.*\.grb"

  • rootDir ="Q:/grid/grib/grib1/data/agg/"/
  • subdirs=no
  • dateFormatMark=null
  • onName=yes
  • regexp= ".*\.grb" (anything ending with .grb)
"Q:/grid/grib/grib1/data/agg/" * @author caron * @since Jul 7, 2009 */ @ThreadSafe public class CollectionSpecParser { private String spec; private String topDir; private boolean subdirs = false; private boolean error = false; private String dateFormatMark; private java.util.regex.Pattern pattern; // not dealing yet with dateFormatMark being anywhere else than in the filename, ie not the path public CollectionSpecParser(String collectionSpec, Formatter errlog) { this.spec = collectionSpec.trim(); int posFilter = -1; int posGlob = collectionSpec.indexOf("/**/"); if (posGlob > 0) { topDir = collectionSpec.substring(0, posGlob); posFilter = posGlob + 3; subdirs = true; } else { posFilter = collectionSpec.lastIndexOf('/'); topDir = collectionSpec.substring(0, posFilter); } File locFile = new File(topDir); if (!locFile.exists()) { errlog.format(" Directory %s does not exist %n", topDir); error = true; } // optional filter String filter = null; if (posFilter < collectionSpec.length() - 2) filter = collectionSpec.substring(posFilter + 1); // remove topDir if (filter != null) { // optional dateFormatMark int posFormat = filter.indexOf('#'); if (posFormat >= 0) { // check for two hash marks int posFormat2 = filter.lastIndexOf('#'); if (posFormat != posFormat2) { // two hash dateFormatMark = filter.substring(0, posFormat2); // everything up to the second hash filter = StringUtil.remove(filter, '#'); // remove hashes, replace with . StringBuilder sb = new StringBuilder(filter); for (int i = posFormat; i < posFormat2 - 1; i++) sb.setCharAt(i, '.'); String regExp = sb.toString(); this.pattern = java.util.regex.Pattern.compile(regExp); } else { // one hash dateFormatMark = filter; // everything String regExp = filter.substring(0, posFormat) + "*"; pattern = java.util.regex.Pattern.compile(regExp); } } else { // no hash (dateFormatMark) pattern = java.util.regex.Pattern.compile(filter); } } } public String getSpec() { return spec; } public String getTopDir() { return topDir; } public boolean wantSubdirs() { return subdirs; } public Pattern getFilter() { return pattern; } public String getDateFormatMark() { return dateFormatMark; } public boolean isError() { return error; } @Override public String toString() { return "CollectionSpecParser{" + "\n topDir='" + topDir + '\'' + "\n subdirs=" + subdirs + "\n regExp='" + pattern + '\'' + "\n dateFormatMark='" + dateFormatMark + '\'' + "\n}"; } ///////////////////////////////////////////////////////// // debugging private static void doit(String spec, Formatter errlog) { CollectionSpecParser specp = new CollectionSpecParser(spec, errlog); System.out.printf("spec= %s%n%s%n", spec, specp); String err = errlog.toString(); if (err.length() > 0) System.out.printf("%s%n", err); System.out.printf("-----------------------------------%n"); } public static void main(String arg[]) { doit("C:/data/formats/gempak/surface/#yyyyMMdd#_sao.gem", new Formatter()); //doit("C:/data/formats/gempak/surface/#yyyyMMdd#_sao\\.gem", new Formatter()); // doit("Q:/station/ldm/metar/Surface_METAR_#yyyyMMdd_HHmm#.nc", new Formatter()); } public static void main2(String arg[]) { doit("/data/ldm/pub/decoded/netcdf/surface/metar/**/Surface_METAR_#yyyyMMdd_HHmm#\\.nc", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/**/Surface_METAR_#yyyyMMdd_HHmm#.nc", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/**/Surface_METAR_#yyyyMMdd_HHmm", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/Surface_METAR_#yyyyMMdd_HHmm", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/Surface_METAR_#yyyyMMdd_HHmm#.nc", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/Surface_METAR_yyyyMMdd_HHmm.nc", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/**/", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/**/*", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/*", new Formatter()); doit("/data/ldm/pub/decoded/netcdf/surface/metar/T*.T", new Formatter()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy