Skip to content

Commit 202a743

Browse files
committed
introduce a singleton empty EconomicSet
1 parent 4fd1fe4 commit 202a743

File tree

5 files changed

+189
-3
lines changed

5 files changed

+189
-3
lines changed
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,90 @@
1+
/*
2+
* Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* The Universal Permissive License (UPL), Version 1.0
6+
*
7+
* Subject to the condition set forth below, permission is hereby granted to any
8+
* person obtaining a copy of this software, associated documentation and/or
9+
* data (collectively the "Software"), free of charge and under any and all
10+
* copyright rights in the Software, and any and all patent rights owned or
11+
* freely licensable by each licensor hereunder covering either (i) the
12+
* unmodified Software as contributed to or provided by such licensor, or (ii)
13+
* the Larger Works (as defined below), to deal in both
14+
*
15+
* (a) the Software, and
16+
*
17+
* (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
18+
* one is included with the Software each a "Larger Work" to which the Software
19+
* is contributed by such licensors),
20+
*
21+
* without restriction, including without limitation the rights to copy, create
22+
* derivative works of, display, perform, and distribute the Software and make,
23+
* use, sell, offer for sale, import, export, have made, and have sold the
24+
* Software and the Larger Work(s), and to sublicense the foregoing rights on
25+
* either these or other terms.
26+
*
27+
* This license is subject to the following condition:
28+
*
29+
* The above copyright notice and either this complete permission notice or at a
30+
* minimum a reference to the UPL must be included in all copies or substantial
31+
* portions of the Software.
32+
*
33+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
39+
* SOFTWARE.
40+
*/
41+
package org.graalvm.collections.test;
42+
43+
import java.util.NoSuchElementException;
44+
45+
import org.graalvm.collections.EconomicSet;
46+
import org.junit.Assert;
47+
import org.junit.Test;
48+
49+
public class EmptyEconomicSetTest {
50+
51+
@Test
52+
public void testIsEmpty() {
53+
Assert.assertTrue(EconomicSet.emptySet().isEmpty());
54+
}
55+
56+
@Test
57+
public void testSizeZero() {
58+
Assert.assertEquals(0, EconomicSet.emptySet().size());
59+
}
60+
61+
@Test(expected = IllegalArgumentException.class)
62+
public void testAdd() {
63+
EconomicSet.emptySet().add(1);
64+
}
65+
66+
@Test(expected = IllegalArgumentException.class)
67+
public void testRemove() {
68+
EconomicSet.emptySet().remove(1);
69+
}
70+
71+
@Test(expected = IllegalArgumentException.class)
72+
public void testClear() {
73+
EconomicSet.emptySet().clear();
74+
}
75+
76+
@Test
77+
public void testContains() {
78+
Assert.assertFalse(EconomicSet.emptySet().contains(1));
79+
}
80+
81+
@Test
82+
public void testIteratorAlwaysEmpty() {
83+
Assert.assertFalse(EconomicSet.emptySet().iterator().hasNext());
84+
}
85+
86+
@Test(expected = NoSuchElementException.class)
87+
public void testIteratorThrowsException() {
88+
EconomicSet.emptySet().iterator().next();
89+
}
90+
}

sdk/src/org.graalvm.collections/snapshot.sigtest

+1
Original file line numberDiff line numberDiff line change
@@ -136,6 +136,7 @@ meth public static <%0 extends java.lang.Object> org.graalvm.collections.Economi
136136
meth public static <%0 extends java.lang.Object> org.graalvm.collections.EconomicSet<{%%0}> create(org.graalvm.collections.Equivalence,int)
137137
meth public static <%0 extends java.lang.Object> org.graalvm.collections.EconomicSet<{%%0}> create(org.graalvm.collections.Equivalence,org.graalvm.collections.UnmodifiableEconomicSet<{%%0}>)
138138
meth public static <%0 extends java.lang.Object> org.graalvm.collections.EconomicSet<{%%0}> create(org.graalvm.collections.UnmodifiableEconomicSet<{%%0}>)
139+
meth public static org.graalvm.collections.EconomicSet emptySet()
139140
meth public void addAll(java.lang.Iterable<{org.graalvm.collections.EconomicSet%0}>)
140141
meth public void addAll(java.util.Iterator<{org.graalvm.collections.EconomicSet%0}>)
141142
meth public void addAll(org.graalvm.collections.EconomicSet<{org.graalvm.collections.EconomicSet%0}>)

