package org.openlca.ecospold.internal.process;
import java.io.Serializable;
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.XmlAnyElement;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlType;
import org.openlca.ecospold.IAllocation;
import org.openlca.ecospold.IExchange;
import org.openlca.ecospold.IFlowData;
import org.w3c.dom.Element;
/**
* Contains information about inputs and outputs (to and from nature as well as
* to and from technosphere) and information about allocation (flows to be
* allocated, co-products to be allocated to, allocation factors).
*
* <p>
* Java class for TFlowData complex type.
*
* <p>
* The following schema fragment specifies the expected content contained within
* this class.
*
* <pre>
* <complexType name="TFlowData">
* <complexContent>
* <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
* <sequence>
* <element name="exchange" type="{http://www.EcoInvent.org/EcoSpold01}TExchange" maxOccurs="unbounded"/>
* <element name="allocation" type="{http://www.EcoInvent.org/EcoSpold01}TAllocation" maxOccurs="unbounded" minOccurs="0"/>
* <any processContents='lax' namespace='##other' maxOccurs="unbounded" minOccurs="0"/>
* </sequence>
* </restriction>
* </complexContent>
* </complexType>
* </pre>
*
*
*/
@XmlAccessorType(XmlAccessType.FIELD)
@XmlType(name = "TFlowData", propOrder = { "exchange", "allocation", "any" })
class FlowData implements Serializable, IFlowData {
private final static long serialVersionUID = 1L;
@XmlElement(required = true, type = Exchange.class)
protected List<IExchange> exchange;
@XmlElement(type = Allocation.class)
protected List<IAllocation> allocation;
@XmlAnyElement(lax = true)
protected List<Object> any;
/**
* Gets the value of the exchange 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 exchange property.
*
* <p>
* For example, to add a new item, do as follows:
*
* <pre>
* getExchange().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list {@link Exchange }
*
*
*/
@Override
public List<IExchange> getExchange() {
if (exchange == null) {
exchange = new ArrayList<>();
}
return this.exchange;
}
/**
* Gets the value of the allocation 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 allocation property.
*
* <p>
* For example, to add a new item, do as follows:
*
* <pre>
* getAllocation().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list
* {@link Allocation }
*
*
*/
@Override
public List<IAllocation> getAllocation() {
if (allocation == null) {
allocation = new ArrayList<>();
}
return this.allocation;
}
/**
* Gets the value of the any 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 any property.
*
* <p>
* For example, to add a new item, do as follows:
*
* <pre>
* getAny().add(newItem);
* </pre>
*
*
* <p>
* Objects of the following type(s) are allowed in the list {@link Object }
* {@link Element }
*
*
*/
@Override
public List<Object> getAny() {
if (any == null) {
any = new ArrayList<>();
}
return this.any;
}
}