Semantic Version
The com.mooltiverse.oss.nyx.version
package provides you with a fully featured implementation of the Semantic Versioning (SemVer) specification without any external dependency. Full support for parsing, ordering, bumping and manipulating versions and their identifiers is provided.
This library is used at the Nyx core but yet is completely independent from its logic so is perfectly suitable for use in ano other context.
Get the library
Manual download
You can download the jar file directly from the Maven Central repository or by using the Maven Central repository search engine. The GitHub Packages repository is the other source where you can get it.
Using Maven
When using Maven just add the following dependency to your POM
:
<dependency>
<groupId>com.mooltiverse.oss.nyx</groupId>
<artifactId>version</artifactId>
<version>3.1.3</version>
</dependency>
Your local Maven setup will likely use the Maven Central repository by default but if you like to use the GitHub Packages repository you can follow these instructions.
Using Ivy
When using Ivy just add the following dependency:
<dependency org="com.mooltiverse.oss.nyx" name="version" rev="3.1.3" />
Using Gradle
If you're using the Groovy DLS add this to the dependencies your script:
implementation 'com.mooltiverse.oss.nyx:version:3.1.3'
while if you're using the Kotlin DSL use this dependency:
implementation("com.mooltiverse.oss.nyx:version:3.1.3")
API docs
Thanks to javadoc.io you can browse the Javadoc API at this URL.
Using the library
Using the library is extremely simple. Just import the SemanticVersion
class and use it as in the following example.
Remember the SemanticVersion
class is immutable so every time you invoke a method that changes the number you actually get a new object representing the new state.
import com.mooltiverse.oss.nyx.version.SemanticVersion;
public class Test {
static void main(String[] args){
// parse any string as a semantic version, in this case we use the default initial version "0.1.0"
SemanticVersion v1 = SemanticVersion.valueOf(SemanticVersion.DEFAULT_INITIAL_VERSION);
// bump the MINOR number > "0.2.0"
SemanticVersion v2 = v1.bumpMinor();
// bump the MAJOR number > "1.0.0"
SemanticVersion v3 = v2.bumpMajor();
// bump the new pre-release identifier named 'alpha' > "1.0.0-alpha.1"
SemanticVersion v4 = v3.bumpPrerelease("alpha");
// bump the 'alpha' pre-release identifier again > "1.0.0-alpha.2"
SemanticVersion v5 = v4.bumpPrerelease("alpha");
// add the 'build' identifier and give it the '123' value > "1.0.0-alpha.2+build.123"
SemanticVersion v6 = v5.setBuild("build", "123")
// and so on...
}
}
The SemanticVersion
class also provides additional useful methods to handle arbitrary identifiers so that it's even more expressive. For example:
SemanticVersion v1 = SemanticVersion.valueOf("2.0.3");
SemanticVersion v2 = v1.setBuildAttribute("timestamp", "20200101T1500"); // v2 is now "2.0.3+timestamp.20200101T1500"
// but in another run you want to overwrite the attribute with the same name, so...
SemanticVersion v3 = v2.setBuildAttribute("timestamp", "20991201T2359"); // v3 is now "2.0.3+timestamp.20991201T2359"
// or add a branch name and a tag value in the pre-release part, one as a simple attribute and the other as a named pair
SemanticVersion v4 = v3.setPrereleaseAttribute("develop").setPrereleaseAttribute("tag", 3);
// v4 is now "2.0.3-develop.tag.3+timestamp.20991201T2359"