sdk/src/org.graalvm.collections/src/org/graalvm/collections/EconomicSet.java

+11-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
/*
2-
* Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved.
2+
* Copyright (c) 2017, 2025, Oracle and/or its affiliates. All rights reserved.
33
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
44
*
55
* The Universal Permissive License (UPL), Version 1.0
@@ -206,4 +206,14 @@ static <E> EconomicSet<E> create(Equivalence strategy, int initialCapacity) {
206206
static <E> EconomicSet<E> create(Equivalence strategy, UnmodifiableEconomicSet<E> c) {
207207
return EconomicMapImpl.create(strategy, c, true);
208208
}
209+
210+
/**
211+
* Return an empty, unmodifiable {@link EconomicSet}.
212+
*
213+
* @since 25.0
214+
*/
215+
@SuppressWarnings("unchecked")
216+
static <E> EconomicSet<E> emptySet() {
217+
return (EconomicSet<E>) EmptySet.EMPTY_SET;
218+
}
209219
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,85 @@
1+
/*
2+
* Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* The Universal Permissive License (UPL), Version 1.0
6+
*
7+
* Subject to the condition set forth below, permission is hereby granted to any
8+
* person obtaining a copy of this software, associated documentation and/or
9+
* data (collectively the "Software"), free of charge and under any and all
10+
* copyright rights in the Software, and any and all patent rights owned or
11+
* freely licensable by each licensor hereunder covering either (i) the
12+
* unmodified Software as contributed to or provided by such licensor, or (ii)
13+
* the Larger Works (as defined below), to deal in both
14+
*
15+
* (a) the Software, and
16+
*
17+
* (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
18+
* one is included with the Software each a "Larger Work" to which the Software
19+
* is contributed by such licensors),
20+
*
21+
* without restriction, including without limitation the rights to copy, create
22+
* derivative works of, display, perform, and distribute the Software and make,
23+
* use, sell, offer for sale, import, export, have made, and have sold the
24+
* Software and the Larger Work(s), and to sublicense the foregoing rights on
25+
* either these or other terms.
26+
*
27+
* This license is subject to the following condition:
28+
*
29+
* The above copyright notice and either this complete permission notice or at a
30+
* minimum a reference to the UPL must be included in all copies or substantial
31+
* portions of the Software.
32+
*
33+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
39+
* SOFTWARE.
40+
*/
41+
package org.graalvm.collections;
42+
43+
import java.util.Iterator;
44+
45+
/**
46+
* Singleton instance for empty set. Reuses empty iterator from {@link EmptyMap}.
47+
*/
48+
class EmptySet {
49+
static final EconomicSet<Object> EMPTY_SET = new EconomicSet<>() {
50+
@Override
51+
public boolean add(Object element) {
52+
throw new IllegalArgumentException("Cannot modify the always-empty set");
53+
}
54+
55+
@Override
56+
public void remove(Object element) {
57+
throw new IllegalArgumentException("Cannot modify the always-empty set");
58+
}
59+
60+
@Override
61+
public void clear() {
62+
throw new IllegalArgumentException("Cannot modify the always-empty set");
63+
}
64+
65+
@Override
66+
public boolean contains(Object element) {
67+
return false;
68+
}
69+
70+
@Override
71+
public int size() {
72+
return 0;
73+
}
74+
75+
@Override
76+
public boolean isEmpty() {
77+
return true;
78+
}
79+
80+
@Override
81+
public Iterator<Object> iterator() {
82+
return EmptyMap.EMPTY_ITERATOR;
83+
}
84+
};
85+
}

substratevm/src/com.oracle.svm.hosted/src/com/oracle/svm/hosted/code/CompilationGraph.java

+2-2
Original file line numberDiff line numberDiff line change
@@ -120,8 +120,8 @@ static CompilationGraph encode(StructuredGraph graph) {
120120
return new CompilationGraph(
121121
GraphEncoder.encodeSingleGraph(graph, AnalysisParsedGraph.HOST_ARCHITECTURE),
122122
graph.getNodeCount(),
123-
invokeInfos, // todo is there an empty global singleton we could use?
124-
allocationInfos);
123+
invokeInfos.isEmpty() ? EconomicSet.emptySet() : invokeInfos,
124+
allocationInfos.isEmpty() ? EconomicSet.emptySet() : allocationInfos);
125125
}
126126

127127
public EncodedGraph getEncodedGraph() {

0 commit comments

Comments
 (0)