/*
* GeoTools - The Open Source Java GIS Toolkit
* http://geotools.org
*
* (C) 2011, Open Source Geospatial Foundation (OSGeo)
* (C) 2005 Open Geospatial Consortium Inc.
* (C) 2001-2004 EXSE, Department of Geography, University of Bonn
* lat/lon Fitzke/Fretter/Poth GbR
*
* 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; either
* version 2.1 of the License, or (at your option) any later version.
*
* 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.
*/
package org.opengis.filter.capability;
// Annotations
import java.util.List;
import org.opengis.annotation.UML;
import org.opengis.parameter.Parameter;
import static org.opengis.annotation.Specification.*;
/**
* Function description provided in a filter capabilities.
* <p>
* <pre>
* <xsd:complexType name="FunctionNameType">
* <xsd:simpleContent>
* <xsd:extension base="xsd:string">
* <xsd:attribute name="nArgs" type="xsd:string" use="required"/>
* </xsd:extension>
* </xsd:simpleContent>
* </xsd:complexType>
* </pre>
* </p>
* <p>
* We have extended this idea to include a list of argument names to better serve interactive
* clients.
*
* @author <a href="mailto:tfr@users.sourceforge.net">Torsten Friebe </A>
* @author Justin Deoliveira, The Open Planning Project
*
* @source $URL: http://svn.osgeo.org/geotools/trunk/modules/library/opengis/src/main/java/org/opengis/filter/capability/FunctionName.java $
*/
public interface FunctionName extends Operator {
/**
* Number of arguments the function accepts.
* <p>
* <ul>
* <li>Use a postivie number to indicate the number of arguments.
* Example: add( number1, number2 ) = 2</li>
* <li>Use a negative number to indicate a minimum number:
* Example: concat( str1, str2,... ) has -2</li>
* </ul>
*
* <pre>
* <xsd:attribute name="nArgs" type="xsd:string" use="required"/>
* </pre>
* </p>
* <p>
* This value is derived from {@link #getArguments()}
* </p>
*/
@UML(identifier="argumentCount", specification=UNSPECIFIED)
int getArgumentCount();
/**
* Argument names for documentation purposes if known.
* <p>
* This value is derived from {@link #getArguments()}
* </p>
* @return Argument names (for documentation purposes) if known
*/
List<String> getArgumentNames();
/**
* Arguments for the function accepts.
*
* @version 8.0
*/
List<Parameter<?>> getArguments();
/**
* Return type of the function.
*
* @version 8.0
*/
Parameter<?> getReturn();
}