Skip to content

Commit

Permalink
Return a SortedSet in getAllJavaSourceVersionsSupportedByCompiler()
Browse files Browse the repository at this point in the history
The list current returned by
JavaCore.getAllJavaSourceVersionsSupportedByCompiler()
is mainly/only used to either fetch the first or
last element or test if a version-String is contained.

Especially for the last operation a Set is a better choice regarding
runtime. A SortedSet additionally also offers the methods
first()/last(), which are semantically more expressive than calling
List.get(0)/List.get(List.size()-1).

Furthermore using a SortedSet would also better reflect the general
semantic of the returned collection and element-access is usually not of
interest.
  • Loading branch information
HannesWell committed Jul 28, 2024
1 parent ed787f5 commit 64d4dbb
Showing 1 changed file with 17 additions and 5 deletions.
22 changes: 17 additions & 5 deletions org.eclipse.jdt.core/model/org/eclipse/jdt/core/JavaCore.java
Original file line number Diff line number Diff line change
Expand Up @@ -121,13 +121,16 @@
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Hashtable;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.SortedSet;
import java.util.TreeSet;
import java.util.stream.Collectors;
import java.util.stream.Stream;
import java.util.zip.ZipFile;
Expand Down Expand Up @@ -3336,12 +3339,19 @@ public final class JavaCore extends Plugin {
* Ordered set (from oldest to latest) of all Java source versions <b>supported</b> by compiler.
* The values are from {@link JavaCore}{@code #VERSION_*}.
*/
private static final List<String> SUPPORTED_VERSIONS;
private static final SortedSet<String> SUPPORTED_VERSIONS;
static {
ArrayList<String> temp = new ArrayList<>();
Comparator<String> byVersion = Comparator.comparingDouble((String v) -> {
try {
return Double.parseDouble(v);
} catch (RuntimeException e) {
return 0;
}
}).thenComparing(Comparator.naturalOrder());
SortedSet<String> temp = new TreeSet<>(byVersion);
temp.addAll(allVersions);
temp.removeAll(UNSUPPORTED_VERSIONS);
SUPPORTED_VERSIONS = Collections.unmodifiableList(temp);
SUPPORTED_VERSIONS = Collections.unmodifiableSortedSet(temp);
}

/**
Expand All @@ -3367,7 +3377,7 @@ public static List<String> getAllVersions() {
* @see #getFirstJavaSourceVersionSupportedByCompiler()
* @since 3.39
*/
public static List<String> getAllJavaSourceVersionsSupportedByCompiler() {
public static SortedSet<String> getAllJavaSourceVersionsSupportedByCompiler() {
return SUPPORTED_VERSIONS;
}

Expand Down Expand Up @@ -3396,6 +3406,7 @@ public static boolean isSupportedJavaVersion(String version) {
* @since 3.39
*/
public static boolean isJavaSourceVersionSupportedByCompiler(String version) {
//TODO: drop this again and just mention the use-case in the doc of getAllJavaSourceVersionsSupportedByCompiler()?
if(version == null || version.isBlank()) {
return false;
}
Expand Down Expand Up @@ -6472,7 +6483,8 @@ public static String latestSupportedJavaVersion() {
* @since 3.39
*/
public static String getFirstJavaSourceVersionSupportedByCompiler() {
return SUPPORTED_VERSIONS.get(0);
return SUPPORTED_VERSIONS.first();
//TODO: drop this again and just mention the use-case in the doc of getAllJavaSourceVersionsSupportedByCompiler()?
}

/**
Expand Down

0 comments on commit 64d4dbb

Please sign in to comment.