Skip to main content

Global Options

These are the top level options in the configuration:

NameTypeCommand Line OptionEnvironment VariableDefault
bumpstring-b=<NAME>, --bump=<NAME>NYX_BUMP=<NAME>N/A
changelogobjectSee ChangelogSee ChangelogN/A
commitMessageConventionsobjectSee Commit Message ConventionsSee Commit Message ConventionsN/A
configurationFilestring-c=<PATH>, --configuration-file=<PATH>NYX_CONFIGURATION_FILE=<PATH>N/A
directorystring-d=<PATH>, --directory=<PATH>NYX_DIRECTORY=<PATH>Current working directory
dryRunboolean--dry-run, --dry-run=true|falseNYX_DRY_RUN=true|falsefalse
gitobjectSee GitSee GitN/A
helpflag--helpN/AN/A
initialVersionstring--initial-version=<VERSION>NYX_INITIAL_VERSION=<VERSION>Depends on the configured version scheme
presetstring--preset=<NAME>NYX_PRESET=<NAME>N/A
releaseAssetsobjectSee Release AssetsSee Release AssetsN/A
releaseLenientboolean--release-lenient, --release-lenient=true|falseNYX_RELEASE_LENIENT=true|falsetrue
releasePrefixstring--release-prefix=<PREFIX>NYX_RELEASE_PREFIX=<PREFIX>N/A
releaseTypesobjectSee Release TypesSee Release TypesN/A
resumestring--resume, resume=true|falseNYX_RESUME=true|falsefalse
schemestring--scheme=<NAME>NYX_SCHEME=<NAME>SEMVER
servicesobjectSee ServicesSee ServicesN/A
sharedConfigurationFilestring--shared-configuration-file=<PATH>NYX_SHARED_CONFIGURATION_FILE=<PATH>N/A
stateFilestring--state-file=<PATH>NYX_STATE_FILE=<PATH>N/A
summarystring--summary, summary=true|falseNYX_SUMMARY=true|falsefalse
summaryFilestring--summary-file=<PATH>NYX_SUMMARY_FILE=<PATH>N/A
verbositystring--verbosity=<LEVEL>, --fatal, --error, --warning, --info, --debug, --traceNYX_VERBOSITY=<LEVEL>WARNING
versionstring-v=<VERSION>, --version=<VERSION>NYX_VERSION=<VERSION>N/A

Bump

Namebump
Typestring
DefaultN/A
Command Line Option-b=<NAME>, --bump=<NAME>
Environment VariableNYX_BUMP=<NAME>
Configuration File Optionbump
Related state attributes

Instructs Nyx on which identifier to bump on the past version in order to build the new version.

This option prevents Nyx to infer the identifier to bump from the commit history.

Valid values for this options are the identifier names for the current version scheme.

Using Semver they are core, major, minor. Names other than these are interpreted as pre-release identifier names so, for example, if the past version is 1.2.3 and you set this option to alpha, the new version will be 1.2.3-alpha.1 at the first run, 1.2.3-alpha.2 the second and so on.

This option has no effect if version is also used.

The short option name -b=<NAME> has priority over the extended --bump=<NAME> in case they are used together.

Configuration file

NameconfigurationFile
Typestring
DefaultN/A
Command Line Option-c=<PATH>, --configuration-file=<PATH>
Environment VariableNYX_CONFIGURATION_FILE=<PATH>
Configuration File OptionconfigurationFile
Related state attributes

This option allows you to load a configuration file from a location other than default ones. This can be a relative or absolute path to a local file or an URL to load a remote file. This configuration file can override other options, as per the evaluation order, and can be authored as .yaml (or .yml) or .json (the format is inferred by the file extension or JSON is used by default) just like the default configuration files.

Configuration files have higher priority over shared configuration files so they can override specific options inherited from them.

info

Consider using a standard path for configuration files before using a custom one, so you don't even need to use this option.

