/* * Copyright (c) 2004, 2010, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package javax.xml.bind.annotation; import java.lang.annotation.Target; import java.lang.annotation.Retention; import static java.lang.annotation.ElementType.*; import static java.lang.annotation.RetentionPolicy.*; /** *
* Enables mapping a class to a XML Schema complex type with a * simpleContent or a XML Schema simple type. *
* ** Usage: *
* The @XmlValue annotation can be used with the following program * elements: *
See "Package Specification" in javax.xml.bind.package javadoc for * additional common information.
* * The usage is subject to the following usage constraints: ** If the annotated JavaBean property is the sole class member being * mapped to XML Schema construct, then the class is mapped to a * simple type. * * If there are additional JavaBean properties (other than the * JavaBean property annotated with @XmlValue annotation) * that are mapped to XML attributes, then the class is mapped to a * complex type with simpleContent. *
* *Example 1: Map a class to XML Schema simpleType
* *
*
* // Example 1: Code fragment
* public class USPrice {
* @XmlValue
* public java.math.BigDecimal price;
* }
*
* <!-- Example 1: XML Schema fragment -->
* <xs:simpleType name="USPrice">
* <xs:restriction base="xs:decimal"/>
* </xs:simpleType>
*
*
*
* Example 2: Map a class to XML Schema complexType with * with simpleContent.
* *
*
* // Example 2: Code fragment
* public class InternationalPrice {
* @XmlValue
* public java.math.BigDecimal price;
*
* @XmlAttribute
* public String currency;
* }
*
* <!-- Example 2: XML Schema fragment -->
* <xs:complexType name="InternationalPrice">
* <xs:simpleContent>
* <xs:extension base="xs:decimal">
* <xs:attribute name="currency" type="xs:string"/>
* </xs:extension>
* </xs:simpleContent>
* </xs:complexType>
*
*
*
*
* @author Sekhar Vajjhala, Sun Microsystems, Inc.
* @see XmlType
* @since JAXB2.0
*/
@Retention(RUNTIME) @Target({FIELD, METHOD})
public @interface XmlValue {}