Semantic Version
The 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
To install the module locally run:
go get github.com/mooltiverse/nyx/src/go/version
To import it in your source code:
import "github.com/mooltiverse/nyx/src/go/version"
API docs
Thanks to Go docs you can browse the API docs at this URL.
Using the library
Using the library is simple. You just need to create a SemanticVersion
and use it as in the following example.
Remember the SemanticVersion
is immutable so every time you invoke a method that changes the number you actually get a new object representing the new state.
package main
import version "github.com/mooltiverse/nyx/src/go/version"
func main() {
// parse any string as a semantic version, in this case we use the default initial version "0.1.0"
v1, err := version.ValueOfSemanticVersion(version.SEMANTIC_VERSION_DEFAULT_INITIAL_VERSION)
// bump the MINOR number > "0.2.0"
v2, err := v1.BumpMinor()
// bump the MAJOR number > "1.0.0"
v3, err := v2.BumpMajor()
// bump the new pre-release identifier named 'alpha' > "1.0.0-alpha.1"
v4, err := v3.BumpPrerelease("alpha")
// bump the 'alpha' pre-release identifier again > "1.0.0-alpha.2"
v5, err := v4.BumpPrerelease("alpha")
// add the 'build' identifier and give it the '123' value > "1.0.0-alpha.2+build.123"
v6, err := v5.SetBuild("build", "123")
// and so on...
}
The SemanticVersion
also provides additional useful methods to handle arbitrary identifiers so that it's even more expressive. For example:
v1, err := version.ValueOfSemanticVersion("2.0.3")
v2, err := v1.SetBuildAttributeWith("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...
v3, err := v2.SetBuildAttributeWith("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
v4, err := v3.SetPrereleaseAttributeWith("develop").setPrereleaseAttribute("tag", 3)
// v4 is now "2.0.3-develop.tag.3+timestamp.20991201T2359"