/**
*
* geo-platform
* Rich webgis framework
* http://geo-platform.org
* ====================================================================
*
* Copyright (C) 2008-2017 geoSDI Group (CNR IMAA - Potenza - ITALY).
*
* This program is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version. This program 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 General Public License
* for more details. You should have received a copy of the GNU General
* Public License along with this program. If not, see http://www.gnu.org/licenses/
*
* ====================================================================
*
* Linking this library statically or dynamically with other modules is
* making a combined work based on this library. Thus, the terms and
* conditions of the GNU General Public License cover the whole combination.
*
* As a special exception, the copyright holders of this library give you permission
* to link this library with independent modules to produce an executable, regardless
* of the license terms of these independent modules, and to copy and distribute
* the resulting executable under terms of your choice, provided that you also meet,
* for each linked independent module, the terms and conditions of the license of
* that module. An independent module is a module which is not derived from or
* based on this library. If you modify this library, you may extend this exception
* to your version of the library, but you are not obligated to do so. If you do not
* wish to do so, delete this exception statement from your version.
*/
//
// This file was generated by the JavaTM Architecture for XML Binding(JAXB) Reference Implementation, v2.2.5-b10
// See <a href="http://java.sun.com/xml/jaxb">http://java.sun.com/xml/jaxb</a>
// Any modifications to this file will be lost upon recompilation of the source schema.
// Generated on: 2012.10.26 at 03:16:42 PM CEST
//
package org.geosdi.geoplatform.xml.wfs.v110;
import java.math.BigInteger;
import java.util.ArrayList;
import java.util.List;
import javax.xml.bind.annotation.XmlAccessType;
import javax.xml.bind.annotation.XmlAccessorType;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlSchemaType;
import javax.xml.bind.annotation.XmlType;
import org.jvnet.jaxb2_commons.lang.JAXBToStringStrategy;
import org.jvnet.jaxb2_commons.lang.ToString;
import org.jvnet.jaxb2_commons.lang.ToStringStrategy;
import org.jvnet.jaxb2_commons.locator.ObjectLocator;
/**
*
* A GetFeature element contains one or more Query elements that describe a
* query operation on one feature type. In response to a GetFeature request, a
* Web Feature Service must be able to generate a GML3 response that validates
* using a schema generated by the DescribeFeatureType request. A Web Feature
* Service may support other possibly non-XML (and even binary) output formats
* as long as those formats are advertised in the capabilities document.
*
*
* <p>Java class for GetFeatureType complex type.
*
* <p>The following schema fragment specifies the expected content contained
* within this class.
*
* <pre>
* <complexType name="GetFeatureType">
* <complexContent>
* <extension base="{http://www.opengis.net/wfs}BaseRequestType">
* <sequence>
* <element ref="{http://www.opengis.net/wfs}Query" maxOccurs="unbounded"/>
* </sequence>
* <attribute name="resultType" type="{http://www.opengis.net/wfs}ResultTypeType" default="results" />
* <attribute name="outputFormat" type="{http://www.w3.org/2001/XMLSchema}string" default="text/xml; subtype=gml/3.1.1" />
* <attribute name="maxFeatures" type="{http://www.w3.org/2001/XMLSchema}positiveInteger" />
* <attribute name="traverseXlinkDepth" type="{http://www.w3.org/2001/XMLSchema}string" />
* <attribute name="traverseXlinkExpiry" type="{http://www.w3.org/2001/XMLSchema}positiveInteger" />
* </extension>
* </complexContent>
* </complexType>
* </pre>
*
*
*/
@XmlRootElement(name = "GetFeature")
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "GetFeatureType", propOrder = {
"query"
})
public class GetFeatureType
extends BaseRequestType
implements ToString {
@XmlElement(name = "Query", required = true)
protected List<QueryType> query;
@XmlAttribute(name = "resultType")
protected ResultTypeType resultType;
@XmlAttribute(name = "outputFormat")
protected String outputFormat;
@XmlAttribute(name = "maxFeatures")
@XmlSchemaType(name = "positiveInteger")
protected BigInteger maxFeatures;
@XmlAttribute(name = "traverseXlinkDepth")
protected String traverseXlinkDepth;
@XmlAttribute(name = "traverseXlinkExpiry")
@XmlSchemaType(name = "positiveInteger")
protected BigInteger traverseXlinkExpiry;
/**
* Gets the value of the query property.
*
* <p> This accessor method returns a reference to the live list, not a
* snapshot. Therefore any modification you make to the returned list will
* be present inside the JAXB object. This is why there is not a
* <CODE>set</CODE> method for the query property.
*
* <p> For example, to add a new item, do as follows:
* <pre>
* getQuery().add(newItem);
* </pre>
*
*
* <p> Objects of the following type(s) are allowed in the list
* {@link QueryType }
*
*
*/
public List<QueryType> getQuery() {
if (query == null) {
query = new ArrayList<QueryType>();
}
return this.query;
}
/**
* Gets the value of the resultType property.
*
* @return possible object is {@link ResultTypeType }
*
*/
public ResultTypeType getResultType() {
if (resultType == null) {
return ResultTypeType.RESULTS;
} else {
return resultType;
}
}
/**
* Sets the value of the resultType property.
*
* @param value allowed object is {@link ResultTypeType }
*
*/
public void setResultType(ResultTypeType value) {
this.resultType = value;
}
/**
* Gets the value of the outputFormat property.
*
* @return possible object is {@link String }
*
*/
public String getOutputFormat() {
if (outputFormat == null) {
return "text/xml; subtype=gml/3.1.1";
} else {
return outputFormat;
}
}
/**
* Sets the value of the outputFormat property.
*
* @param value allowed object is {@link String }
*
*/
public void setOutputFormat(String value) {
this.outputFormat = value;
}
/**
* Gets the value of the maxFeatures property.
*
* @return possible object is {@link BigInteger }
*
*/
public BigInteger getMaxFeatures() {
return maxFeatures;
}
/**
* Sets the value of the maxFeatures property.
*
* @param value allowed object is {@link BigInteger }
*
*/
public void setMaxFeatures(BigInteger value) {
this.maxFeatures = value;
}
/**
* Gets the value of the traverseXlinkDepth property.
*
* @return possible object is {@link String }
*
*/
public String getTraverseXlinkDepth() {
return traverseXlinkDepth;
}
/**
* Sets the value of the traverseXlinkDepth property.
*
* @param value allowed object is {@link String }
*
*/
public void setTraverseXlinkDepth(String value) {
this.traverseXlinkDepth = value;
}
/**
* Gets the value of the traverseXlinkExpiry property.
*
* @return possible object is {@link BigInteger }
*
*/
public BigInteger getTraverseXlinkExpiry() {
return traverseXlinkExpiry;
}
/**
* Sets the value of the traverseXlinkExpiry property.
*
* @param value allowed object is {@link BigInteger }
*
*/
public void setTraverseXlinkExpiry(BigInteger value) {
this.traverseXlinkExpiry = value;
}
public String toString() {
final ToStringStrategy strategy = JAXBToStringStrategy.INSTANCE;
final StringBuilder buffer = new StringBuilder();
append(null, buffer, strategy);
return buffer.toString();
}
public StringBuilder append(ObjectLocator locator,
StringBuilder buffer,
ToStringStrategy strategy) {
strategy.appendStart(locator, this, buffer);
appendFields(locator, buffer, strategy);
strategy.appendEnd(locator, this, buffer);
return buffer;
}
public StringBuilder appendFields(ObjectLocator locator,
StringBuilder buffer,
ToStringStrategy strategy) {
super.appendFields(locator, buffer, strategy);
{
List<QueryType> theQuery;
theQuery = (((this.query != null) && (!this.query.isEmpty())) ? this.getQuery() : null);
strategy.appendField(locator, this, "query", buffer, theQuery);
}
{
ResultTypeType theResultType;
theResultType = this.getResultType();
strategy.appendField(locator, this, "resultType", buffer,
theResultType);
}
{
String theOutputFormat;
theOutputFormat = this.getOutputFormat();
strategy.appendField(locator, this, "outputFormat", buffer,
theOutputFormat);
}
{
BigInteger theMaxFeatures;
theMaxFeatures = this.getMaxFeatures();
strategy.appendField(locator, this, "maxFeatures", buffer,
theMaxFeatures);
}
{
String theTraverseXlinkDepth;
theTraverseXlinkDepth = this.getTraverseXlinkDepth();
strategy.appendField(locator, this, "traverseXlinkDepth", buffer,
theTraverseXlinkDepth);
}
{
BigInteger theTraverseXlinkExpiry;
theTraverseXlinkExpiry = this.getTraverseXlinkExpiry();
strategy.appendField(locator, this, "traverseXlinkExpiry", buffer,
theTraverseXlinkExpiry);
}
return buffer;
}
public void setQuery(List<QueryType> value) {
this.query = null;
List<QueryType> draftl = this.getQuery();
draftl.addAll(value);
}
}