info

In order to avoid chaining this option is ignored when defined in custom configuration files loaded by means of this same option.

The short option name -c=<PATH> has priority over the extended --configuration-file=<PATH> in case they are used together.

Changelog

See Changelog.

Commit message conventions

See Commit Message Conventions.

Directory

Namedirectory
Typestring
DefaultCurrent working directory
Command Line Option-d=<PATH>, --directory=<PATH>
Environment VariableNYX_DIRECTORY=<PATH>
Configuration File Optiondirectory
Related state attributes

Sets the working directory for Nyx. The directory is where Nyx searches for the Git repository and is also used as the base path when relative paths to local files or directories.

By default Nyx uses the process' working directory for this.

The Gradle plugin reads the current working directory by the projectDir property by default, unless it's overridden by this configuration.

The short option name -d=<PATH> has priority over the extended --directory=<PATH> in case they are used together.

Dry run

NamedryRun
Typeboolean
Defaultfalse
Command Line Option--dry-run, `--dry-run=true
Environment Variable`NYX_DRY_RUN=true
Configuration File OptiondryRun
Related state attributes

When this flag is set to true no action altering the repository state, either local or remote, is taken. Instead the actions that would be taken if this flag was not set are printed to the log.

When used with no value on the command line (i.e. --dry-run alone) true is assumed.

When enabling this flag you probably want to raise the verbosity.

Git

See Git.

Help

Namehelp
Typeflag
DefaultN/A
Command Line Option--help
Environment VariableN/A
Configuration File OptionN/A
Related state attributes

Prints the command line synopsis and exits with code 0, without running any command. Any other option is ignored.

This option is only available on the command line.

Initial version

NameinitialVersion
Typestring
DefaultDepends on the configured version scheme
Command Line Option--initial-version=<VERSION>
Environment VariableNYX_INITIAL_VERSION=<VERSION>
Configuration File OptioninitialVersion
Related state attributes

The default version to use when no previous version can be inferred from the commit history (i.e. when the repository has no tagged releases yet). When not specified this value is determined by the configured version scheme.

