|
Java example source code file (XmlElementRef.java)
The XmlElementRef.java Java example source code/* * Copyright (c) 2004, 2013, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code 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 * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package javax.xml.bind.annotation; import javax.xml.bind.annotation.adapters.XmlJavaTypeAdapter; import java.lang.annotation.Retention; import java.lang.annotation.Target; import static java.lang.annotation.RetentionPolicy.RUNTIME; import static java.lang.annotation.ElementType.FIELD; import static java.lang.annotation.ElementType.METHOD; /** * <p> * Maps a JavaBean property to a XML element derived from property's type. * <p> * <b>Usage * <p> * <tt>@XmlElementRef annotation can be used with a * JavaBean property or from within {@link XmlElementRefs} * <p> * This annotation dynamically associates an XML element name with the JavaBean * property. When a JavaBean property is annotated with {@link * XmlElement}, the XML element name is statically derived from the * JavaBean property name. However, when this annotation is used, the * XML element name is derived from the instance of the type of the * JavaBean property at runtime. * * <h3> XML Schema substitution group support * XML Schema allows a XML document author to use XML element names * that were not statically specified in the content model of a * schema using substitution groups. Schema derived code provides * support for substitution groups using an <i>element property, * (section 5.5.5, "Element Property" of JAXB 2.0 specification). An * element property method signature is of the form: * <pre> * public void setTerm(JAXBElement<? extends Operator>); * public JAXBElement<? extends Operator> getTerm(); * </pre> * <p> * An element factory method annotated with {@link XmlElementDecl} is * used to create a <tt>JAXBElement instance, containing an XML * element name. The presence of @XmlElementRef annotation on an * element property indicates that the element name from <tt>JAXBElement * instance be used instead of deriving an XML element name from the * JavaBean property name. * * <p> * The usage is subject to the following constraints: * <ul> * <li> If the collection item type (for collection property) or * property type (for single valued property) is * {@link javax.xml.bind.JAXBElement}, then * <tt>@XmlElementRef}.name() and @XmlElementRef.namespace() must * point an element factory method with an @XmlElementDecl * annotation in a class annotated with @XmlRegistry (usually * ObjectFactory class generated by the schema compiler) : * <ul> * <li> @XmlElementDecl.name() must equal @XmlElementRef.name() * <li> @XmlElementDecl.namespace() must equal @XmlElementRef.namespace(). * </ul> * </li> * <li> If the collection item type (for collection property) or * property type (for single valued property) is not * {@link javax.xml.bind.JAXBElement}, then the type referenced by the * property or field must be annotated with {@link XmlRootElement}. </li> * <li> This annotation can be used with the following annotations: * {@link XmlElementWrapper}, {@link XmlJavaTypeAdapter}. * </ul> * * <p>See "Package Specification" in javax.xml.bind.package javadoc for * additional common information.</p> * * <p>Example 1: Ant Task Example * The following Java class hierarchy models an Ant build * script. An Ant task corresponds to a class in the class * hierarchy. The XML element name of an Ant task is indicated by the * @XmlRootElement annotation on its corresponding class. * <pre> * @XmlRootElement(name="target") * class Target { * // The presence of @XmlElementRef indicates that the XML * // element name will be derived from the @XmlRootElement * // annotation on the type (for e.g. "jar" for JarTask). * @XmlElementRef * List<Task> tasks; * } * * abstract class Task { * } * * @XmlRootElement(name="jar") * class JarTask extends Task { * ... * } * * @XmlRootElement(name="javac") * class JavacTask extends Task { * ... * } * * <!-- XML Schema fragment --> * <xs:element name="target" type="Target"> * <xs:complexType name="Target"> * <xs:sequence> * <xs:choice maxOccurs="unbounded"> * <xs:element ref="jar"> * <xs:element ref="javac"> * </xs:choice> * </xs:sequence> * </xs:complexType> * * </pre> * <p> * Thus the following code fragment: * <pre> * Target target = new Target(); * target.tasks.add(new JarTask()); * target.tasks.add(new JavacTask()); * marshal(target); * </pre> * will produce the following XML output: * <pre> * <target> * <jar> * .... * </jar> * <javac> * .... * </javac> * </target> * </pre> * <p> * It is not an error to have a class that extends <tt>Task * that doesn't have {@link XmlRootElement}. But they can't show up in an * XML instance (because they don't have XML element names). * * <p>Example 2: XML Schema Susbstitution group support * <p> The following example shows the annotations for XML Schema * substitution groups. The annotations and the ObjectFactory are * derived from the schema. * * <pre> * @XmlElement * class Math { * // The value of {@link #type()}is * // JAXBElement.class , which indicates the XML * // element name ObjectFactory - in general a class marked * // with @XmlRegistry. (See ObjectFactory below) * // * // The {@link #name()} is "operator", a pointer to a * // factory method annotated with a * // {@link XmlElementDecl} with the name "operator". Since * // "operator" is the head of a substitution group that * // contains elements "add" and "sub" elements, "operator" * // element can be substituted in an instance document by * // elements "add" or "sub". At runtime, JAXBElement * // instance contains the element name that has been * // substituted in the XML document. * // * @XmlElementRef(type=JAXBElement.class,name="operator") * JAXBElement<? extends Operator> term; * } * * @XmlRegistry * class ObjectFactory { * @XmlElementDecl(name="operator") * JAXBElement<Operator> createOperator(Operator o) {...} * @XmlElementDecl(name="add",substitutionHeadName="operator") * JAXBElement<Operator> createAdd(Operator o) {...} * @XmlElementDecl(name="sub",substitutionHeadName="operator") * JAXBElement<Operator> createSub(Operator o) {...} * } * * class Operator { * ... * } * </pre> * <p> * Thus, the following code fragment * <pre> * Math m = new Math(); * m.term = new ObjectFactory().createAdd(new Operator()); * marshal(m); * </pre> * will produce the following XML output: * <pre> * <math> * <add>...</add> * </math> * </pre> * * * @author <ul> Other Java examples (source code examples)Here is a short list of links related to this Java XmlElementRef.java source code file: |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.