Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristian W. Damus2013-01-06 18:59:09 +0000
committerChristian W. Damus2013-01-06 19:00:41 +0000
commit53d0b136b63e086d7af9865be12b0c51abac7288 (patch)
tree27f03aac889adfca6d39fe8f8ae00001c96d5bf2 /plugins/org.eclipse.emf.cdo.common
parentb3750dcebc2bb70a7e6547f329e1e1054f6a2adb (diff)
downloadcdo-53d0b136b63e086d7af9865be12b0c51abac7288.tar.gz
cdo-53d0b136b63e086d7af9865be12b0c51abac7288.tar.xz
cdo-53d0b136b63e086d7af9865be12b0c51abac7288.zip
[378620] [Legacy] ClassCastException in unsettable attribute of Custom Datatype
https://bugs.eclipse.org/bugs/show_bug.cgi?id=378620
Diffstat (limited to 'plugins/org.eclipse.emf.cdo.common')
-rw-r--r--plugins/org.eclipse.emf.cdo.common/src/org/eclipse/emf/cdo/internal/common/model/CDOTypeImpl.java9
1 files changed, 6 insertions, 3 deletions
diff --git a/plugins/org.eclipse.emf.cdo.common/src/org/eclipse/emf/cdo/internal/common/model/CDOTypeImpl.java b/plugins/org.eclipse.emf.cdo.common/src/org/eclipse/emf/cdo/internal/common/model/CDOTypeImpl.java
index fbd2724e8d..cfb23b8e55 100644
--- a/plugins/org.eclipse.emf.cdo.common/src/org/eclipse/emf/cdo/internal/common/model/CDOTypeImpl.java
+++ b/plugins/org.eclipse.emf.cdo.common/src/org/eclipse/emf/cdo/internal/common/model/CDOTypeImpl.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2004 - 2012 Eike Stepper (Berlin, Germany) and others.
+ * Copyright (c) 2004 - 2013 Eike Stepper (Berlin, Germany) 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
@@ -9,6 +9,7 @@
* Eike Stepper - initial API and implementation
* Stefan Winkler - Bug 299194: unsettable features inconsistent between revisions
* Erdal Karaca - added support for HASHMAP CDO Type
+ * Christian W. Damus (CEA) - 378620 support unsettable features of custom data type
*/
package org.eclipse.emf.cdo.internal.common.model;
@@ -34,6 +35,7 @@ import org.eclipse.emf.ecore.EEnum;
import org.eclipse.emf.ecore.EEnumLiteral;
import org.eclipse.emf.ecore.EPackage;
import org.eclipse.emf.ecore.EStructuralFeature;
+import org.eclipse.emf.ecore.EStructuralFeature.Internal.DynamicValueHolder;
import org.eclipse.emf.ecore.EcorePackage;
import org.eclipse.emf.ecore.util.EcoreUtil;
import org.eclipse.emf.ecore.util.FeatureMap;
@@ -569,13 +571,14 @@ public abstract class CDOTypeImpl implements CDOType
@Override
public Object convertToEMF(EClassifier eType, Object value)
{
- return EcoreUtil.createFromString((EDataType)eType, (String)value);
+ return value == CDORevisionData.NIL ? DynamicValueHolder.NIL : EcoreUtil.createFromString((EDataType)eType,
+ (String)value);
}
@Override
public Object convertToCDO(EClassifier eType, Object value)
{
- return EcoreUtil.convertToString((EDataType)eType, value);
+ return value == DynamicValueHolder.NIL ? CDORevisionData.NIL : EcoreUtil.convertToString((EDataType)eType, value);
}
};

Back to the top