diff options
Diffstat (limited to 'hibernate/org.eclipse.emf.teneo.hibernate.mapper/src/org/eclipse/emf/teneo/hibernate/cdo/CDOMappingContext.java')
-rwxr-xr-x | hibernate/org.eclipse.emf.teneo.hibernate.mapper/src/org/eclipse/emf/teneo/hibernate/cdo/CDOMappingContext.java | 108 |
1 files changed, 108 insertions, 0 deletions
diff --git a/hibernate/org.eclipse.emf.teneo.hibernate.mapper/src/org/eclipse/emf/teneo/hibernate/cdo/CDOMappingContext.java b/hibernate/org.eclipse.emf.teneo.hibernate.mapper/src/org/eclipse/emf/teneo/hibernate/cdo/CDOMappingContext.java new file mode 100755 index 000000000..15959d834 --- /dev/null +++ b/hibernate/org.eclipse.emf.teneo.hibernate.mapper/src/org/eclipse/emf/teneo/hibernate/cdo/CDOMappingContext.java @@ -0,0 +1,108 @@ +/*************************************************************************** + * Copyright (c) 2004 - 2008 Springsite B.V. and others + * 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: + * Martin Taal - initial API and implementation + **************************************************************************/ +package org.eclipse.emf.teneo.hibernate.cdo; + +import org.eclipse.emf.teneo.annotations.pamodel.PAnnotatedEClass; +import org.eclipse.emf.teneo.extension.ExtensionManager; +import org.eclipse.emf.teneo.hibernate.mapper.EntityMapper; +import org.eclipse.emf.teneo.hibernate.mapper.MappingContext; +import org.eclipse.emf.teneo.simpledom.Element; + +/** + * Mapping context for CDO. It provides cdo classes as propertyhandler etc. + * + * @author <a href="mtaal@elver.org">Martin Taal</a> + */ +public class CDOMappingContext extends MappingContext { + + /** Add a tuplizer element or not */ + @Override + public void addTuplizerElement(Element entityElement, PAnnotatedEClass aclass) { + Element tuplizerElement = + new Element("tuplizer").addAttribute("entity-mode", "dynamic-map").addAttribute("class", + "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDORevisionTuplizer"); + entityElement.add(0, tuplizerElement); + tuplizerElement = + new Element("tuplizer").addAttribute("entity-mode", "pojo").addAttribute("class", + "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDORevisionTuplizer"); + entityElement.add(0, tuplizerElement); + } + + public void setExtensionManager(ExtensionManager extensionManager) { + super.setExtensionManager(extensionManager); + extensionManager.registerExtension(EntityMapper.class.getName(), CDOEntityMapper.class.getName()); + } + + @Override + public String getComponentPropertyHandlerName() { + return super.getComponentPropertyHandlerName(); + } + + @Override + public String getIdPropertyHandlerName() { + return null; + } + + @Override + public String getPropertyHandlerName() { + return super.getPropertyHandlerName(); + } + + @Override + public String getVersionPropertyHandlerName() { + return null; + } + + @Override + public String getEnumUserType() { + return "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDOENumStringType"; + } + + @Override + public String getEnumIntegerUserType() { + return "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDOENumIntegerType"; + } + + @Override + public String getSyntheticIdPropertyHandlerName() { + return "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDOSyntheticIdPropertyHandler"; + } + + @Override + public String getSyntheticVersionPropertyHandlerName() { + return "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDOSyntheticVersionPropertyHandler"; + } + + @Override + public String getDynamicEnumUserType() { + return "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDOENumStringType"; + } + + @Override + public String getDynamicEnumIntegerUserType() { + return "org.eclipse.emf.cdo.server.internal.hibernate.tuplizer.CDOENumIntegerType"; + } + + @Override + public String getDefaultUserType() { + return super.getDefaultUserType(); + } + + @Override + public String getXSDDateUserType() { + return super.getXSDDateUserType(); + } + + @Override + public String getXSDDateTimeUserType() { + return super.getXSDDateTimeUserType(); + } +} |