blob: f419bb4b3fc8be9a9be609e439d9331ca5afeea1 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2006, 2007 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.core.internal.content.orm;
import org.eclipse.emf.common.notify.Adapter;
import org.eclipse.emf.common.notify.Notification;
import org.eclipse.emf.common.notify.NotificationChain;
import org.eclipse.emf.ecore.EClass;
import org.eclipse.emf.ecore.InternalEObject;
import org.eclipse.emf.ecore.impl.ENotificationImpl;
import org.eclipse.emf.ecore.util.EcoreUtil;
import org.eclipse.jpt.core.internal.IMappingKeys;
import org.eclipse.jpt.core.internal.mappings.IColumn;
import org.eclipse.jpt.core.internal.mappings.IColumnMapping;
import org.eclipse.jpt.core.internal.mappings.IGeneratedValue;
import org.eclipse.jpt.core.internal.mappings.IId;
import org.eclipse.jpt.core.internal.mappings.ISequenceGenerator;
import org.eclipse.jpt.core.internal.mappings.ITableGenerator;
import org.eclipse.jpt.core.internal.mappings.JpaCoreMappingsPackage;
import org.eclipse.jpt.core.internal.mappings.TemporalType;
import org.eclipse.wst.common.internal.emf.resource.EMF2DOMAdapter;
/**
* <!-- begin-user-doc -->
* A representation of the model object '<em><b>Xml Id</b></em>'.
* <!-- end-user-doc -->
*
*
* @see org.eclipse.jpt.core.internal.content.orm.OrmPackage#getXmlId()
* @model kind="class"
* @generated
*/
public class XmlId extends XmlAttributeMapping
implements IId, IXmlColumnMapping
{
/**
* The cached value of the '{@link #getColumn() <em>Column</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getColumn()
* @generated
* @ordered
*/
protected IColumn column;
/**
* The cached value of the '{@link #getGeneratedValue() <em>Generated Value</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getGeneratedValue()
* @generated
* @ordered
*/
protected IGeneratedValue generatedValue;
/**
* The default value of the '{@link #getTemporal() <em>Temporal</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getTemporal()
* @generated
* @ordered
*/
protected static final TemporalType TEMPORAL_EDEFAULT = TemporalType.NULL;
/**
* The cached value of the '{@link #getTemporal() <em>Temporal</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getTemporal()
* @generated
* @ordered
*/
protected TemporalType temporal = TEMPORAL_EDEFAULT;
/**
* The cached value of the '{@link #getTableGenerator() <em>Table Generator</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getTableGenerator()
* @generated
* @ordered
*/
protected ITableGenerator tableGenerator;
/**
* The cached value of the '{@link #getSequenceGenerator() <em>Sequence Generator</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @see #getSequenceGenerator()
* @generated
* @ordered
*/
protected ISequenceGenerator sequenceGenerator;
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated NOT
*/
protected XmlId() {
super();
this.column = OrmFactory.eINSTANCE.createXmlColumn(buildOwner());
((InternalEObject) this.column).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - OrmPackage.XML_ID__COLUMN, null, null);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EClass eStaticClass() {
return OrmPackage.Literals.XML_ID;
}
/**
* Returns the value of the '<em><b>Column</b></em>' containment reference.
* <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Column</em>' containment reference isn't clear,
* there really should be more of a description here...
* </p>
* <!-- end-user-doc -->
* @return the value of the '<em>Column</em>' containment reference.
* @see org.eclipse.jpt.core.internal.content.orm.OrmPackage#getIId_Column()
* @model containment="true" required="true" changeable="false"
* @generated
*/
public IColumn getColumn() {
return column;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetColumn(IColumn newColumn, NotificationChain msgs) {
IColumn oldColumn = column;
column = newColumn;
if (eNotificationRequired()) {
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__COLUMN, oldColumn, newColumn);
if (msgs == null)
msgs = notification;
else
msgs.add(notification);
}
return msgs;
}
/**
* Returns the value of the '<em><b>Generated Value</b></em>' containment reference.
* <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Generated Value</em>' reference isn't clear,
* there really should be more of a description here...
* </p>
* <!-- end-user-doc -->
* @return the value of the '<em>Generated Value</em>' containment reference.
* @see #setGeneratedValue(IGeneratedValue)
* @see org.eclipse.jpt.core.internal.content.orm.OrmPackage#getIId_GeneratedValue()
* @model containment="true"
* @generated
*/
public IGeneratedValue getGeneratedValue() {
return generatedValue;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetGeneratedValue(IGeneratedValue newGeneratedValue, NotificationChain msgs) {
IGeneratedValue oldGeneratedValue = generatedValue;
generatedValue = newGeneratedValue;
if (eNotificationRequired()) {
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__GENERATED_VALUE, oldGeneratedValue, newGeneratedValue);
if (msgs == null)
msgs = notification;
else
msgs.add(notification);
}
return msgs;
}
/**
* Sets the value of the '{@link org.eclipse.jpt.core.internal.content.orm.XmlId#getGeneratedValue <em>Generated Value</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @param value the new value of the '<em>Generated Value</em>' containment reference.
* @see #getGeneratedValue()
* @generated
*/
public void setGeneratedValue(IGeneratedValue newGeneratedValue) {
if (newGeneratedValue != generatedValue) {
NotificationChain msgs = null;
if (generatedValue != null)
msgs = ((InternalEObject) generatedValue).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - OrmPackage.XML_ID__GENERATED_VALUE, null, msgs);
if (newGeneratedValue != null)
msgs = ((InternalEObject) newGeneratedValue).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - OrmPackage.XML_ID__GENERATED_VALUE, null, msgs);
msgs = basicSetGeneratedValue(newGeneratedValue, msgs);
if (msgs != null)
msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__GENERATED_VALUE, newGeneratedValue, newGeneratedValue));
}
/**
* Returns the value of the '<em><b>Temporal</b></em>' attribute.
* The literals are from the enumeration {@link org.eclipse.jpt.core.internal.mappings.TemporalType}.
* <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Temporal</em>' attribute isn't clear,
* there really should be more of a description here...
* </p>
* <!-- end-user-doc -->
* @return the value of the '<em>Temporal</em>' attribute.
* @see org.eclipse.jpt.core.internal.mappings.TemporalType
* @see #setTemporal(TemporalType)
* @see org.eclipse.jpt.core.internal.content.orm.OrmPackage#getIId_Temporal()
* @model
* @generated
*/
public TemporalType getTemporal() {
return temporal;
}
/**
* Sets the value of the '{@link org.eclipse.jpt.core.internal.content.orm.XmlId#getTemporal <em>Temporal</em>}' attribute.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @param value the new value of the '<em>Temporal</em>' attribute.
* @see org.eclipse.jpt.core.internal.mappings.TemporalType
* @see #getTemporal()
* @generated
*/
public void setTemporal(TemporalType newTemporal) {
TemporalType oldTemporal = temporal;
temporal = newTemporal == null ? TEMPORAL_EDEFAULT : newTemporal;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__TEMPORAL, oldTemporal, temporal));
}
/**
* Returns the value of the '<em><b>Table Generator</b></em>' containment reference.
* <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Table Generator</em>' reference isn't clear,
* there really should be more of a description here...
* </p>
* <!-- end-user-doc -->
* @return the value of the '<em>Table Generator</em>' containment reference.
* @see #setTableGenerator(ITableGenerator)
* @see org.eclipse.jpt.core.internal.content.orm.OrmPackage#getIId_TableGenerator()
* @model containment="true"
* @generated
*/
public ITableGenerator getTableGenerator() {
return tableGenerator;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetTableGenerator(ITableGenerator newTableGenerator, NotificationChain msgs) {
ITableGenerator oldTableGenerator = tableGenerator;
tableGenerator = newTableGenerator;
if (eNotificationRequired()) {
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__TABLE_GENERATOR, oldTableGenerator, newTableGenerator);
if (msgs == null)
msgs = notification;
else
msgs.add(notification);
}
return msgs;
}
/**
* Sets the value of the '{@link org.eclipse.jpt.core.internal.content.orm.XmlId#getTableGenerator <em>Table Generator</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @param value the new value of the '<em>Table Generator</em>' containment reference.
* @see #getTableGenerator()
* @generated
*/
public void setTableGenerator(ITableGenerator newTableGenerator) {
if (newTableGenerator != tableGenerator) {
NotificationChain msgs = null;
if (tableGenerator != null)
msgs = ((InternalEObject) tableGenerator).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - OrmPackage.XML_ID__TABLE_GENERATOR, null, msgs);
if (newTableGenerator != null)
msgs = ((InternalEObject) newTableGenerator).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - OrmPackage.XML_ID__TABLE_GENERATOR, null, msgs);
msgs = basicSetTableGenerator(newTableGenerator, msgs);
if (msgs != null)
msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__TABLE_GENERATOR, newTableGenerator, newTableGenerator));
}
/**
* Returns the value of the '<em><b>Sequence Generator</b></em>' containment reference.
* <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Sequence Generator</em>' reference isn't clear,
* there really should be more of a description here...
* </p>
* <!-- end-user-doc -->
* @return the value of the '<em>Sequence Generator</em>' containment reference.
* @see #setSequenceGenerator(ISequenceGenerator)
* @see org.eclipse.jpt.core.internal.content.orm.OrmPackage#getIId_SequenceGenerator()
* @model containment="true"
* @generated
*/
public ISequenceGenerator getSequenceGenerator() {
return sequenceGenerator;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public NotificationChain basicSetSequenceGenerator(ISequenceGenerator newSequenceGenerator, NotificationChain msgs) {
ISequenceGenerator oldSequenceGenerator = sequenceGenerator;
sequenceGenerator = newSequenceGenerator;
if (eNotificationRequired()) {
ENotificationImpl notification = new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__SEQUENCE_GENERATOR, oldSequenceGenerator, newSequenceGenerator);
if (msgs == null)
msgs = notification;
else
msgs.add(notification);
}
return msgs;
}
/**
* Sets the value of the '{@link org.eclipse.jpt.core.internal.content.orm.XmlId#getSequenceGenerator <em>Sequence Generator</em>}' containment reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @param value the new value of the '<em>Sequence Generator</em>' containment reference.
* @see #getSequenceGenerator()
* @generated
*/
public void setSequenceGenerator(ISequenceGenerator newSequenceGenerator) {
if (newSequenceGenerator != sequenceGenerator) {
NotificationChain msgs = null;
if (sequenceGenerator != null)
msgs = ((InternalEObject) sequenceGenerator).eInverseRemove(this, EOPPOSITE_FEATURE_BASE - OrmPackage.XML_ID__SEQUENCE_GENERATOR, null, msgs);
if (newSequenceGenerator != null)
msgs = ((InternalEObject) newSequenceGenerator).eInverseAdd(this, EOPPOSITE_FEATURE_BASE - OrmPackage.XML_ID__SEQUENCE_GENERATOR, null, msgs);
msgs = basicSetSequenceGenerator(newSequenceGenerator, msgs);
if (msgs != null)
msgs.dispatch();
}
else if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__SEQUENCE_GENERATOR, newSequenceGenerator, newSequenceGenerator));
}
/**
* Returns the value of the '<em><b>Column For Xml</b></em>' reference.
* <!-- begin-user-doc -->
* <p>
* If the meaning of the '<em>Column For Xml</em>' reference isn't clear,
* there really should be more of a description here...
* </p>
* <!-- end-user-doc -->
* @return the value of the '<em>Column For Xml</em>' reference.
* @see #setColumnForXml(XmlColumn)
* @see org.eclipse.jpt.core.internal.content.orm.OrmPackage#getIXmlColumnMapping_ColumnForXml()
* @model resolveProxies="false" volatile="true"
* @generated NOT
*/
public XmlColumn getColumnForXml() {
if (((XmlColumn) getColumn()).isAllFeaturesUnset()) {
return null;
}
return (XmlColumn) getColumn();
}
/**
* Sets the value of the '{@link org.eclipse.jpt.core.internal.content.orm.XmlId#getColumnForXml <em>Column For Xml</em>}' reference.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @param value the new value of the '<em>Column For Xml</em>' reference.
* @see #getColumnForXml()
* @generated NOT
*/
public void setColumnForXmlGen(XmlColumn newColumnForXml) {
XmlColumn oldValue = newColumnForXml == null ? (XmlColumn) getColumn() : null;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, OrmPackage.XML_ID__COLUMN_FOR_XML, oldValue, newColumnForXml));
}
public void setColumnForXml(XmlColumn newColumnForXml) {
setColumnForXmlGen(newColumnForXml);
if (newColumnForXml == null) {
((XmlColumn) getColumn()).unsetAllAttributes();
//Bug 191067 more translators hackery. Remove their listener since it is not getting removed by them.
//this will allow us to later add this tag back in to the xml. When we switch to the
//resource model approach in 2.0, we shouldn't need the *forXml objects.
Adapter adapter = EcoreUtil.getExistingAdapter(getColumn(), EMF2DOMAdapter.ADAPTER_CLASS);
((XmlColumn) getColumn()).eAdapters().remove(adapter);
}
}
public void makeColumnForXmlNonNull() {
setColumnForXmlGen(getColumnForXml());
}
public void makeColumnForXmlNull() {
setColumnForXmlGen(null);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) {
switch (featureID) {
case OrmPackage.XML_ID__COLUMN :
return basicSetColumn(null, msgs);
case OrmPackage.XML_ID__GENERATED_VALUE :
return basicSetGeneratedValue(null, msgs);
case OrmPackage.XML_ID__TABLE_GENERATOR :
return basicSetTableGenerator(null, msgs);
case OrmPackage.XML_ID__SEQUENCE_GENERATOR :
return basicSetSequenceGenerator(null, msgs);
}
return super.eInverseRemove(otherEnd, featureID, msgs);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public Object eGet(int featureID, boolean resolve, boolean coreType) {
switch (featureID) {
case OrmPackage.XML_ID__COLUMN :
return getColumn();
case OrmPackage.XML_ID__GENERATED_VALUE :
return getGeneratedValue();
case OrmPackage.XML_ID__TEMPORAL :
return getTemporal();
case OrmPackage.XML_ID__TABLE_GENERATOR :
return getTableGenerator();
case OrmPackage.XML_ID__SEQUENCE_GENERATOR :
return getSequenceGenerator();
case OrmPackage.XML_ID__COLUMN_FOR_XML :
return getColumnForXml();
}
return super.eGet(featureID, resolve, coreType);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eSet(int featureID, Object newValue) {
switch (featureID) {
case OrmPackage.XML_ID__GENERATED_VALUE :
setGeneratedValue((IGeneratedValue) newValue);
return;
case OrmPackage.XML_ID__TEMPORAL :
setTemporal((TemporalType) newValue);
return;
case OrmPackage.XML_ID__TABLE_GENERATOR :
setTableGenerator((ITableGenerator) newValue);
return;
case OrmPackage.XML_ID__SEQUENCE_GENERATOR :
setSequenceGenerator((ISequenceGenerator) newValue);
return;
case OrmPackage.XML_ID__COLUMN_FOR_XML :
setColumnForXml((XmlColumn) newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case OrmPackage.XML_ID__GENERATED_VALUE :
setGeneratedValue((IGeneratedValue) null);
return;
case OrmPackage.XML_ID__TEMPORAL :
setTemporal(TEMPORAL_EDEFAULT);
return;
case OrmPackage.XML_ID__TABLE_GENERATOR :
setTableGenerator((ITableGenerator) null);
return;
case OrmPackage.XML_ID__SEQUENCE_GENERATOR :
setSequenceGenerator((ISequenceGenerator) null);
return;
case OrmPackage.XML_ID__COLUMN_FOR_XML :
setColumnForXml((XmlColumn) null);
return;
}
super.eUnset(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case OrmPackage.XML_ID__COLUMN :
return column != null;
case OrmPackage.XML_ID__GENERATED_VALUE :
return generatedValue != null;
case OrmPackage.XML_ID__TEMPORAL :
return temporal != TEMPORAL_EDEFAULT;
case OrmPackage.XML_ID__TABLE_GENERATOR :
return tableGenerator != null;
case OrmPackage.XML_ID__SEQUENCE_GENERATOR :
return sequenceGenerator != null;
case OrmPackage.XML_ID__COLUMN_FOR_XML :
return getColumnForXml() != null;
}
return super.eIsSet(featureID);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public int eBaseStructuralFeatureID(int derivedFeatureID, Class<?> baseClass) {
if (baseClass == IColumnMapping.class) {
switch (derivedFeatureID) {
default :
return -1;
}
}
if (baseClass == IId.class) {
switch (derivedFeatureID) {
case OrmPackage.XML_ID__COLUMN :
return JpaCoreMappingsPackage.IID__COLUMN;
case OrmPackage.XML_ID__GENERATED_VALUE :
return JpaCoreMappingsPackage.IID__GENERATED_VALUE;
case OrmPackage.XML_ID__TEMPORAL :
return JpaCoreMappingsPackage.IID__TEMPORAL;
case OrmPackage.XML_ID__TABLE_GENERATOR :
return JpaCoreMappingsPackage.IID__TABLE_GENERATOR;
case OrmPackage.XML_ID__SEQUENCE_GENERATOR :
return JpaCoreMappingsPackage.IID__SEQUENCE_GENERATOR;
default :
return -1;
}
}
if (baseClass == IXmlColumnMapping.class) {
switch (derivedFeatureID) {
case OrmPackage.XML_ID__COLUMN_FOR_XML :
return OrmPackage.IXML_COLUMN_MAPPING__COLUMN_FOR_XML;
default :
return -1;
}
}
return super.eBaseStructuralFeatureID(derivedFeatureID, baseClass);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public int eDerivedStructuralFeatureID(int baseFeatureID, Class<?> baseClass) {
if (baseClass == IColumnMapping.class) {
switch (baseFeatureID) {
default :
return -1;
}
}
if (baseClass == IId.class) {
switch (baseFeatureID) {
case JpaCoreMappingsPackage.IID__COLUMN :
return OrmPackage.XML_ID__COLUMN;
case JpaCoreMappingsPackage.IID__GENERATED_VALUE :
return OrmPackage.XML_ID__GENERATED_VALUE;
case JpaCoreMappingsPackage.IID__TEMPORAL :
return OrmPackage.XML_ID__TEMPORAL;
case JpaCoreMappingsPackage.IID__TABLE_GENERATOR :
return OrmPackage.XML_ID__TABLE_GENERATOR;
case JpaCoreMappingsPackage.IID__SEQUENCE_GENERATOR :
return OrmPackage.XML_ID__SEQUENCE_GENERATOR;
default :
return -1;
}
}
if (baseClass == IXmlColumnMapping.class) {
switch (baseFeatureID) {
case OrmPackage.IXML_COLUMN_MAPPING__COLUMN_FOR_XML :
return OrmPackage.XML_ID__COLUMN_FOR_XML;
default :
return -1;
}
}
return super.eDerivedStructuralFeatureID(baseFeatureID, baseClass);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
public String toString() {
if (eIsProxy())
return super.toString();
StringBuffer result = new StringBuffer(super.toString());
result.append(" (temporal: ");
result.append(temporal);
result.append(')');
return result.toString();
}
public String getKey() {
return IMappingKeys.ID_ATTRIBUTE_MAPPING_KEY;
}
@Override
protected void initializeOn(XmlAttributeMapping newMapping) {
newMapping.initializeFromXmlIdMapping(this);
}
@Override
public void initializeFromXmlBasicMapping(XmlBasic oldMapping) {
super.initializeFromXmlBasicMapping(oldMapping);
setTemporal(oldMapping.getTemporal());
}
@Override
public int xmlSequence() {
return 0;
}
public String primaryKeyColumnName() {
return this.getColumn().getName();
}
public IGeneratedValue createGeneratedValue() {
return OrmFactory.eINSTANCE.createXmlGeneratedValue();
}
public ISequenceGenerator createSequenceGenerator() {
return OrmFactory.eINSTANCE.createXmlSequenceGenerator();
}
public ITableGenerator createTableGenerator() {
return OrmFactory.eINSTANCE.createXmlTableGenerator();
}
@Override
public boolean isOverridableAttributeMapping() {
return true;
}
@Override
public boolean isIdMapping() {
return true;
}
}