diff --git a/pom.xml b/pom.xml
index 88cb573..bfc2d8c 100644
--- a/pom.xml
+++ b/pom.xml
@@ -50,6 +50,11 @@
slf4j-api
1.7.25
+
+ com.vdurmont
+ semver4j
+ 3.1.0
+
org.junit.jupiter
diff --git a/src/main/java/org/apache/cassandra/distributed/shared/Versions.java b/src/main/java/org/apache/cassandra/distributed/shared/Versions.java
index bc47625..6270aff 100644
--- a/src/main/java/org/apache/cassandra/distributed/shared/Versions.java
+++ b/src/main/java/org/apache/cassandra/distributed/shared/Versions.java
@@ -24,7 +24,6 @@
import java.nio.file.Paths;
import java.util.ArrayList;
import java.util.Collections;
-import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@@ -32,6 +31,8 @@
import java.util.regex.Pattern;
import java.util.stream.Collectors;
+import com.vdurmont.semver4j.Semver;
+import com.vdurmont.semver4j.Semver.SemverType;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@@ -73,82 +74,61 @@ public enum Major
v4X("4\\.([1-9][0-9]*)(\\.([0-9]+))?");
final Pattern pattern;
- Major(String verify)
+ private Major(String verify)
{
this.pattern = Pattern.compile(verify);
}
- static Major fromFull(String version)
+ static Major of(Semver version)
{
- if (version.isEmpty())
- throw new IllegalArgumentException(version);
- switch (version.charAt(0))
+ switch (version.getMajor())
{
- case '2':
- if (version.startsWith("2.2"))
+ case 2:
+ if (2 == version.getMinor())
return v22;
- throw new IllegalArgumentException(version);
- case '3':
- if (version.startsWith("3.0"))
+ throw new IllegalArgumentException(version.getOriginalValue());
+ case 3:
+ if (0 == version.getMinor())
return v30;
return v3X;
- case '4':
- if (version.startsWith("4.0"))
+ case 4:
+ if (0 == version.getMinor())
return v40;
return v4X;
default:
- throw new IllegalArgumentException(version);
+ throw new IllegalArgumentException(version.getOriginalValue());
}
}
// verify that the version string is valid for this major version
- boolean verify(String version)
+ boolean verify(Semver version)
{
- return pattern.matcher(version).matches();
- }
-
- // sort two strings of the same major version as this enum instance
- int compare(String a, String b)
- {
- Matcher ma = pattern.matcher(a);
- Matcher mb = pattern.matcher(b);
- if (!ma.matches()) throw new IllegalArgumentException(a);
- if (!mb.matches()) throw new IllegalArgumentException(b);
- int result = Integer.compare(Integer.parseInt(ma.group(1)), Integer.parseInt(mb.group(1)));
- if (result == 0 && this == v3X && (ma.group(3) != null || mb.group(3) != null))
- {
- if (ma.group(3) != null && mb.group(3) != null)
- {
- // XXX likely wrong for alpha|beta|rc versions
- result = Integer.compare(Integer.parseInt(ma.group(3)), Integer.parseInt(mb.group(3)));
- }
- else
- {
- result = ma.group(3) != null ? 1 : -1;
- }
- }
- // sort descending
- return -result;
+ return pattern.matcher(version.getOriginalValue()).matches();
}
}
- public static class Version
+ public static final class Version implements Comparable
{
public final Major major;
- public final String version;
+ public final Semver version;
public final URL[] classpath;
public Version(String version, URL[] classpath)
{
- this(Major.fromFull(version), version, classpath);
+ this(new Semver(version, SemverType.LOOSE), classpath);
}
- public Version(Major major, String version, URL[] classpath)
+ public Version(Semver version, URL[] classpath)
{
- this.major = major;
+ this.major = Major.of(version);
this.version = version;
this.classpath = classpath;
}
+
+ @Override
+ public int compareTo(Version o) {
+ return version.compareTo(o.version);
+ }
}
private final Map> versions;
@@ -160,11 +140,16 @@ private Versions(Map> versions)
public Version get(String full)
{
- return versions.get(Major.fromFull(full))
+ return get(new Semver(full, SemverType.LOOSE));
+ }
+
+ public Version get(Semver version)
+ {
+ return versions.get(Major.of(version))
.stream()
- .filter(v -> full.equals(v.version))
+ .filter(v -> version.equals(v.version))
.findFirst()
- .orElseThrow(() -> new RuntimeException("No version " + full + " found"));
+ .orElseThrow(() -> new RuntimeException("No version " + version.getOriginalValue() + " found"));
}
public Version getLatest(Major major)
@@ -189,9 +174,9 @@ public static Versions find()
Matcher m = pattern.matcher(file.getName());
if (!m.matches())
continue;
- String version = m.group(1);
- Major major = Major.fromFull(version);
- versions.get(major).add(new Version(major, version, new URL[]{ toURL(file) }));
+ Semver sem = new Semver(m.group(1), SemverType.LOOSE);
+ Major major = Major.of(sem);
+ versions.get(major).add(new Version(sem, new URL[]{ toURL(file) }));
}
}
@@ -199,8 +184,8 @@ public static Versions find()
{
if (e.getValue().isEmpty())
continue;
- Collections.sort(e.getValue(), Comparator.comparing(v -> v.version, e.getKey()::compare));
- System.out.println("Found " + e.getValue().stream().map(v -> v.version).collect(Collectors.joining(", ")));
+ Collections.sort(e.getValue(), Collections.reverseOrder());
+ System.out.println("Found " + e.getValue().stream().map(v -> v.version.getOriginalValue()).collect(Collectors.joining(", ")));
}
return new Versions(versions);