This might be useful for project bootstrapping only (from Nyx's perspective) when the default initial version just doesn't fit your need. Remember that this value will be considered just once because after the first release (which consumes this option) there will be a previous version in the commit history.

This value is ignored when the version option is used. See this example to see how this option can be used.

Preset

Namepreset
Typestring
DefaultN/A
Command Line Option--preset=<NAME>
Environment VariableNYX_PRESET=<NAME>
Configuration File Optionpreset
Related state attributes

This option allows you to import one preset configuration into your configuration to save configuration time and effort.

Presets have low priority in the evaluation order so you can override their values by several means if you need to. On the other hand they are an effective way to get started in minutes using well known and tested streamlined configurations.

Release assets

See Release Assets.

Release lenient

NamereleaseLenient
Typeboolean
Defaulttrue
Command Line Option--release-lenient, --release-lenient=true|false
Environment VariableNYX_RELEASE_LENIENT=true|false
Configuration File OptionreleaseLenient
Related state attributes

When this option is enabled (it is by default), Nyx will attempt to tolerate prefixes and other unnecessary characters (like leading zeroes) when reading Git tags from the commit history. When true, tags like vx.y.x, relx.y.x etc will be detected as release tags (for version x.y.x), regardless of the prefix Nyx uses to generate release names. On the other hand, when this is false, Nyx will only detect tags strictly complying with the version scheme and the release prefix so, for instance, when releasePrefix is set to v, Nyx will only detect tags of the form vx.y.x while if the releasePrefix is not used, only x.y.x tags are detected, with no extra leading zeroes etc.

With this option enabled the prefixes of tags parsed by Nyx don't need to use the same prefix as releasePrefix so, for instance, if releasePrefix is v, Nyx can parse tags like x.y.x, vx.y.x, relx.y.x etc.

Unnecessary leading zeroes will still allow version numbers to be parsed although they will be sanitized upon parsing. For example, 1.02.3 has an offending 0 which will not cause the version to be rejected when this option is enabled. However, the version will be parsed as 1.2.3, with the offending characted sanitized.

When used with no value on the command line (i.e. --release-lenient alone) true is assumed.

Release prefix

NamereleasePrefix
Typestring
DefaultN/A
Command Line Option--release-prefix=<PREFIX>
Environment VariableNYX_RELEASE_PREFIX=<PREFIX>
Configuration File OptionreleasePrefix
Related state attributes

It's a common practice to add a leading string to version numbers to give releases a name. Common prefixes are v or rel but you might use anything, or no prefix at all.

When specifying a custom prefix, only use alphanumeric characters (no numbers or special characters).

info

Release names are not necessarily equal to versions. For example version 1.2.3 can be issued by the release named v1.2.3. This is a small difference but helps coping with the strict interpretation of valid version identifiers.

This option only affects the way Nyx generates release names and tags, while releaseLenient controls how tolerant Nyx is when reading release tags from the Git repository.

Release types

See Release Types.

Resume

Nameresume
Typeboolean
Defaultfalse
Command Line Option--resume, --resume=true|false
Environment VariableNYX_RESUME=true|false
Configuration File Optionresume
Related state attributes

When this flag is set to true Nyx tries to load an existing state file and resume operations from where it left when the state file was saved. This can improve execution time when you need to run Nyx in separate steps (i.e. when you run Infer, then do other tasks external to Nyx and then finalize the release process by running Infer).

This option only makes sense when you also set a value for the stateFile. If no stateFile is defined this option just has no effect.

When used with no value on the command line (i.e. --resume alone) true is assumed.

Scheme

Namescheme
Typestring
DefaultSEMVER
Command Line Option--scheme=<NAME>
Environment VariableNYX_SCHEME=<NAME>
Configuration File Optionscheme
Related state attributes

Selects the version scheme to use. Defaults to SEMVER.

Services

See Services.

Shared configuration file

NamesharedConfigurationFile
Typestring
DefaultN/A
Command Line Option--shared-configuration-file=<PATH>
Environment VariableNYX_SHARED_CONFIGURATION_FILE=<PATH>
Configuration File OptionsharedConfigurationFile
Related state attributes

This option allows you to load a shared configuration file from a location other than default ones. This can be a relative or absolute path to a local file or an URL to load a remote file. This configuration file can be authored as .yaml (or .yml), .json (the format is inferred by the file extension or JSON is used by default) just like the default configuration files.

Shared configuration files are meant to share a common set of configuration options among projects and they have lower priority over regular configuration files which, in turn, can be used to override specific options inherited from shared files.

info

Consider using a standard path for configuration files before using a custom one, so you don't even need to use this option.

info

In order to avoid chaining this option is ignored when defined in custom configuration files loaded by means of this same option.

State file

NamestateFile
Typestring
DefaultN/A
Command Line Option--state-file=<PATH>
Environment VariableNYX_STATE_FILE=<PATH>
Configuration File OptionstateFile
Related state attributes

Enables the creation of the state file where Nyx stores its findings and generated values.

The value passed here can be:

  • a simple file name that will be interpred as local to the current working directory
  • a relative path that will be interpreted as relative to the current working directory
  • an absolute file name

Nyx will infer the format of the file by the extension, where available ones are .yaml (or .yml), .json. When unable to infer the format by the extension JSON is assumed by default. This way, if you need to read the file for your own purposes, you can have it in the format that is more accessible to you.

info

The suggested name for the file, when used, is .nyx-state.<EXT> (so .nyx-state.yaml, .nyx-state.yml or .nyx-state.json). It's recommended to let Git ignore this file.

This option can also be used in conjunction with resume in case you wish to suspend the execution and resume from where you left at any other time.

Also see summaryFile in case you're interested in a smaller but easily parseable subset of information.

Summary

Namesummary
Typeboolean
Defaultfalse
Command Line Option--summary, --summary=true|false
Environment VariableNYX_SUMMARY=true|false
Configuration File Optionsummary
Related state attributes

When this flag is set to true a short summary containing relevant information from the internal state is printed to the console. The output is the same as the summary file but is printed to the standard output (regardless of the verbosity).

When used with no value on the command line (i.e. --summary alone) true is assumed.

This option is only available on the command line.

Summary file

NamesummaryFile
Typestring
DefaultN/A
Command Line Option--summary-file=<PATH>
Environment VariableNYX_SUMMARY_FILE=<PATH>
Configuration File OptionsummaryFile
Related state attributes

Enables the creation of the summary file where Nyx saves a subset of relevant information from the internal state as name value pairs, easy to parse.

An example of the file content is:

branch           = main
bump = minor
core version = true
latest version = true
new release = true
new version = true
scheme = SEMVER
timestamp = 1591802533
current version = 1.2.3
previous version = 1.2.2
prime version = 1.2.2

The value passed here can be:

  • a simple file name that will be interpred as local to the current working directory
  • a relative path that will be interpreted as relative to the current working directory
  • an absolute file name

The output is a simple text file and an example is .nyx-summary.txt.

info

When parsing the file you can rely on labels (on the left of the = sign) to be consistent and the presence of the = sign itself as a separator. Do not rely on the order of rows or the alignment and justification as they may change so you should always find values by grepping the line by the label and trim values.

Verbosity

Nameverbosity
Typestring
DefaultWARNING
Command Line Option--verbosity=<LEVEL>, --fatal, --error, --warning, --info, --debug, --trace
Environment VariableNYX_VERBOSITY=<LEVEL>
Configuration File Optionverbosity
Related state attributes

Controls the amount of output emitted by Nyx, where values are:

  • FATAL: only prints critical errors that prevent Nyx to complete. No output is printed when no fatal error is encountered
  • ERROR: only prints errors along with some essential information
  • WARNING: only prints errors and warnings along with some essential information (like the generated version number)
  • INFO : prints high level information about the internal action that Nyx runs
  • DEBUG: prints information obout internals that can be useful to debug Nyx in case of anomalies
  • TRACE: this is the most verbose option that prints lots of information, including internals

The command line supports a shorthand option for each verbosity level so you can also use --fatal, --error, --warning, --info, --debug, --trace instead of --verbosity=<LEVEL>. When multiple verbosity levels are given, the most verbose one is used.

The Java library ignores this setting as it is supposed to be managed by the application using the library, as explained here.

The Gradle plugin manages its own log level and being the Nyx plugin a library used by Gradle, it just conforms to Gradle's verbosity. In other words, when using the Gradle plugin you just have to set Gradle's verbosity.

Version

Nameversion
Typestring
DefaultN/A
Command Line Option-v=<VERSION>, --version=<VERSION>
Environment VariableNYX_VERSION=<VERSION>
Configuration File Optionversion
Related state attributes

Overrides the version and prevents Nyx to infer. When overriding this value you take over the tool and go the manual versioning way so Nyx won't try to read past versions from the commit history nor determine which identifiers to bump.

The short option name -v=<VERSION> has priority over the extended --version=<VERSION> in case they are used together.

The version in Gradle scripts

In Gradle build scripts the version standard Gradle project property is used instead of an extension configuration to grant consistency between the Gradle environment and Nyx. Example:

version = 'v1.2.3'
nyx {
// no 'version' option here
}

The entire Gradle script will be able to read the version number inferred by Nyx by reading the version property. In other words, the version property is both a configuration option and an output value to Nyx when used as a Gradle plugin.

In order to infer the version you should not assign any value to the version property in the Gradle script (which is to say you need to remove any version = ... definition) but you can still read it.