All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.plasma.query.model.GroupBy Maven / Gradle / Ivy

There is a newer version: 1.3.3
Show newest version
/**
 *         PlasmaSDO™ License
 * 
 * This is a community release of PlasmaSDO™, a dual-license 
 * Service Data Object (SDO) 2.1 implementation. 
 * This particular copy of the software is released under the 
 * version 2 of the GNU General Public License. PlasmaSDO™ was developed by 
 * TerraMeta Software, Inc.
 * 
 * Copyright (c) 2013, TerraMeta Software, Inc. All rights reserved.
 * 
 * General License information can be found below.
 * 
 * This distribution may include materials developed by third
 * parties. For license and attribution notices for these
 * materials, please refer to the documentation that accompanies
 * this distribution (see the "Licenses for Third-Party Components"
 * appendix) or view the online documentation at 
 * .
 *  
 */
package org.plasma.query.model;

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.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlType;

import org.plasma.query.visitor.QueryVisitor;
import org.plasma.query.visitor.Traversal;



/**
 * 

Java class for GroupBy complex type. * *

The following schema fragment specifies the expected content contained within this class. * *

 * <complexType name="GroupBy">
 *   <complexContent>
 *     <restriction base="{http://www.w3.org/2001/XMLSchema}anyType">
 *       <sequence>
 *         <element ref="{http://www.terrameta.org/plasma/query}Property" maxOccurs="unbounded" minOccurs="0"/>
 *         <element ref="{http://www.terrameta.org/plasma/query}TextContent" minOccurs="0"/>
 *       </sequence>
 *     </restriction>
 *   </complexContent>
 * </complexType>
 * 
* * */ @XmlAccessorType(XmlAccessType.FIELD) @XmlType(name = "GroupBy", propOrder = { "properties", "textContent" }) @XmlRootElement(name = "GroupBy") public class GroupBy implements org.plasma.query.GroupBy { @XmlElement(name = "Property") protected List properties; @XmlElement(name = "TextContent") protected TextContent textContent; public GroupBy() { super(); } //-- org.plasma.mda.query.GroupBy() public GroupBy(Property p1) { this(); getProperties().add(p1); } public GroupBy(Property p1, Property p2) { this(); getProperties().add(p1); getProperties().add(p2); } public GroupBy(Property p1, Property p2, Property p3) { this(); getProperties().add(p1); getProperties().add(p2); getProperties().add(p3); } public GroupBy(Property p1, Property p2, Property p3, Property p4) { this(); getProperties().add(p1); getProperties().add(p2); getProperties().add(p3); getProperties().add(p4); } public GroupBy(Property[] properties) { this(); for (int i = 0; i < properties.length; i++) getProperties().add(properties[i]); } /** * Gets the value of the properties property. * *

* 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 set method for the properties property. * *

* For example, to add a new item, do as follows: *

     *    getProperties().add(newItem);
     * 
* * *

* Objects of the following type(s) are allowed in the list * {@link Property } * * */ public List getProperties() { if (properties == null) { properties = new ArrayList(); } return this.properties; } public void addProperty(Property property) { this.getProperties().add(property); } /** * Gets the value of the textContent property. * * @return * possible object is * {@link TextContent } * */ public TextContent getTextContent() { return textContent; } /** * Sets the value of the textContent property. * * @param value * allowed object is * {@link TextContent } * */ public void setTextContent(TextContent value) { this.textContent = value; } public void accept(QueryVisitor visitor) { visitor.start(this); if (visitor.getContext().getTraversal().ordinal() == Traversal.CONTINUE.ordinal()) { for (int i = 0; i < this.getProperties().size(); i++) this.getProperties().get(i).accept(visitor); } visitor.end(this); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy