Skip to main content

Notice: This Wiki is now read only and edits are no longer possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.

Jump to: navigation, search

Difference between revisions of "EclipseLink/DesignDocs/293925/Phase6"

Line 6: Line 6:
 
== Annotations  ==
 
== Annotations  ==
  
The following annotations will be targetted in this phase:  
+
The following annotations will be targeted in this phase:  
  
 
{|{{BMTableStyle}}
 
{|{{BMTableStyle}}
Line 38: Line 38:
 
| align="center" | X<br>
 
| align="center" | X<br>
 
|}
 
|}
 +
== Example: XmlElements annotation ==
 +
 +
=== Java Metadata  ===
 +
 +
The following example will demonstrate how the [http://java.sun.com/javase/6/docs/api/javax/xml/bind/annotation/XmlElements.html XmlElements] annotation can be applied:
 +
 +
==== org.example.Foo.java  ====
 +
 +
<source lang="java">
 +
package org.example;
 +
 +
@javax.xml.bind.annotation.XmlRootElement
 +
public class Foo {
 +
    @javax.xml.bind.annotation.XmlElementWrapper(name="items")
 +
    @javax.xml.bind.annotation.XmlElements({
 +
        @javax.xml.bind.annotation.XmlElement(name="A", type=Integer.class),
 +
        @javax.xml.bind.annotation.XmlElement(name="B", type=Float.class)
 +
    })
 +
    public java.util.List items;
 +
}
 +
</source>
 +
 +
=== XML Metadata  ===
 +
 +
==== xml-elements  ====
 +
 +
If this is present, the entire annotation will be replaced.
 +
 +
==== org/example/eclipselink-oxm.xml  ====
 +
 +
This XML file represents metadata overrides for the "org.example.Foo" class.
 +
 +
<source lang="xml">
 +
<?xml version="1.0" encoding="US-ASCII"?>
 +
<xml-bindings xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/oxm">
 +
<java-types>
 +
<java-type name="org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlelements.Foo">
 +
            <xml-root-element name="foo"/>
 +
            <java-attributes>
 +
                <xml-elements java-attribute="items">
 +
                    <xml-element java-attribute="A" type="java.lang.Integer" />
 +
                    <xml-element java-attribute="B" type="java.lang.Float" />
 +
                </xml-elements>
 +
            </java-attributes>
 +
</java-type>
 +
</java-types>
 +
</xml-bindings>
 +
</source>

Revision as of 15:01, 2 December 2009

Phase 6 - Substitution Groups (page under construction)

Provide support for substitution groups.

Annotations

The following annotations will be targeted in this phase:

Annotation XML Metadata Tag Package Type Field Method
XmlElements xml-elements     X X
XmlElementRef xml-element-ref     X X
XmlElementRefs xml-element-refs X
X

Example: XmlElements annotation

Java Metadata

The following example will demonstrate how the XmlElements annotation can be applied:

org.example.Foo.java

package org.example;
 
@javax.xml.bind.annotation.XmlRootElement
public class Foo {
    @javax.xml.bind.annotation.XmlElementWrapper(name="items")
    @javax.xml.bind.annotation.XmlElements({
        @javax.xml.bind.annotation.XmlElement(name="A", type=Integer.class),
        @javax.xml.bind.annotation.XmlElement(name="B", type=Float.class)
    })
    public java.util.List items;
}

XML Metadata

xml-elements

If this is present, the entire annotation will be replaced.

org/example/eclipselink-oxm.xml

This XML file represents metadata overrides for the "org.example.Foo" class.

<?xml version="1.0" encoding="US-ASCII"?>
<xml-bindings xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/oxm">
	<java-types>
		<java-type name="org.eclipse.persistence.testing.jaxb.externalizedmetadata.xmlelements.Foo">
            <xml-root-element name="foo"/>
            <java-attributes>
                <xml-elements java-attribute="items">
                    <xml-element java-attribute="A" type="java.lang.Integer" />
                    <xml-element java-attribute="B" type="java.lang.Float" />
                </xml-elements>
            </java-attributes>
		</java-type>
	</java-types>
</xml-bindings>

Back to the top