001: //$HeadURL: https://svn.wald.intevation.org/svn/deegree/base/trunk/src/org/deegree/owscommon/com110/Operation110.java $
002: /*---------------- FILE HEADER ------------------------------------------
003:
004: This file is part of deegree.
005: Copyright (C) 2001-2008 by:
006: EXSE, Department of Geography, University of Bonn
007: http://www.giub.uni-bonn.de/deegree/
008: lat/lon GmbH
009: http://www.lat-lon.de
010:
011: This library is free software; you can redistribute it and/or
012: modify it under the terms of the GNU Lesser General Public
013: License as published by the Free Software Foundation; either
014: version 2.1 of the License, or (at your option) any later version.
015:
016: This library is distributed in the hope that it will be useful,
017: but WITHOUT ANY WARRANTY; without even the implied warranty of
018: MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
019: Lesser General Public License for more details.
020:
021: You should have received a copy of the GNU Lesser General Public
022: License along with this library; if not, write to the Free Software
023: Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
024:
025: Contact:
026:
027: Andreas Poth
028: lat/lon GmbH
029: Aennchenstraße 19
030: 53177 Bonn
031: Germany
032: E-Mail: poth@lat-lon.de
033:
034: Prof. Dr. Klaus Greve
035: Department of Geography
036: University of Bonn
037: Meckenheimer Allee 166
038: 53115 Bonn
039: Germany
040: E-Mail: greve@giub.uni-bonn.de
041:
042: ---------------------------------------------------------------------------*/
043:
044: package org.deegree.owscommon.com110;
045:
046: import org.deegree.ogcwebservices.getcapabilities.DCPType;
047: import org.deegree.ogcwebservices.getcapabilities.Operation;
048: import org.deegree.owscommon.OWSMetadata;
049:
050: /**
051: * TODO class description
052: *
053: * @author <a href="mailto:mays@lat-lon.de">Judit Mays</a>
054: * @author last edited by: $Author: apoth $
055: *
056: * @version 2.0, $Revision: 9346 $, $Date: 2007-12-27 08:39:07 -0800 (Thu, 27 Dec 2007) $
057: *
058: * @since 2.0
059: */
060: public class Operation110 extends Operation {
061:
062: private OWSDomainType110[] parameters;
063: private OWSDomainType110[] constraints;
064: private OWSMetadata[] metadata;
065:
066: /**
067: * Creates a new <code>Operation110</code> object with information on
068: * <code>DHCP</code>, <code>Parameter</code> and <code>Constraint</code>.
069: *
070: * @param name
071: * @param dcps
072: * @param parameters
073: * @param constraints
074: * @param metadata
075: */
076: public Operation110(String name, DCPType[] dcps,
077: OWSDomainType110[] parameters,
078: OWSDomainType110[] constraints, OWSMetadata[] metadata) {
079:
080: super (name, dcps);
081:
082: if (parameters == null) {
083: this .parameters = new OWSDomainType110[0];
084: } else {
085: this .parameters = parameters;
086: }
087:
088: if (constraints == null) {
089: this .constraints = new OWSDomainType110[0];
090: } else {
091: this .constraints = constraints;
092: }
093:
094: if (metadata == null) {
095: this .metadata = new OWSMetadata[0];
096: } else {
097: this .metadata = metadata;
098: }
099: }
100:
101: /**
102: * Returns an array of all the parameter objects.
103: * If parameters is null, an array of size 0 is returned.
104: *
105: * @return Returns all the parameters.
106: */
107: public OWSDomainType110[] getParameters110() {
108: return parameters;
109: }
110:
111: /**
112: * @param name
113: * @return Returns the parameter object to the given name.
114: */
115: public OWSDomainType110 getParameter110(String name) {
116:
117: for (int i = 0; i < parameters.length; i++) {
118: if (name.equals(parameters[i].getName())) {
119: return parameters[i];
120: }
121: }
122: return null;
123: }
124:
125: /**
126: * Returns an array of all the constraint objects.
127: * If constraints is null, an array of size 0 is returned.
128: *
129: * @return Returns all the constraints.
130: */
131: public OWSDomainType110[] getConstraints110() {
132: return constraints;
133: }
134:
135: /**
136: * @param name
137: * @return Returns the constraint object to the given name.
138: */
139: public OWSDomainType110 getConstraint110(String name) {
140:
141: for (int i = 0; i < constraints.length; i++) {
142: if (name.equals(constraints[i].getName())) {
143: return constraints[i];
144: }
145: }
146: return null;
147: }
148:
149: /**
150: * Returns an array of all the metadata objects.
151: * If metadata is null, an array of size 0 is returned.
152: *
153: * @return Returns the metadata.
154: */
155: public OWSMetadata[] getMetadata110() {
156: return metadata;
157: }
158:
159: }
|