| /* |
| * Copyright (c) 1998, 2021 Oracle and/or its affiliates. All rights reserved. |
| * |
| * This program and the accompanying materials are made available under the |
| * terms of the Eclipse Public License v. 2.0 which is available at |
| * http://www.eclipse.org/legal/epl-2.0, |
| * or the Eclipse Distribution License v. 1.0 which is available at |
| * http://www.eclipse.org/org/documents/edl-v10.php. |
| * |
| * SPDX-License-Identifier: EPL-2.0 OR BSD-3-Clause |
| */ |
| |
| // Contributors: |
| // Denise Smith - 2.3 |
| package org.eclipse.persistence.testing.jaxb.xmlschema.model; |
| |
| import java.math.BigInteger; |
| import java.util.ArrayList; |
| import java.util.List; |
| import jakarta.xml.bind.JAXBElement; |
| import jakarta.xml.bind.annotation.XmlAccessType; |
| import jakarta.xml.bind.annotation.XmlAccessorType; |
| import jakarta.xml.bind.annotation.XmlAttribute; |
| import jakarta.xml.bind.annotation.XmlElementRef; |
| import jakarta.xml.bind.annotation.XmlElementRefs; |
| import jakarta.xml.bind.annotation.XmlSchemaType; |
| import jakarta.xml.bind.annotation.XmlSeeAlso; |
| import jakarta.xml.bind.annotation.XmlType; |
| import jakarta.xml.bind.annotation.adapters.CollapsedStringAdapter; |
| import jakarta.xml.bind.annotation.adapters.XmlJavaTypeAdapter; |
| import javax.xml.namespace.QName; |
| |
| |
| /** |
| * |
| * group type for explicit groups, named top-level groups and |
| * group references |
| * |
| * <p>Java class for group complex type. |
| * |
| * <p>The following schema fragment specifies the expected content contained within this class. |
| * |
| * <pre>{@code |
| * <complexType name="group"> |
| * <complexContent> |
| * <extension base="{http://www.w3.org/2001/XMLSchema}annotated"> |
| * <group ref="{http://www.w3.org/2001/XMLSchema}particle" maxOccurs="unbounded" minOccurs="0"/> |
| * <attGroup ref="{http://www.w3.org/2001/XMLSchema}defRef"/> |
| * <attGroup ref="{http://www.w3.org/2001/XMLSchema}occurs"/> |
| * <anyAttribute processContents='lax' namespace='##other'/> |
| * </extension> |
| * </complexContent> |
| * </complexType> |
| * }</pre> |
| * |
| * |
| */ |
| @XmlAccessorType(XmlAccessType.FIELD) |
| @XmlType(name = "group", propOrder = { |
| "particle" |
| }) |
| @XmlSeeAlso({ |
| ExplicitGroup.class, |
| RealGroup.class |
| }) |
| public abstract class Group |
| extends Annotated |
| { |
| |
| @XmlElementRefs({ |
| @XmlElementRef(name = "element", namespace = "http://www.w3.org/2001/XMLSchema", type = JAXBElement.class), |
| @XmlElementRef(name = "all", namespace = "http://www.w3.org/2001/XMLSchema", type = JAXBElement.class), |
| @XmlElementRef(name = "any", namespace = "http://www.w3.org/2001/XMLSchema", type = Any.class), |
| @XmlElementRef(name = "sequence", namespace = "http://www.w3.org/2001/XMLSchema", type = JAXBElement.class), |
| @XmlElementRef(name = "group", namespace = "http://www.w3.org/2001/XMLSchema", type = JAXBElement.class), |
| @XmlElementRef(name = "choice", namespace = "http://www.w3.org/2001/XMLSchema", type = JAXBElement.class) |
| }) |
| protected List<Object> particle; |
| @XmlAttribute(name = "name") |
| @XmlJavaTypeAdapter(CollapsedStringAdapter.class) |
| @XmlSchemaType(name = "NCName") |
| protected String name; |
| @XmlAttribute(name = "ref") |
| protected QName ref; |
| @XmlAttribute(name = "minOccurs") |
| @XmlSchemaType(name = "nonNegativeInteger") |
| protected BigInteger minOccurs; |
| @XmlAttribute(name = "maxOccurs") |
| @XmlSchemaType(name = "allNNI") |
| protected String maxOccurs; |
| |
| /** |
| * Gets the value of the particle 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 particle property. |
| * |
| * <p> |
| * For example, to add a new item, do as follows: |
| * <pre> |
| * getParticle().add(newItem); |
| * }</pre> |
| * |
| * |
| * <p> |
| * Objects of the following type(s) are allowed in the list |
| * {@link Any } |
| * {@link JAXBElement }{@code <}{@link LocalElement }{@code >} |
| * {@link JAXBElement }{@code <}{@link All }{@code >} |
| * {@link JAXBElement }{@code <}{@link ExplicitGroup }{@code >} |
| * {@link JAXBElement }{@code <}{@link ExplicitGroup }{@code >} |
| * {@link JAXBElement }{@code <}{@link GroupRef }{@code >} |
| * |
| * |
| */ |
| public List<Object> getParticle() { |
| if (particle == null) { |
| particle = new ArrayList<Object>(); |
| } |
| return this.particle; |
| } |
| |
| /** |
| * Gets the value of the name property. |
| * |
| * @return |
| * possible object is |
| * {@link String } |
| * |
| */ |
| public String getName() { |
| return name; |
| } |
| |
| /** |
| * Sets the value of the name property. |
| * |
| * @param value |
| * allowed object is |
| * {@link String } |
| * |
| */ |
| public void setName(String value) { |
| this.name = value; |
| } |
| |
| /** |
| * Gets the value of the ref property. |
| * |
| * @return |
| * possible object is |
| * {@link QName } |
| * |
| */ |
| public QName getRef() { |
| return ref; |
| } |
| |
| /** |
| * Sets the value of the ref property. |
| * |
| * @param value |
| * allowed object is |
| * {@link QName } |
| * |
| */ |
| public void setRef(QName value) { |
| this.ref = value; |
| } |
| |
| /** |
| * Gets the value of the minOccurs property. |
| * |
| * @return |
| * possible object is |
| * {@link BigInteger } |
| * |
| */ |
| public BigInteger getMinOccurs() { |
| if (minOccurs == null) { |
| return new BigInteger("1"); |
| } else { |
| return minOccurs; |
| } |
| } |
| |
| /** |
| * Sets the value of the minOccurs property. |
| * |
| * @param value |
| * allowed object is |
| * {@link BigInteger } |
| * |
| */ |
| public void setMinOccurs(BigInteger value) { |
| this.minOccurs = value; |
| } |
| |
| /** |
| * Gets the value of the maxOccurs property. |
| * |
| * @return |
| * possible object is |
| * {@link String } |
| * |
| */ |
| public String getMaxOccurs() { |
| if (maxOccurs == null) { |
| return "1"; |
| } else { |
| return maxOccurs; |
| } |
| } |
| |
| /** |
| * Sets the value of the maxOccurs property. |
| * |
| * @param value |
| * allowed object is |
| * {@link String } |
| * |
| */ |
| public void setMaxOccurs(String value) { |
| this.maxOccurs = value; |
| } |
| |
| } |