diff options
author | 2024-01-03 02:13:15 +0100 | |
---|---|---|
committer | 2024-01-03 13:33:55 +0100 | |
commit | 2fe65e414ff3194cdddde01bea6818bbab5290e9 (patch) | |
tree | a597343718059a2ee8727a296e817f997876f248 /subprojects/language-web/src/main/java/tools/refinery/language/web/semantics/metadata/MetadataCreator.java | |
parent | refactor: matching node names in CLI and web (diff) | |
download | refinery-2fe65e414ff3194cdddde01bea6818bbab5290e9.tar.gz refinery-2fe65e414ff3194cdddde01bea6818bbab5290e9.tar.zst refinery-2fe65e414ff3194cdddde01bea6818bbab5290e9.zip |
feat(web): color identifiers and nodes
We use a palette-based coloring strategy, where each class and enum gets a color
from
Diffstat (limited to 'subprojects/language-web/src/main/java/tools/refinery/language/web/semantics/metadata/MetadataCreator.java')
-rw-r--r-- | subprojects/language-web/src/main/java/tools/refinery/language/web/semantics/metadata/MetadataCreator.java | 46 |
1 files changed, 8 insertions, 38 deletions
diff --git a/subprojects/language-web/src/main/java/tools/refinery/language/web/semantics/metadata/MetadataCreator.java b/subprojects/language-web/src/main/java/tools/refinery/language/web/semantics/metadata/MetadataCreator.java index 67ef82ce..f05abc45 100644 --- a/subprojects/language-web/src/main/java/tools/refinery/language/web/semantics/metadata/MetadataCreator.java +++ b/subprojects/language-web/src/main/java/tools/refinery/language/web/semantics/metadata/MetadataCreator.java | |||
@@ -13,9 +13,7 @@ import org.eclipse.xtext.naming.IQualifiedNameProvider; | |||
13 | import org.eclipse.xtext.naming.QualifiedName; | 13 | import org.eclipse.xtext.naming.QualifiedName; |
14 | import org.eclipse.xtext.scoping.IScope; | 14 | import org.eclipse.xtext.scoping.IScope; |
15 | import org.eclipse.xtext.scoping.IScopeProvider; | 15 | import org.eclipse.xtext.scoping.IScopeProvider; |
16 | import org.jetbrains.annotations.NotNull; | ||
17 | import tools.refinery.language.model.problem.*; | 16 | import tools.refinery.language.model.problem.*; |
18 | import tools.refinery.language.semantics.NodeNameProvider; | ||
19 | import tools.refinery.language.semantics.ProblemTrace; | 17 | import tools.refinery.language.semantics.ProblemTrace; |
20 | import tools.refinery.language.semantics.TracedException; | 18 | import tools.refinery.language.semantics.TracedException; |
21 | import tools.refinery.language.utils.ProblemUtil; | 19 | import tools.refinery.language.utils.ProblemUtil; |
@@ -23,14 +21,11 @@ import tools.refinery.store.model.Model; | |||
23 | import tools.refinery.store.reasoning.ReasoningAdapter; | 21 | import tools.refinery.store.reasoning.ReasoningAdapter; |
24 | import tools.refinery.store.reasoning.literal.Concreteness; | 22 | import tools.refinery.store.reasoning.literal.Concreteness; |
25 | import tools.refinery.store.reasoning.representation.PartialRelation; | 23 | import tools.refinery.store.reasoning.representation.PartialRelation; |
26 | import tools.refinery.store.reasoning.translator.typehierarchy.TypeHierarchyTranslator; | ||
27 | import tools.refinery.store.tuple.Tuple; | ||
28 | 24 | ||
29 | import java.util.ArrayList; | 25 | import java.util.ArrayList; |
30 | import java.util.Collections; | 26 | import java.util.Collections; |
31 | import java.util.Comparator; | 27 | import java.util.Comparator; |
32 | import java.util.List; | 28 | import java.util.List; |
33 | import java.util.function.IntFunction; | ||
34 | 29 | ||
35 | public class MetadataCreator { | 30 | public class MetadataCreator { |
36 | @Inject | 31 | @Inject |
@@ -43,7 +38,7 @@ public class MetadataCreator { | |||
43 | private IQualifiedNameConverter qualifiedNameConverter; | 38 | private IQualifiedNameConverter qualifiedNameConverter; |
44 | 39 | ||
45 | @Inject | 40 | @Inject |
46 | private Provider<NodeNameProvider> nodeNameProviderProvider; | 41 | private Provider<NodeMetadataFactory> nodeMetadataFactoryProvider; |
47 | 42 | ||
48 | private ProblemTrace problemTrace; | 43 | private ProblemTrace problemTrace; |
49 | private IScope nodeScope; | 44 | private IScope nodeScope; |
@@ -63,56 +58,31 @@ public class MetadataCreator { | |||
63 | int nodeCount = model.getAdapter(ReasoningAdapter.class).getNodeCount(); | 58 | int nodeCount = model.getAdapter(ReasoningAdapter.class).getNodeCount(); |
64 | var nodeTrace = problemTrace.getNodeTrace(); | 59 | var nodeTrace = problemTrace.getNodeTrace(); |
65 | var nodes = new NodeMetadata[Math.max(nodeTrace.size(), nodeCount)]; | 60 | var nodes = new NodeMetadata[Math.max(nodeTrace.size(), nodeCount)]; |
66 | var getName = makeGetName(model, concreteness); | 61 | var nodeMetadataFactory = nodeMetadataFactoryProvider.get(); |
62 | nodeMetadataFactory.initialize(problemTrace, concreteness, model); | ||
67 | boolean preserveNewNodes = concreteness == Concreteness.PARTIAL; | 63 | boolean preserveNewNodes = concreteness == Concreteness.PARTIAL; |
68 | for (var entry : nodeTrace.keyValuesView()) { | 64 | for (var entry : nodeTrace.keyValuesView()) { |
69 | var node = entry.getOne(); | 65 | var node = entry.getOne(); |
70 | var id = entry.getTwo(); | 66 | var id = entry.getTwo(); |
71 | nodes[id] = getNodeMetadata(id, node, preserveNewNodes, getName); | 67 | nodes[id] = getNodeMetadata(id, node, preserveNewNodes, nodeMetadataFactory); |
72 | } | 68 | } |
73 | for (int i = 0; i < nodes.length; i++) { | 69 | for (int i = 0; i < nodes.length; i++) { |
74 | if (nodes[i] == null) { | 70 | if (nodes[i] == null) { |
75 | var nodeName = getName.apply(i); | 71 | nodes[i] = nodeMetadataFactory.createFreshlyNamedMetadata(i); |
76 | nodes[i] = new NodeMetadata(nodeName, nodeName, NodeKind.IMPLICIT); | ||
77 | } | 72 | } |
78 | } | 73 | } |
79 | return List.of(nodes); | 74 | return List.of(nodes); |
80 | } | 75 | } |
81 | 76 | ||
82 | @NotNull | ||
83 | private IntFunction<String> makeGetName(Model model, Concreteness concreteness) { | ||
84 | var nodeNameProvider = nodeNameProviderProvider.get(); | ||
85 | nodeNameProvider.setProblem(problemTrace.getProblem()); | ||
86 | var typeInterpretation = model.getInterpretation(TypeHierarchyTranslator.TYPE_SYMBOL); | ||
87 | var existsInterpretation = model.getAdapter(ReasoningAdapter.class).getPartialInterpretation(concreteness, | ||
88 | ReasoningAdapter.EXISTS_SYMBOL); | ||
89 | return nodeId -> { | ||
90 | var key = Tuple.of(nodeId); | ||
91 | var inferredType = typeInterpretation.get(key); | ||
92 | if (inferredType == null || inferredType.candidateType() == null) { | ||
93 | return nodeNameProvider.getNextName(null); | ||
94 | } | ||
95 | if (concreteness == Concreteness.CANDIDATE && !existsInterpretation.get(key).may()) { | ||
96 | // Do not increment the node name counter for non-existent nodes in the candidate interpretation. | ||
97 | // While non-existent nodes may appear in the partial interpretation, they are never displayed in the | ||
98 | // candidate interpretation. | ||
99 | return "::" + nodeId; | ||
100 | } | ||
101 | var relation = problemTrace.getRelation(inferredType.candidateType()); | ||
102 | return nodeNameProvider.getNextName(relation.getName()); | ||
103 | }; | ||
104 | } | ||
105 | |||
106 | private NodeMetadata getNodeMetadata(int nodeId, Node node, boolean preserveNewNodes, | 77 | private NodeMetadata getNodeMetadata(int nodeId, Node node, boolean preserveNewNodes, |
107 | IntFunction<String> getName) { | 78 | NodeMetadataFactory nodeMetadataFactory) { |
108 | var kind = getNodeKind(node); | 79 | var kind = getNodeKind(node); |
109 | if (!preserveNewNodes && kind == NodeKind.NEW) { | 80 | if (!preserveNewNodes && kind == NodeKind.NEW) { |
110 | var nodeName = getName.apply(nodeId); | 81 | return nodeMetadataFactory.createFreshlyNamedMetadata(nodeId); |
111 | return new NodeMetadata(nodeName, nodeName, NodeKind.IMPLICIT); | ||
112 | } | 82 | } |
113 | var qualifiedName = getQualifiedName(node); | 83 | var qualifiedName = getQualifiedName(node); |
114 | var simpleName = getSimpleName(node, qualifiedName, nodeScope); | 84 | var simpleName = getSimpleName(node, qualifiedName, nodeScope); |
115 | return new NodeMetadata(qualifiedNameConverter.toString(qualifiedName), | 85 | return nodeMetadataFactory.doCreateMetadata(nodeId, qualifiedNameConverter.toString(qualifiedName), |
116 | qualifiedNameConverter.toString(simpleName), getNodeKind(node)); | 86 | qualifiedNameConverter.toString(simpleName), getNodeKind(node)); |
117 | } | 87 | } |
118 | 88 | ||