/* * Geotoolkit - An Open Source Java GIS Toolkit * http://www.geotoolkit.org * * (C) 2008 - 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; 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.geotoolkit.gml.xml.v321; import java.io.Serializable; import java.util.ArrayList; import java.util.List; import javax.xml.bind.JAXBElement; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlAttribute; import javax.xml.bind.annotation.XmlElementRef; import javax.xml.bind.annotation.XmlSchemaType; import javax.xml.bind.annotation.XmlSeeAlso; import javax.xml.bind.annotation.XmlType; /** * gml:TimePrimitivePropertyType provides a standard content model for associations between an arbitrary member of the substitution group whose head is gml:AbstractTimePrimitive and another object. * * <p>Java class for TimePrimitivePropertyType complex type. * * <p>The following schema fragment specifies the expected content contained within this class. * * <pre> * <complexType name="TimePrimitivePropertyType"> * <complexContent> * <restriction base="{http://www.w3.org/2001/XMLSchema}anyType"> * <sequence minOccurs="0"> * <element ref="{http://www.opengis.net/gml/3.2}AbstractTimePrimitive"/> * </sequence> * <attGroup ref="{http://www.opengis.net/gml/3.2}OwnershipAttributeGroup"/> * <attGroup ref="{http://www.opengis.net/gml/3.2}AssociationAttributeGroup"/> * </restriction> * </complexContent> * </complexType> * </pre> * * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "TimePrimitivePropertyType", propOrder = { "abstractTimePrimitive" }) @XmlSeeAlso({ RelatedTimeType.class }) public class TimePrimitivePropertyType implements Serializable{ @XmlElementRef(name = "AbstractTimePrimitive", namespace = "http://www.opengis.net/gml/3.2", type = JAXBElement.class) private JAXBElement<? extends AbstractTimePrimitiveType> abstractTimePrimitive; @XmlAttribute private java.lang.Boolean owns; @XmlAttribute private List<String> nilReason; @XmlAttribute(namespace = "http://www.opengis.net/gml/3.2") @XmlSchemaType(name = "anyURI") private String remoteSchema; @XmlAttribute(namespace = "http://www.w3.org/1999/xlink") private String type; @XmlAttribute(namespace = "http://www.w3.org/1999/xlink") @XmlSchemaType(name = "anyURI") private String href; @XmlAttribute(namespace = "http://www.w3.org/1999/xlink") @XmlSchemaType(name = "anyURI") private String role; @XmlAttribute(namespace = "http://www.w3.org/1999/xlink") @XmlSchemaType(name = "anyURI") private String arcrole; @XmlAttribute(namespace = "http://www.w3.org/1999/xlink") private String title; @XmlAttribute(namespace = "http://www.w3.org/1999/xlink") private String show; @XmlAttribute(namespace = "http://www.w3.org/1999/xlink") private String actuate; public TimePrimitivePropertyType() { } public TimePrimitivePropertyType(final TimePrimitivePropertyType that) { if (that != null) { this.actuate = that.actuate; this.arcrole = that.arcrole; this.href = that.href; this.nilReason = new ArrayList<String>(that.nilReason); this.owns = that.owns; this.remoteSchema = that.remoteSchema; this.role = that.role; this.show = that.show; this.title = that.title; this.type = that.type; if (that.abstractTimePrimitive != null) { final ObjectFactory factory = new ObjectFactory(); final AbstractTimePrimitiveType tp = that.abstractTimePrimitive.getValue(); if (tp instanceof TimeInstantType) { final TimeInstantType ti = new TimeInstantType((TimeInstantType)tp); this.abstractTimePrimitive = factory.createTimeInstant(ti); } else if (tp instanceof TimePeriodType) { final TimePeriodType ti = new TimePeriodType((TimePeriodType)tp); this.abstractTimePrimitive = factory.createTimePeriod(ti); } else if (tp instanceof TimeEdgeType) { final TimeEdgeType ti = new TimeEdgeType((TimeEdgeType)tp); this.abstractTimePrimitive = factory.createTimeEdge(ti); } else if (tp instanceof TimeNodeType) { final TimeNodeType ti = new TimeNodeType((TimeNodeType)tp); this.abstractTimePrimitive = factory.createTimeNode(ti); } } } } /** * Gets the value of the abstractTimePrimitive property. * * @return * possible object is * {@link JAXBElement }{@code <}{@link AbstractTimeTopologyPrimitiveType }{@code >} * {@link JAXBElement }{@code <}{@link AbstractTimeGeometricPrimitiveType }{@code >} * {@link JAXBElement }{@code <}{@link AbstractTimePrimitiveType }{@code >} * {@link JAXBElement }{@code <}{@link TimeInstantType }{@code >} * {@link JAXBElement }{@code <}{@link TimePeriodType }{@code >} * {@link JAXBElement }{@code <}{@link TimeEdgeType }{@code >} * {@link JAXBElement }{@code <}{@link TimeNodeType }{@code >} * */ public JAXBElement<? extends AbstractTimePrimitiveType> getAbstractTimePrimitive() { return abstractTimePrimitive; } /** * Sets the value of the abstractTimePrimitive property. * * @param value * allowed object is * {@link JAXBElement }{@code <}{@link AbstractTimeTopologyPrimitiveType }{@code >} * {@link JAXBElement }{@code <}{@link AbstractTimeGeometricPrimitiveType }{@code >} * {@link JAXBElement }{@code <}{@link AbstractTimePrimitiveType }{@code >} * {@link JAXBElement }{@code <}{@link TimeInstantType }{@code >} * {@link JAXBElement }{@code <}{@link TimePeriodType }{@code >} * {@link JAXBElement }{@code <}{@link TimeEdgeType }{@code >} * {@link JAXBElement }{@code <}{@link TimeNodeType }{@code >} * */ public void setAbstractTimePrimitive(JAXBElement<? extends AbstractTimePrimitiveType> value) { this.abstractTimePrimitive = ((JAXBElement<? extends AbstractTimePrimitiveType> ) value); } /** * Gets the value of the owns property. * * @return * possible object is * {@link java.lang.Boolean } * */ public boolean isOwns() { if (owns == null) { return false; } else { return owns; } } /** * Sets the value of the owns property. * * @param value * allowed object is * {@link java.lang.Boolean } * */ public void setOwns(java.lang.Boolean value) { this.owns = value; } /** * Gets the value of the nilReason 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 nilReason property. * * <p> * For example, to add a new item, do as follows: * <pre> * getNilReason().add(newItem); * </pre> * * * <p> * Objects of the following type(s) are allowed in the list * {@link String } * * */ public List<String> getNilReason() { if (nilReason == null) { nilReason = new ArrayList<String>(); } return this.nilReason; } /** * Gets the value of the remoteSchema property. * * @return * possible object is * {@link String } * */ public String getRemoteSchema() { return remoteSchema; } /** * Sets the value of the remoteSchema property. * * @param value * allowed object is * {@link String } * */ public void setRemoteSchema(String value) { this.remoteSchema = value; } /** * Gets the value of the type property. * * @return * possible object is * {@link String } * */ public String getType() { if (type == null) { return "simple"; } else { return type; } } /** * Sets the value of the type property. * * @param value * allowed object is * {@link String } * */ public void setType(String value) { this.type = value; } /** * Gets the value of the href property. * * @return * possible object is * {@link String } * */ public String getHref() { return href; } /** * Sets the value of the href property. * * @param value * allowed object is * {@link String } * */ public void setHref(String value) { this.href = value; } /** * Gets the value of the role property. * * @return * possible object is * {@link String } * */ public String getRole() { return role; } /** * Sets the value of the role property. * * @param value * allowed object is * {@link String } * */ public void setRole(String value) { this.role = value; } /** * Gets the value of the arcrole property. * * @return * possible object is * {@link String } * */ public String getArcrole() { return arcrole; } /** * Sets the value of the arcrole property. * * @param value * allowed object is * {@link String } * */ public void setArcrole(String value) { this.arcrole = value; } /** * Gets the value of the title property. * * @return * possible object is * {@link String } * */ public String getTitle() { return title; } /** * Sets the value of the title property. * * @param value * allowed object is * {@link String } * */ public void setTitle(String value) { this.title = value; } /** * Gets the value of the show property. * * @return * possible object is * {@link String } * */ public String getShow() { return show; } /** * Sets the value of the show property. * * @param value * allowed object is * {@link String } * */ public void setShow(String value) { this.show = value; } /** * Gets the value of the actuate property. * * @return * possible object is * {@link String } * */ public String getActuate() { return actuate; } /** * Sets the value of the actuate property. * * @param value * allowed object is * {@link String } * */ public void setActuate(String value) { this.actuate = value; } }