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

thredds.catalog2.simpleImpl.PropertyContainer Maven / Gradle / Ivy

/*
 * 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.catalog2.simpleImpl;

import thredds.catalog2.Property;
import thredds.catalog2.builder.BuilderIssues;

import java.util.*;

/**
 * Helper class for those classes that contain properties: ServiceImpl, DatasetNodeImpl, and CatalogImpl.
 *
 * @author edavis
 * @since 4.0
 */
class PropertyContainer
{
  private org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger( getClass() );

  private Map propertiesMap;

  private boolean isBuilt;

  PropertyContainer()
  {
    this.isBuilt = false;
    this.propertiesMap = null;
  }

  boolean isEmpty()
  {
    if ( this.propertiesMap == null )
      return true;
    return this.propertiesMap.isEmpty();
  }

  int size()
  {
    if ( this.propertiesMap == null )
      return 0;
    return this.propertiesMap.size();
  }

  /**
   * Add a Property with the given name and value to this container.
   *
   * @param name the name of the Property to add.
   * @param value the value of the Property to add.
   * @throws IllegalArgumentException if name or value are null.
   * @throws IllegalStateException if build() has been called on this PropertyContainer.
   */
  void addProperty( String name, String value )
  {
    if ( this.isBuilt )
      throw new IllegalStateException( "This PropertyContainer has been built.");

    if ( this.propertiesMap == null )
      this.propertiesMap = new LinkedHashMap();

    PropertyImpl property = new PropertyImpl( name, value );
    if ( null != this.propertiesMap.put( name, property ))
      if ( log.isDebugEnabled())
        log.debug( "addProperty(): reseting property [" + name + "]." );
    
    return;
  }

  /**
   * Remove the named Property from this container if it was present.
   *
   * @param name the name of the Property to remove.
   * @return true if a Property with the given name was present and has been removed, otherwise false.
   * @throws IllegalArgumentException if name is null.
   * @throws IllegalStateException if build() has been called on this PropertyContainer.
   */
  boolean removeProperty( String name )
  {
    if ( this.isBuilt )
      throw new IllegalStateException( "This PropertyContainer has been built." );

    if ( name == null )
      throw new IllegalArgumentException( "Given name may not be null." );

    if ( this.propertiesMap == null )
      return false;

    Property property = this.propertiesMap.remove( name );
    if ( property == null )
      return false;

    return true;
  }

  List getPropertyNames()
  {
    if ( this.propertiesMap == null )
      return Collections.emptyList();
    return Collections.unmodifiableList( new ArrayList( this.propertiesMap.keySet() ) );
  }

  boolean containsPropertyName( String name )
  {
    if ( name == null )
      return false;

    if ( this.propertiesMap == null )
      return false;

    if ( this.propertiesMap.get( name ) == null )
      return false;
    return true;
  }

  String getPropertyValue( String name )
  {
    if ( name == null )
      return null;

    if ( this.propertiesMap == null )
      return null;

    Property property = this.propertiesMap.get( name );
    if ( property == null )
      return null;
    return property.getValue();
  }

  List getProperties()
  {
    if ( this.propertiesMap == null )
      return Collections.emptyList();

    return Collections.unmodifiableList( new ArrayList( this.propertiesMap.values() ) );
  }

  Property getPropertyByName( String name )
  {
    if ( name == null )
      return null;

    if ( this.propertiesMap == null )
      return null;

    return this.propertiesMap.get( name );
  }

  boolean isBuilt()
  {
    return this.isBuilt;
  }

  /**
   * This method always returns an empty BuilderIssues object because no action is required to
   * finish any contained Property classes.
   *
   * The reasons for this are:
   * 
    *
  1. The Property class is immutable and doesn't allow null names or values.
  2. *
  3. This container stores the properties in a Map by property name (so there are no duplicate names).
  4. *
* * @return an empty BuilderIssues object. */ BuilderIssues getIssues() { return null; } /** * Mark this PropertyContainer as unmodifiable and return "true". * * No validation is required * (see {@link #getIssues()}) */ void build() { this.isBuilt = true; return; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy