]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.objmap2/src/org/simantics/objmap/internal/MonotoneBackwardMapping.java
Migrated source code from Simantics SVN
[simantics/platform.git] / bundles / org.simantics.objmap2 / src / org / simantics / objmap / internal / MonotoneBackwardMapping.java
1 /*******************************************************************************\r
2  * Copyright (c) 2012, 2013 Association for Decentralized Information Management in\r
3  * Industry THTH ry.\r
4  * All rights reserved. This program and the accompanying materials\r
5  * are made available under the terms of the Eclipse Public License v1.0\r
6  * which accompanies this distribution, and is available at\r
7  * http://www.eclipse.org/legal/epl-v10.html\r
8  *\r
9  * Contributors:\r
10  *     VTT Technical Research Centre of Finland - initial API and implementation\r
11  *******************************************************************************/\r
12 package org.simantics.objmap.internal;\r
13 \r
14 import gnu.trove.map.hash.THashMap;\r
15 \r
16 import java.util.Collections;\r
17 import java.util.Set;\r
18 \r
19 import org.simantics.db.WriteGraph;\r
20 import org.simantics.objmap.backward.IBackwardLinkType;\r
21 import org.simantics.objmap.backward.IBackwardMapping;\r
22 import org.simantics.objmap.backward.IBackwardMappingSchema;\r
23 import org.simantics.objmap.exceptions.MappingException;\r
24 \r
25 /**\r
26  * An unidirectional (from range to domain) mapping that does not support removals.\r
27  * \r
28  * @author Hannu Niemistö\r
29  */\r
30 public class MonotoneBackwardMapping<Domain, Range> implements IBackwardMapping<Domain, Range> {\r
31 \r
32     IBackwardMappingSchema<Domain, Range> schema;\r
33     THashMap<Range, Domain> map = new THashMap<Range, Domain>();\r
34     \r
35     public MonotoneBackwardMapping(IBackwardMappingSchema<Domain, Range> schema) {\r
36         this.schema = schema;\r
37     }\r
38 \r
39     @Override\r
40     public Set<Range> getRange() {\r
41         return Collections.unmodifiableSet(map.keySet());\r
42     }\r
43 \r
44     @Override\r
45     public Domain inverseGet(Range rangeElement) {\r
46         return map.get(rangeElement);\r
47     }\r
48 \r
49     @Override\r
50     public Domain inverseMap(WriteGraph graph, Range rangeElement) throws MappingException {\r
51         Domain result = inverseGet(rangeElement);\r
52         if(result == null) {\r
53             IBackwardLinkType<Domain, Range> linkType = \r
54                     schema.linkTypeOfRangeElement(graph, rangeElement);\r
55             // Two phase creation makes cyclic references possible\r
56             Domain domainElement = linkType.createDomainElement(graph, rangeElement);\r
57             map.put(rangeElement, domainElement);\r
58             linkType.createDomain(graph, this, domainElement, rangeElement);\r
59         }\r
60         return result;\r
61     }\r
62 \r
63 }\r