![JAR search and dependency download from the Maven repository](/logo.png)
org.codehaus.plexus.languages.java.version.JavaVersion Maven / Gradle / Ivy
package org.codehaus.plexus.languages.java.version;
import java.util.Objects;
import java.util.StringTokenizer;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
/**
* @author Robert Scholte
* @since 1.0.0
*
* @see Java SE Naming and Versions
* @see JEP 223: New Version-String Scheme
* @see JEP 322: Time-Based Release Versioning
*/
public class JavaVersion implements Comparable {
/**
* Represents the System property {@code java.specification.version}
*/
public static final JavaVersion JAVA_SPECIFICATION_VERSION =
parse(System.getProperty("java.specification.version"));
/**
* Represents the System property {@code java.version}
*/
public static final JavaVersion JAVA_VERSION = parse(System.getProperty("java.version"));
private static final Pattern startingDigits = Pattern.compile("(\\d+)(.*)");
private final String rawVersion;
private final boolean isMajor;
private JavaVersion(String rawVersion, boolean isMajor) {
this.rawVersion = rawVersion;
this.isMajor = isMajor;
}
/**
* Lazy parse the version-scheme.
* Actual parsing is done when calling {@link #compareTo(JavaVersion)}
*
* @param s the version string, never {@code null}
* @return the version wrapped in a JavaVersion
*/
public static JavaVersion parse(String s) {
return new JavaVersion(s, !s.startsWith("1."));
}
@Override
public int compareTo(JavaVersion other) {
String[] thisSegments = this.rawVersion.split("\\.");
String[] otherSegments = other.rawVersion.split("\\.");
int minSegments = Math.min(thisSegments.length, otherSegments.length);
for (int index = 0; index < minSegments; index++) {
Matcher thisMatcher = startingDigits.matcher(thisSegments[index]);
int thisValue;
if (thisMatcher.find()) {
thisValue = Integer.parseInt(thisMatcher.group(1));
} else {
thisValue = -1;
}
Matcher otherMatcher = startingDigits.matcher(otherSegments[index]);
int otherValue;
if (otherMatcher.find()) {
otherValue = Integer.parseInt(otherMatcher.group(1));
} else {
otherValue = -1;
}
int compareValue = Integer.compare(thisValue, otherValue);
if (compareValue != 0) {
return compareValue;
}
compareValue = suffixRate(thisMatcher.group(2)) - suffixRate(otherMatcher.group(2));
if (compareValue != 0) {
return compareValue;
}
// works for now, but needs improvement
compareValue = thisMatcher.group(2).compareTo(otherMatcher.group(2));
if (compareValue != 0) {
return compareValue;
}
}
return (thisSegments.length - otherSegments.length);
}
private int suffixRate(String suffix) {
if ("-ea".equals(suffix)) {
return -100;
} else if ("".equals(suffix)) {
return 0;
} else {
return 10;
}
}
/**
* Verify if this version is before some other version
*
* @param other the version to compare with
* @return {@code true} is this is less than {@code other}, otherwise {@code false}
*/
public boolean isBefore(JavaVersion other) {
return this.compareTo(other) < 0;
}
/**
* Verify if this version is before some other version
*
* @param other the version to compare with
* @return {@code true} is this is less than {@code other}, otherwise {@code false}
*/
public boolean isBefore(String other) {
return this.compareTo(parse(other)) < 0;
}
/**
* Verify if this version is at least some other version
*
* @param other the version to compare with
* @return {@code true} is this is greater than or equal to {@code other}, otherwise {@code false}
*/
public boolean isAtLeast(JavaVersion other) {
return this.compareTo(other) >= 0;
}
/**
* Verify if this version is at least some other version
*
* @param other the version to compare with
* @return {@code true} is this is greater than or equal to {@code other}, otherwise {@code false}
*/
public boolean isAtLeast(String other) {
return this.compareTo(parse(other)) >= 0;
}
/**
* If original version starts with {@code "1."}, then remove this part from the version
*
* @return a new JavaVersion if version has to be changed, otherwise return itself
*/
public JavaVersion asMajor() {
if (!isMajor) {
return new JavaVersion(rawVersion.substring(2), true);
} else {
return this;
}
}
/**
* Returns the original version
*
* @return the raw version
*/
public String getValue() {
return rawVersion;
}
/**
* Returns a value respecting the nuber of groups.
* If the original has more groups, the end of that value will be removed.
* If the original has less groups, the value will be extended this ".0".
*
*
* JavaVersion.parse( "1" ).getValue( 1 ) is "1"
* JavaVersion.parse( "1" ).getValue( 2 ) is "1.0"
* JavaVersion.parse( "2.1" ).getValue( 1 ) is "2"
* JavaVersion.parse( "2.1" ).getValue( 2 ) is "2.1"
*
*
* @param groups number of groups to return
* @return the version respecting the number of groups
*/
public String getValue(int groups) {
StringBuilder value = new StringBuilder();
StringTokenizer tokenizer = new StringTokenizer(rawVersion, ".");
value.append(tokenizer.nextToken());
for (int group = 1; group < groups; group++) {
value.append('.');
if (tokenizer.hasMoreTokens()) {
value.append(tokenizer.nextToken());
} else {
value.append("0");
}
}
return value.toString();
}
@Override
public String toString() {
return rawVersion;
}
@Override
public int hashCode() {
return Objects.hashCode(rawVersion);
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
JavaVersion other = (JavaVersion) obj;
if (isMajor != other.isMajor) {
final String thisOneDotVersion;
final String otherOneDotVersion;
if (isMajor) {
thisOneDotVersion = "1." + rawVersion;
otherOneDotVersion = other.rawVersion;
} else {
thisOneDotVersion = rawVersion;
otherOneDotVersion = "1." + other.rawVersion;
}
if (!Objects.equals(thisOneDotVersion, otherOneDotVersion)) {
return false;
}
} else if (!Objects.equals(rawVersion, other.rawVersion)) {
return false;
}
return true;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy