Nyx Main
You can use the main Nyx library to embed it into your project and use all or some of its features. The com.mooltiverse.oss.nyx
package brings the Nyx
class that is the entry point for all the available commands and features.
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.
In order to also download the correct dependencies you should use one of the automatic tools below.
Using Maven
When using Maven just add the following dependency to your POM
:
<dependency>
<groupId>com.mooltiverse.oss.nyx</groupId>
<artifactId>main</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="main" 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:main:3.1.3'
while if you're using the Kotlin DSL use this dependency:
implementation("com.mooltiverse.oss.nyx:main: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 simple. You just need to create a Nyx
instance and run the publish
command. It takes just one line of code, like:
import com.mooltiverse.oss.nyx.Nyx;
public class Test {
static void main(String[] args)
throws Exception {
new Nyx().publish(); // This is it!
}
}
In this example Nyx loads the configuration from the files it optionally finds at their default locations and runs the publish
command, which also implies infer
, mark
and make
.
You can get more control on the behavior by injecting some configuration programmatically and running tasks one by one. You can also start Nyx in a specific directory, get access to the internal Git repositoryobject and even the internal state, like in this example:
import com.mooltiverse.oss.nyx.Nyx;
import com.mooltiverse.oss.nyx.configuration.SimpleConfigurationLayer;
public class Test {
static void main(String[] args)
throws Exception {
File customDirectory = new File("~/project");
Nyx nyx = new Nyx(customDirectory); // Nyx now runs on the '~/project' directory
// Create a new configuration layer, set some options, and add it on top
// of other layers at the 'command line' layer level
SimpleConfigurationLayer configurationLayer = new SimpleConfigurationLayer();
configurationLayer.setDryRun(Boolean.TRUE); // make it run dry
configurationLayer.setReleasePrefix("rel"); // make it use 'rel' as the prefix for generated versions
nyx.configuration().withCommandLineConfiguration(configurationLayer); // inject the configuration
nyx.infer(); // let Nyx infer values from the Git repository
// now we have plenty of values in the State, let's read some...
System.out.println(nyx.state().getBranch());
System.out.println(nyx.state().getVersion());
// it might be a good place to run some custom tasks of yours, i.e. using the Git Repository
// let's say you create a RELEASE_NOTES.md file and want to commit it
nyx.repository().commit("Adding RELEASE_NOTES.md");
// then run the remaining tasks one by one
nyx.make();
nyx.mark();
nyx.publish();
}
}
Logging
Nyx uses SLF4J for logging and since it's an adapter to various logging frameworks it doesn't address any implementation specific setting or feature. What Nyx does is just sending log messages to SLF4J, but what actually happens behind SLF4J is out of Nyx's scope.
This means that if you're using one of the SLF4J supported frameworks you can have Nyx emit its logs conforming to the rest of your application. If you don't, just deploy and configure one of the supported frameworks along with Nyx.
This is why the verbosity
configuration option is ignored by the Java implementation of Nyx.
Log events are decorated with markers to let you categorize, colorize and filter them if you wish. The list of used markers is modelled in the Markers
class.