diff options
Diffstat (limited to 'subprojects/viatra-runtime/src/main/java/tools/refinery/viatra/runtime/matchers/util/SingletonMemoryView.java')
-rw-r--r-- | subprojects/viatra-runtime/src/main/java/tools/refinery/viatra/runtime/matchers/util/SingletonMemoryView.java | 105 |
1 files changed, 105 insertions, 0 deletions
diff --git a/subprojects/viatra-runtime/src/main/java/tools/refinery/viatra/runtime/matchers/util/SingletonMemoryView.java b/subprojects/viatra-runtime/src/main/java/tools/refinery/viatra/runtime/matchers/util/SingletonMemoryView.java new file mode 100644 index 00000000..b303f9ad --- /dev/null +++ b/subprojects/viatra-runtime/src/main/java/tools/refinery/viatra/runtime/matchers/util/SingletonMemoryView.java | |||
@@ -0,0 +1,105 @@ | |||
1 | /******************************************************************************* | ||
2 | * Copyright (c) 2010-2018, Gabor Bergmann, IncQuery Labs Ltd. | ||
3 | * This program and the accompanying materials are made available under the | ||
4 | * terms of the Eclipse Public License v. 2.0 which is available at | ||
5 | * http://www.eclipse.org/legal/epl-v20.html. | ||
6 | * | ||
7 | * SPDX-License-Identifier: EPL-2.0 | ||
8 | *******************************************************************************/ | ||
9 | package tools.refinery.viatra.runtime.matchers.util; | ||
10 | |||
11 | import java.util.Collections; | ||
12 | import java.util.Iterator; | ||
13 | import java.util.NoSuchElementException; | ||
14 | import java.util.Set; | ||
15 | |||
16 | /** | ||
17 | * An immutable memory view that consists of a single non-null element with multiplicity 1. | ||
18 | * @author Gabor Bergmann | ||
19 | * @since 2.0 | ||
20 | */ | ||
21 | public final class SingletonMemoryView<Value> implements IMemoryView<Value> { | ||
22 | |||
23 | private Value wrapped; | ||
24 | private static final int ONE_HASH = Integer.valueOf(1).hashCode(); | ||
25 | |||
26 | public SingletonMemoryView(Value value) { | ||
27 | this.wrapped = value; | ||
28 | } | ||
29 | |||
30 | @Override | ||
31 | public Iterator<Value> iterator() { | ||
32 | return new Iterator<Value>() { | ||
33 | boolean hasNext = true; | ||
34 | |||
35 | @Override | ||
36 | public boolean hasNext() { | ||
37 | return hasNext; | ||
38 | } | ||
39 | |||
40 | @Override | ||
41 | public Value next() { | ||
42 | if (hasNext) { | ||
43 | hasNext = false; | ||
44 | return wrapped; | ||
45 | } else throw new NoSuchElementException(); | ||
46 | } | ||
47 | }; | ||
48 | } | ||
49 | |||
50 | @Override | ||
51 | public int getCount(Value value) { | ||
52 | return wrapped.equals(value) ? 1 : 0; | ||
53 | } | ||
54 | |||
55 | @Override | ||
56 | public int getCountUnsafe(Object value) { | ||
57 | return wrapped.equals(value) ? 1 : 0; | ||
58 | } | ||
59 | |||
60 | @Override | ||
61 | public boolean containsNonZero(Value value) { | ||
62 | return wrapped.equals(value); | ||
63 | } | ||
64 | |||
65 | @Override | ||
66 | public boolean containsNonZeroUnsafe(Object value) { | ||
67 | return wrapped.equals(value); | ||
68 | } | ||
69 | |||
70 | @Override | ||
71 | public int size() { | ||
72 | return 1; | ||
73 | } | ||
74 | |||
75 | @Override | ||
76 | public boolean isEmpty() { | ||
77 | return false; | ||
78 | } | ||
79 | |||
80 | @Override | ||
81 | public Set<Value> distinctValues() { | ||
82 | return Collections.singleton(wrapped); | ||
83 | } | ||
84 | |||
85 | @Override | ||
86 | public boolean equals(Object obj) { | ||
87 | if (obj instanceof IMemoryView<?>) { | ||
88 | IMemoryView<?> other = (IMemoryView<?>) obj; | ||
89 | if (1 != other.size()) return false; | ||
90 | if (1 != other.getCountUnsafe(wrapped)) return false; | ||
91 | return true; | ||
92 | } | ||
93 | return false; | ||
94 | } | ||
95 | |||
96 | @Override | ||
97 | public int hashCode() { | ||
98 | return wrapped.hashCode() ^ ONE_HASH; | ||
99 | } | ||
100 | |||
101 | @Override | ||
102 | public String toString() { | ||
103 | return "{" + wrapped + "}"; | ||
104 | } | ||
105 | } | ||