From 0ff75f28fe7a0b7b4757c02b533704354c1dd46c Mon Sep 17 00:00:00 2001 From: Alexander Kriegisch Date: Wed, 5 Oct 2022 10:11:54 +0200 Subject: LangUtil: improve Java version major/minor parsing - Ignore everything including and after '+' in versions like '19+36-2238' - Add minor '.0' to Java versions like '19', '19+36-2238' Signed-off-by: Alexander Kriegisch --- util/src/main/java/org/aspectj/util/LangUtil.java | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'util') diff --git a/util/src/main/java/org/aspectj/util/LangUtil.java b/util/src/main/java/org/aspectj/util/LangUtil.java index 02aa7d94b..7151c092b 100644 --- a/util/src/main/java/org/aspectj/util/LangUtil.java +++ b/util/src/main/java/org/aspectj/util/LangUtil.java @@ -96,16 +96,17 @@ public class LangUtil { private static List getJavaMajorMinor(String vm) { List result = new ArrayList<>(); // Can be something like '1.5', '11.0.16.1', '19+36-2238' - StringTokenizer st = new StringTokenizer(vm,".-_+"); + StringTokenizer st = new StringTokenizer(vm.replaceFirst("[+].*", ""), ".-_"); try { result.add(Integer.parseInt(st.nextToken())); - // FIXME: The minor will be wrong for version strings like '19+36-2238'. - // The minor is only relevant for Java <= 1.8. Even so, this is super ugly. result.add(Integer.parseInt(st.nextToken())); } catch (Exception e) { // NoSuchElementException if no more tokens // NumberFormatException if not a number } + // Always add a default minor, just in case a caller expects it + if (result.size() == 1) + result.add(0); return result; } -- cgit v1.2.3