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

thredds.cataloggen.config.CatalogGenConfig 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.

The newest version!
/*
 * Copyright 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.cataloggen.config;

import thredds.catalog.InvDataset;

/**
 * 

Title: Catalog Generator

*

Description: Tool for generating THREDDS catalogs.

*

Copyright: Copyright (c) 2001

*

Company: UCAR/Unidata

* @author Ethan Davis * @version 1.0 */ public class CatalogGenConfig { // private static Log log = LogFactory.getLog( CatalogGenConfig.class ); static private org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(CatalogGenConfig.class); // parent dataset for this CatalogGenConfig private InvDataset parentDataset = null; // type of catalogGenConfig private CatalogGenConfig.Type type = null; // list of DatasetSources private DatasetSource datasetSource = null; // validation flag and log private boolean isValid = true; private StringBuffer msgLog = new StringBuffer(); public static final String CATALOG_GEN_CONFIG_NAMESPACE_URI_0_5 = "http://www.unidata.ucar.edu/namespaces/thredds/CatalogGenConfig/v0.5"; /** Constructor */ public CatalogGenConfig( InvDataset parentDataset, String typeName) { this( parentDataset, CatalogGenConfig.Type.getType( typeName)); } /** Constructor */ public CatalogGenConfig( InvDataset parentDataset, CatalogGenConfig.Type type) { log.debug( "CatalogGenConfig(): type " + type.toString() + "."); this.parentDataset = parentDataset; this.type = type; } /** Return the parent dataset of this CatalogGenConfig */ public InvDataset getParentDataset() { return( this.parentDataset); } /** Set the type of this CatalogGenConfig */ public void setParentDataset( InvDataset parentDataset) { this.parentDataset = parentDataset; } /** Return the type of this CatalogGenConfig */ public CatalogGenConfig.Type getType() { return( this.type); } /** Set the type of this CatalogGenConfig */ public void setType( CatalogGenConfig.Type type) { this.type = type; } /** Return the DatasetSource for this CatalogGenConfig */ public DatasetSource getDatasetSource() { return( this.datasetSource); } /** Set the DatasetSource for this CatalogGenConfig */ public void setDatasetSource( DatasetSource dsSource) { this.datasetSource = dsSource; } public boolean validate( StringBuilder out) { log.debug( "validate(): checking if valid"); this.isValid = true; // If log from construction has content, append to validation output msg. if (this.msgLog.length() > 0) { out.append( this.msgLog); } // Check that type is not null. if ( this.getType() == null) { isValid = false; out.append( " ** CatalogGenConfig (3): null value for type is not valid (set with bad string?)."); } // Validate DatasetSource child element. this.isValid &= this.getDatasetSource().validate( out); log.debug( "validate(): isValid=" + this.isValid + " message is\n" + out.toString()); return( this.isValid); } public String toString() { StringBuffer tmp = new StringBuffer(); tmp.append( "CatalogGenConfig[type:<") .append( this.getType() ).append( "> child ") .append( this.getDatasetSource().toString() + ")]"); return( tmp.toString()); } enum Type { CATALOG( "Catalog" ), AGGREGATION( "Aggregation" ); private String altId; Type( String altId ) { this.altId = altId; } public String toString() { return this.altId; } public static Type getType( String altId ) { if ( altId == null ) return null; for ( Type curType : Type.values() ) { if ( curType.altId.equals( altId ) ) return curType; } return null; } } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy