blob: 0d31b6a6592e7c6483f2dc5be49b806254f4c438 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2011 Oracle. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0, which accompanies this distribution
* and is available at http://www.eclipse.org/legal/epl-v10.html.
*
* Contributors:
* Oracle - initial API and implementation
******************************************************************************/
package org.eclipse.jpt.jaxb.core.internal.context.java;
import java.util.List;
import org.eclipse.jdt.core.dom.CompilationUnit;
import org.eclipse.jpt.jaxb.core.MappingKeys;
import org.eclipse.jpt.jaxb.core.context.JaxbPersistentAttribute;
import org.eclipse.jpt.jaxb.core.context.XmlAdaptable;
import org.eclipse.jpt.jaxb.core.context.XmlJavaTypeAdapter;
import org.eclipse.jpt.jaxb.core.context.XmlValueMapping;
import org.eclipse.jpt.jaxb.core.resource.java.JavaResourceAnnotatedElement;
import org.eclipse.jpt.jaxb.core.resource.java.XmlJavaTypeAdapterAnnotation;
import org.eclipse.jpt.jaxb.core.resource.java.XmlValueAnnotation;
import org.eclipse.wst.validation.internal.provisional.core.IMessage;
import org.eclipse.wst.validation.internal.provisional.core.IReporter;
public class GenericJavaXmlValueMapping
extends AbstractJavaAttributeMapping<XmlValueAnnotation>
implements XmlValueMapping
{
protected final XmlAdaptable xmlAdaptable;
public GenericJavaXmlValueMapping(JaxbPersistentAttribute parent) {
super(parent);
this.xmlAdaptable = buildXmlAdaptable();
}
@Override
public void synchronizeWithResourceModel() {
super.synchronizeWithResourceModel();
this.xmlAdaptable.synchronizeWithResourceModel();
}
@Override
public void update() {
super.update();
this.xmlAdaptable.update();
}
public String getKey() {
return MappingKeys.XML_VALUE_ATTRIBUTE_MAPPING_KEY;
}
@Override
protected String getAnnotationName() {
return XmlValueAnnotation.ANNOTATION_NAME;
}
//****************** XmlJavaTypeAdapter *********************
public XmlAdaptable buildXmlAdaptable() {
return new GenericJavaXmlAdaptable(this, new XmlAdaptable.Owner() {
public JavaResourceAnnotatedElement getResource() {
return getJavaResourceAttribute();
}
public XmlJavaTypeAdapter buildXmlJavaTypeAdapter(XmlJavaTypeAdapterAnnotation adapterAnnotation) {
return GenericJavaXmlValueMapping.this.buildXmlJavaTypeAdapter(adapterAnnotation);
}
public void fireXmlAdapterChanged(XmlJavaTypeAdapter oldAdapter, XmlJavaTypeAdapter newAdapter) {
GenericJavaXmlValueMapping.this.firePropertyChanged(XML_JAVA_TYPE_ADAPTER_PROPERTY, oldAdapter, newAdapter);
}
});
}
public XmlJavaTypeAdapter getXmlJavaTypeAdapter() {
return this.xmlAdaptable.getXmlJavaTypeAdapter();
}
public XmlJavaTypeAdapter addXmlJavaTypeAdapter() {
return this.xmlAdaptable.addXmlJavaTypeAdapter();
}
protected XmlJavaTypeAdapter buildXmlJavaTypeAdapter(XmlJavaTypeAdapterAnnotation xmlJavaTypeAdapterAnnotation) {
return new GenericJavaAttributeXmlJavaTypeAdapter(this, xmlJavaTypeAdapterAnnotation);
}
public void removeXmlJavaTypeAdapter() {
this.xmlAdaptable.removeXmlJavaTypeAdapter();
}
//****************** validation *********************
@Override
public void validate(List<IMessage> messages, IReporter reporter, CompilationUnit astRoot) {
// TODO Auto-generated method stub
super.validate(messages, reporter, astRoot);
}
//validation:
// If a class contains a mapped property or field annotated with
// @XmlValue annotation, then all other mapped fields or properties in the
// class must be mapped to an XML attribute.
//if the class, subClass, derives from another XML-bound class, baseClass
// directly or indirectly (other than java.lang.Object), then the subClass
// must not contain a mapped property or field annotated with @XmlValue
// annotation.
//The containing class must not extend another class (other than java.lang.Obect).
//If the type of the field or property is a collection type, then the
// collection item type must map to a simple schema type. Examples:
// // Examples (not exhaustive): Legal usage of @XmlValue
// @XmlValue List<Integer> foo; // int maps to xs:int
// @XmlValue String[] foo; // String maps to xs:string
// @XmlValue List<Bar> foo; // only if Bar maps to a simple schema type
// If the type of the field or property is not a collection type, then the type
// of the property or field must map to a schema simple type.
}