/* * grEMF * * Copyright (C) 2006-2012 Institute for Software Technology * University of Koblenz-Landau, Germany * ist@uni-koblenz.de * * For bug reports, documentation and further information, visit * * https://github.com/jgralab/gremf * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 3 of the License, or (at your * option) any later version. * * This program is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General * Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, see <http://www.gnu.org/licenses>. * * Additional permission under GNU GPL version 3 section 7 * * If you modify this Program, or any covered work, by linking or combining * it with Eclipse (or a modified version of that program or an Eclipse * plugin), containing parts covered by the terms of the Eclipse Public * License (EPL), the licensors of this Program grant you additional * permission to convey the resulting work. Corresponding Source for a * non-source form of such a combination shall include the source code for * the parts of JGraLab used as well as that of the covered work. */ package de.uni_koblenz.gremf.schema.impl; import java.util.Map; import java.util.Map.Entry; import org.eclipse.emf.ecore.EDataType; import org.eclipse.emf.ecore.EcoreFactory; import org.pcollections.ArrayPMap; import org.pcollections.PMap; import de.uni_koblenz.gremf.schema.GrEMFCollectionDomain; import de.uni_koblenz.gremf.schema.GrEMFCompositeDomain; import de.uni_koblenz.gremf.schema.GrEMFDomain; import de.uni_koblenz.jgralab.schema.Domain; import de.uni_koblenz.jgralab.schema.Schema; import de.uni_koblenz.jgralab.schema.impl.MapDomainImpl; public class GrEMFMapDomainImpl extends MapDomainImpl implements GrEMFCompositeDomain { private static EDataType emfDataType; private boolean containsRecordOrEnumDomain; protected GrEMFMapDomainImpl(Schema schema, Domain aKeyDomain, Domain aValueDomain) { super(schema, aKeyDomain, aValueDomain); if (emfDataType == null) { emfDataType = EcoreFactory.eINSTANCE.createEDataType(); emfDataType.setInstanceClass(Map.class); emfDataType.setInstanceClassName("java.util.Map"); emfDataType.setInstanceTypeName("java.util.Map"); emfDataType.setName("java.util.Map"); emfDataType.setSerializable(true); } if ((aKeyDomain instanceof GrEMFEnumDomainImpl) || (aValueDomain instanceof GrEMFEnumDomainImpl)) { this.containsRecordOrEnumDomain = true; } else if ((aKeyDomain instanceof GrEMFRecordDomainImpl) || (aValueDomain instanceof GrEMFRecordDomainImpl)) { this.containsRecordOrEnumDomain = true; } else if ((aKeyDomain instanceof GrEMFDateDomainImpl) || (aValueDomain instanceof GrEMFDateDomainImpl)) { this.containsRecordOrEnumDomain = true; } else if (aKeyDomain instanceof GrEMFCompositeDomain) { this.containsRecordOrEnumDomain = ((GrEMFCompositeDomain) aKeyDomain) .containsRecordOrEnumDomain(); if (aValueDomain instanceof GrEMFCompositeDomain) { this.containsRecordOrEnumDomain |= ((GrEMFCompositeDomain) aValueDomain) .containsRecordOrEnumDomain(); } } else if (aValueDomain instanceof GrEMFCompositeDomain) { this.containsRecordOrEnumDomain = ((GrEMFCompositeDomain) aValueDomain) .containsRecordOrEnumDomain(); } if (aKeyDomain instanceof GrEMFCollectionDomain) { ((GrEMFCollectionDomain) aKeyDomain).setComponentOfOtherDomain(); } if (aValueDomain instanceof GrEMFCollectionDomain) { ((GrEMFCollectionDomain) aValueDomain).setComponentOfOtherDomain(); } } @Override public EDataType getEMFDataType() { return emfDataType; } @Override public Object getDefaultValue() { return null; } @Override public Object getEMFValue(Object jgralabValue) { if ((jgralabValue != null) && this.containsRecordOrEnumDomain) { Map<?, ?> jgraMap = (Map<?, ?>) jgralabValue; PMap<Object, Object> map = ArrayPMap.empty(); for (Entry<?, ?> e : jgraMap.entrySet()) { map = map.plus(((GrEMFDomain) this.getKeyDomain()) .getEMFValue(e.getKey()), ((GrEMFDomain) this .getValueDomain()).getEMFValue(e.getValue())); } return map; } else { return jgralabValue; } } @Override public Object getJGraLabValue(Object emfValue) { if ((emfValue != null) && (this.containsRecordOrEnumDomain || !(emfValue instanceof PMap))) { Map<?, ?> emfMap = (Map<?, ?>) emfValue; PMap<Object, Object> map = ArrayPMap.empty(); for (Entry<?, ?> e : emfMap.entrySet()) { map = map.plus(((GrEMFDomain) this.getKeyDomain()) .getJGraLabValue(e.getKey()), ((GrEMFDomain) this .getValueDomain()).getJGraLabValue(e.getValue())); } return map; } else { return emfValue; } } @Override public boolean containsRecordOrEnumDomain() { return this.containsRecordOrEnumDomain; } }