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

org.geotoolkit.parameter.AbstractParameterDescriptor Maven / Gradle / Ivy

/*
 *    Geotoolkit.org - An Open Source Java GIS Toolkit
 *    http://www.geotoolkit.org
 *
 *    (C) 2004-2012, Open Source Geospatial Foundation (OSGeo)
 *    (C) 2009-2012, Geomatys
 *
 *    This library is free software; you can redistribute it and/or
 *    modify it under the terms of the GNU Lesser General Public
 *    License as published by the Free Software Foundation;
 *    version 2.1 of the License.
 *
 *    This library is distributed in the hope that it will be useful,
 *    but WITHOUT ANY WARRANTY; without even the implied warranty of
 *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 *    Lesser General Public License for more details.
 *
 *    This package contains documentation from OpenGIS specifications.
 *    OpenGIS consortium's work is fully acknowledged here.
 */
package org.geotoolkit.parameter;

import java.util.Map;
import net.jcip.annotations.Immutable;

import org.opengis.parameter.ParameterValue;
import org.opengis.parameter.GeneralParameterValue;
import org.opengis.parameter.GeneralParameterDescriptor;

import org.geotoolkit.resources.Errors;
import org.geotoolkit.io.wkt.Formatter;
import org.geotoolkit.util.ComparisonMode;
import org.geotoolkit.referencing.AbstractIdentifiedObject;

import static org.geotoolkit.util.Utilities.hash;


/**
 * The root class of {@link org.opengis.parameter.ParameterDescriptor} and
 * {@link org.opengis.parameter.ParameterDescriptorGroup} implementations.
 * Subclasses provide abstract definition of a parameter or group of parameters
 * used by an operation method.
 *
 * @author Martin Desruisseaux (IRD, Geomatys)
 * @version 3.18
 *
 * @see AbstractParameter
 *
 * @since 2.0
 * @module
 */
@Immutable
public abstract class AbstractParameterDescriptor extends AbstractIdentifiedObject
           implements GeneralParameterDescriptor
{
    /**
     * Serial number for inter-operability with different versions.
     */
    private static final long serialVersionUID = -2630644278783845276L;

    /**
     * The minimum number of times that values for this parameter group or
     * parameter are required.
     */
    private final int minimumOccurs;

    /**
     * Constructs a descriptor with the same values than the specified one. This copy constructor
     * may be used in order to wraps an arbitrary implementation into a Geotk one.
     *
     * @param descriptor The descriptor to copy.
     *
     * @since 2.2
     */
    protected AbstractParameterDescriptor(final GeneralParameterDescriptor descriptor) {
        super(descriptor);
        minimumOccurs = descriptor.getMinimumOccurs();
    }

    /**
     * Constructs a parameter from a set of properties. The properties map is given unchanged to the
     * {@linkplain AbstractIdentifiedObject#AbstractIdentifiedObject(Map) super-class constructor}.
     *
     * @param properties Set of properties. Should contains at least {@code "name"}.
     * @param minimumOccurs The {@linkplain #getMinimumOccurs minimum number of times}
     *        that values for this parameter group or parameter are required.
     * @param maximumOccurs The {@linkplain #getMaximumOccurs maximum number of times} that values
     *        for this parameter group or parameter are required. This value is used in order to
     *        check the range. For {@link ParameterValue}, it should always be 1.
     */
    protected AbstractParameterDescriptor(final Map properties,
                                          final int minimumOccurs,
                                          final int maximumOccurs)
    {
        super(properties);
        this.minimumOccurs = minimumOccurs;
        if (minimumOccurs < 0  ||  maximumOccurs < minimumOccurs) {
            throw new IllegalArgumentException(Errors.format(Errors.Keys.ILLEGAL_RANGE_$2,
                        minimumOccurs, maximumOccurs));
        }
    }

    /**
     * Creates a new instance of {@linkplain AbstractParameter parameter value or group} initialized
     * with the {@linkplain DefaultParameterDescriptor#getDefaultValue default value(s)}.
     * The {@linkplain AbstractParameter#getDescriptor parameter value descriptor} for the
     * created parameter value(s) will be {@code this} object.
     * 

* Implementation example: * * {@preformat java * return new Parameter(this); * } */ @Override public abstract GeneralParameterValue createValue(); /** * The minimum number of times that values for this parameter group or * parameter are required. The default value is one. A value of 0 means * an optional parameter. * * @see #getMaximumOccurs */ @Override public int getMinimumOccurs() { return minimumOccurs; } /** * The maximum number of times that values for this parameter group or parameter * can be included. For a {@linkplain DefaultParameterDescriptor single parameter}, * the value is always 1. For a {@linkplain DefaultParameterDescriptorGroup parameter group}, * it may vary. * * @see #getMinimumOccurs */ @Override public abstract int getMaximumOccurs(); /** * Compares the specified object with this parameter for equality. * * @param object The object to compare to {@code this}. * @param mode {@link ComparisonMode#STRICT STRICT} for performing a strict comparison, or * {@link ComparisonMode#IGNORE_METADATA IGNORE_METADATA} for comparing only properties * relevant to transformations. * @return {@code true} if both objects are equal. */ @Override public boolean equals(final Object object, final ComparisonMode mode) { if (super.equals(object, mode)) { switch (mode) { case STRICT: { final AbstractParameterDescriptor that = (AbstractParameterDescriptor) object; return this.minimumOccurs == that.minimumOccurs; } default: { final GeneralParameterDescriptor that = (GeneralParameterDescriptor) object; return getMinimumOccurs() == that.getMinimumOccurs() && getMaximumOccurs() == that.getMaximumOccurs(); } } } return false; } /** * {@inheritDoc} */ @Override protected int computeHashCode() { return hash(minimumOccurs, super.computeHashCode()); } /** * Formats the inner part of a * Well * Known Text (WKT) element. Note that WKT is not yet defined for parameter descriptor. * Current implementation print only the name. * * @param formatter The formatter to use. * @return The WKT element name, which is "PARAMETER" */ @Override public String formatWKT(final Formatter formatter) { formatter.setInvalidWKT(GeneralParameterDescriptor.class); return "PARAMETER"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy