diff options
Diffstat (limited to 'subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/metamodel/ContainedTypeHierarchyBuilder.java')
-rw-r--r-- | subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/metamodel/ContainedTypeHierarchyBuilder.java | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/metamodel/ContainedTypeHierarchyBuilder.java b/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/metamodel/ContainedTypeHierarchyBuilder.java new file mode 100644 index 00000000..a21da3d4 --- /dev/null +++ b/subprojects/store-reasoning/src/main/java/tools/refinery/store/reasoning/translator/metamodel/ContainedTypeHierarchyBuilder.java | |||
@@ -0,0 +1,33 @@ | |||
1 | /* | ||
2 | * SPDX-FileCopyrightText: 2023 The Refinery Authors <https://refinery.tools/> | ||
3 | * | ||
4 | * SPDX-License-Identifier: EPL-2.0 | ||
5 | */ | ||
6 | package tools.refinery.store.reasoning.translator.metamodel; | ||
7 | |||
8 | import tools.refinery.store.reasoning.representation.PartialRelation; | ||
9 | import tools.refinery.store.reasoning.translator.TranslationException; | ||
10 | import tools.refinery.store.reasoning.translator.containment.ContainmentHierarchyTranslator; | ||
11 | import tools.refinery.store.reasoning.translator.typehierarchy.TypeHierarchyBuilder; | ||
12 | |||
13 | import java.util.Collection; | ||
14 | |||
15 | public class ContainedTypeHierarchyBuilder extends TypeHierarchyBuilder { | ||
16 | ContainedTypeHierarchyBuilder() { | ||
17 | } | ||
18 | |||
19 | boolean isInvalidType(PartialRelation type) { | ||
20 | return !typeInfoMap.containsKey(type); | ||
21 | } | ||
22 | |||
23 | void setContainedTypes(Collection<PartialRelation> containedTypes) { | ||
24 | for (var containedType : containedTypes) { | ||
25 | var currentInfo = typeInfoMap.get(containedType); | ||
26 | if (currentInfo == null) { | ||
27 | throw new TranslationException(containedType, "Invalid contained type: " + containedType); | ||
28 | } | ||
29 | var newInfo = currentInfo.addSupertype(ContainmentHierarchyTranslator.CONTAINED_SYMBOL); | ||
30 | typeInfoMap.put(containedType, newInfo); | ||
31 | } | ||
32 | } | ||
33 | } | ||