Class Version
- java.lang.Object
-
- org.osgi.framework.Version
-
- All Implemented Interfaces:
java.lang.Comparable<Version>
public class Version extends java.lang.Object implements java.lang.Comparable<Version>
Version identifier for capabilities such as bundles and packages.Version identifiers have four components.
- Major version. A non-negative integer.
- Minor version. A non-negative integer.
- Micro version. A non-negative integer.
- Qualifier. A text string. See
Version(String)
for the format of the qualifier string.
Version
objects are immutable.- Since:
- 1.3
- Author:
- $Id: c24d4d37a0657ac69de29085d2d290cbb0031c4a $
-
-
Field Summary
Fields Modifier and Type Field Description static Version
emptyVersion
The empty version "0.0.0".
-
Constructor Summary
Constructors Constructor Description Version(int major, int minor, int micro)
Creates a version identifier from the specified numerical components.Version(int major, int minor, int micro, java.lang.String qualifier)
Creates a version identifier from the specified components.Version(java.lang.String version)
Creates a version identifier from the specified string.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description int
compareTo(Version other)
Compares thisVersion
object to anotherVersion
.boolean
equals(java.lang.Object object)
Compares thisVersion
object to another object.int
getMajor()
Returns the major component of this version identifier.int
getMicro()
Returns the micro component of this version identifier.int
getMinor()
Returns the minor component of this version identifier.java.lang.String
getQualifier()
Returns the qualifier component of this version identifier.int
hashCode()
Returns a hash code value for the object.static Version
parseVersion(java.lang.String version)
Parses a version identifier from the specified string.java.lang.String
toString()
Returns the string representation of this version identifier.static Version
valueOf(java.lang.String version)
Returns aVersion
object holding the version identifier in the specifiedString
.
-
-
-
Field Detail
-
emptyVersion
public static final Version emptyVersion
The empty version "0.0.0".
-
-
Constructor Detail
-
Version
public Version(int major, int minor, int micro)
Creates a version identifier from the specified numerical components.The qualifier is set to the empty string.
- Parameters:
major
- Major component of the version identifier.minor
- Minor component of the version identifier.micro
- Micro component of the version identifier.- Throws:
java.lang.IllegalArgumentException
- If the numerical components are negative.
-
Version
public Version(int major, int minor, int micro, java.lang.String qualifier)
Creates a version identifier from the specified components.- Parameters:
major
- Major component of the version identifier.minor
- Minor component of the version identifier.micro
- Micro component of the version identifier.qualifier
- Qualifier component of the version identifier. Ifnull
is specified, then the qualifier will be set to the empty string.- Throws:
java.lang.IllegalArgumentException
- If the numerical components are negative or the qualifier string is invalid.
-
Version
public Version(java.lang.String version)
Creates a version identifier from the specified string.Version string grammar:
version ::= major('.'minor('.'micro('.'qualifier)?)?)? major ::= digit+ minor ::= digit+ micro ::= digit+ qualifier ::= (alpha|digit|'_'|'-')+ digit ::= [0..9] alpha ::= [a..zA..Z]
- Parameters:
version
- String representation of the version identifier. There must be no whitespace in the argument.- Throws:
java.lang.IllegalArgumentException
- Ifversion
is improperly formatted.
-
-
Method Detail
-
parseVersion
public static Version parseVersion(java.lang.String version)
Parses a version identifier from the specified string.See
Version(String)
for the format of the version string.- Parameters:
version
- String representation of the version identifier. Leading and trailing whitespace will be ignored.- Returns:
- A
Version
object representing the version identifier. Ifversion
isnull
or the empty string thenemptyVersion
will be returned. - Throws:
java.lang.IllegalArgumentException
- Ifversion
is improperly formatted.
-
valueOf
public static Version valueOf(java.lang.String version)
Returns aVersion
object holding the version identifier in the specifiedString
.See
Version(String)
for the format of the version string.This method performs a similar function as
parseVersion(String)
but has the static factoryvalueOf(String)
method signature.- Parameters:
version
- String representation of the version identifier. Leading and trailing whitespace will be ignored. Must not benull
.- Returns:
- A
Version
object representing the version identifier. Ifversion
is the empty string thenemptyVersion
will be returned. - Throws:
java.lang.IllegalArgumentException
- Ifversion
is improperly formatted.- Since:
- 1.8
-
getMajor
public int getMajor()
Returns the major component of this version identifier.- Returns:
- The major component.
-
getMinor
public int getMinor()
Returns the minor component of this version identifier.- Returns:
- The minor component.
-
getMicro
public int getMicro()
Returns the micro component of this version identifier.- Returns:
- The micro component.
-
getQualifier
public java.lang.String getQualifier()
Returns the qualifier component of this version identifier.- Returns:
- The qualifier component.
-
toString
public java.lang.String toString()
Returns the string representation of this version identifier.The format of the version string will be
major.minor.micro
if qualifier is the empty string ormajor.minor.micro.qualifier
otherwise.- Overrides:
toString
in classjava.lang.Object
- Returns:
- The string representation of this version identifier.
-
hashCode
public int hashCode()
Returns a hash code value for the object.- Overrides:
hashCode
in classjava.lang.Object
- Returns:
- An integer which is a hash code value for this object.
-
equals
public boolean equals(java.lang.Object object)
Compares thisVersion
object to another object.A version is considered to be equal to another version if the major, minor and micro components are equal and the qualifier component is equal (using
String.equals
).- Overrides:
equals
in classjava.lang.Object
- Parameters:
object
- TheVersion
object to be compared.- Returns:
true
ifobject
is aVersion
and is equal to this object;false
otherwise.
-
compareTo
public int compareTo(Version other)
Compares thisVersion
object to anotherVersion
.A version is considered to be less than another version if its major component is less than the other version's major component, or the major components are equal and its minor component is less than the other version's minor component, or the major and minor components are equal and its micro component is less than the other version's micro component, or the major, minor and micro components are equal and it's qualifier component is less than the other version's qualifier component (using
String.compareTo
).A version is considered to be equal to another version if the major, minor and micro components are equal and the qualifier component is equal (using
String.compareTo
).- Specified by:
compareTo
in interfacejava.lang.Comparable<Version>
- Parameters:
other
- TheVersion
object to be compared.- Returns:
- A negative integer, zero, or a positive integer if this version
is less than, equal to, or greater than the specified
Version
object. - Throws:
java.lang.ClassCastException
- If the specified object is not aVersion
object.
-
-