Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@favware/cliff-jumper

favware10.6kMIT6.0.0

A small CLI tool to create a semantic release and git-cliff powered Changelog

git-cliff, favware, cli, generator, changelog, semver, commit, conventional-changelog, keepachangelog, changelog-generator, conventional-commits

readme

cliff-jumper

A small CLI tool to create a semantic release and git-cliff powered Changelog

GitHub npm

Support Server

Description

When managing a collection of projects you often want to follow a standard CHANGELOG template for all of them, but you also do not want to have to setup the release flow for every package. This is where cliff-jumper comes in.

How this works

cliff-jumper uses a combination of conventional-recommended-bump and git-cliff to bump your package using semantic versioning (following a variation of the Angular preset (seen here)). It will:

  1. Perform preflight checks to verify that the tool can run
  2. Resolve which bump strategy should be used by using conventional-recommended-bump
    • If the CLI tool is ran inside a mono repo then only commits that affect the nested package will be considered!
  3. Bump the version in your package.json using npm version with the resolved strategy
  4. Validate that -t, --skip-tag (CLI flags) weren't provided or skipTag wasn't set to true in the config file
  5. Update the CHANGELOG.md (or a different file if configured through --changelog-prepend-file) file using git-cliff
  6. If --install was provided (or install: true set in the config file) then run the install command of the package manager (npm install, yarn install, or pnpm install) you used to call this CLI.

    • Important: when you install @favware/cliff-jumper globally this will always default to npm because of how NodeJS works. Therefore, if you wish for it to be yarn or npm make sure to add it as dev dependency to your project and call it locally.
  7. Stage the package.json and CHANGELOG.md (or a different file if configured through --changelog-prepend-file) files

  8. Commit the release
  9. Tag the release

Installation

You can use the following command to install this package, or replace npm install -D with your package manager of choice.

npm install -D @favware/cliff-jumper

Or install it globally:

npm install -g @favware/cliff-jumper

Then call the script with cliff-jumper or cj:

cliff-jumper --name "my-package" --package-path "." # Add any other flags or use --help
cj --name "my-package" --package-path "." # Add any other flags or use --help

Alternatively you can call the CLI directly with npx:

npx @favware/cliff-jumper --name "my-package" --package-path "." # Add any other flags or use --help

Usage

You can provide all options through CLI flags:

Usage: cliff-jumper [options]

Options:
  -V, --version                            output the version number
  -n, --name <string>                      The package name to release
  -p, --package-path <string>              The path to the current package. For non-monorepos this is just "."
  --dry-run                                Whether the package should be bumped or not. When this is set no actions will be taken and only the release strategy will be logged
  --skip-automatic-bump                    Whether to skip bumping the version (useful if this is the first version, or if you have manually set the version)
  --mono-repo                              Whether the package to be bumped resides in a mono repo,
                                           which enables Lerna-like scanning for what kind of version bump should be applied
                                           Defaults to "true" when "org" is set, false otherwise
  --no-mono-repo                           Whether the package to be bumped resides in a mono repo,
                                           which enables Lerna-like scanning for what kind of version bump should be applied
                                           Defaults to "true" when "org" is set, false otherwise
  -o, --org <string>                       The NPM org scope that should be used WITHOUT "@" sign or trailing "/"
  --preid [string]                         The "prerelease identifier" to use as a prefix for the "prerelease" part of a semver
  --identifier-base <number>               The base number (0 or 1) to be used for the prerelease identifier.
  --no-identifier-base                     Do not use a base number for the prerelease identifier.
  -c, --commit-message-template [string]   A custom commit message template to use.
                                           Defaults to "chore({{name}}): release {{full-name}}@{{new-version}}"
                                           You can use "{{new-version}}" in your template which will be dynamically replaced with whatever the new version is that will be
                                           published.
                                           You can use "{{name}}" in your template, this will be replaced with the name provided through "-n", "--name" or the same value set in
                                           your config file.
                                           You can use "{{full-name}}" in your template, this will be replaced "{{name}}" (when "org" is not provided), or "@{{org}}/{{name}}"
                                           (when "org" is provided).
  --tag-template [string]                  A custom tag template to use.
                                           When "org" is provided this will default to "@{{org}}/{{name}}@{{new-version}}", for example "@favware/cliff-jumper@1.0.0"
                                           When "org" is not provided this will default to "v{{new-version}}", for example "v1.0.0"
                                           You can use "{{new-version}}" in your template which will be dynamically replaced with whatever the new version is that will be
                                           published.
                                           You can use "{{org}}" in your template, this will be replaced with the org provided through "-o", "--org" or the same value set in
                                           your config file.
                                           You can use "{{name}}" in your template, this will be replaced with the name provided through "-n", "--name" or the same value set in
                                           your config file.
                                           You can use "{{full-name}}" in your template, this will be replaced "{{name}}" (when "org" is not provided), or "@{{org}}/{{name}}"
                                           (when "org" is provided).
  -i, --install                            Whether to run npm install after bumping the version but before committing and creating a git tag. This is useful when you have a
                                           mono repo where bumping one package would then cause the lockfile to be out of date.
  --skip-changelog                         Whether to skip updating your changelog file
                                           default "true" when CI=true, "false" otherwise
  --no-skip-changelog                      Whether to skip updating your changelog file
                                           default "true" when CI=true, "false" otherwise
  -t, --skip-tag                           Whether to skip creating a git tag
                                           default "true" when CI=true, "false" otherwise
  --no-skip-tag                            Whether to skip creating a git tag
                                           default "true" when CI=true, "false" otherwise
  --changelog-prepend-file [string]        The file that git-cliff should use for the --prepend flag, defaults to ./CHANGELOG.md. This should be relative to the current working
                                           directory.
  --skip-commit [skipCommit...]            Repeatable, each will be treated as a new entry. A list of SHA1 commit hashes that will be skipped in the changelog.
  --git-host-variant [gitHostVariant]      The git host variant. Git-cliff supports 4 hosting websites, GitHub, GitLab, Gitea, and BitBucket. By setting this option you control
                                           which api is used by git-cliff. Defaults to "github" for backwards compatibility.
  --git-repo                               The git repository to use for linking to issues and PRs in the changelog.
                                           You can pass the unique string "auto" to automatically set this value as {{org}}/{{name}} as provided from --org and --name
                                           This should be in the format "owner/repo"
                                           You can use the "GIT_REPO" environment variable to automatically set this value
  --git-token                              A token to authenticate requests to the Git host API. This can be a GitHub, GitLab, Gitea, or BitBucket token. Which is used is
                                           determined by "--git-host-variant". This is required when using the "--git-repo" option.
                                           You can also set the one of the following environment variables.
                                           - GITHUB_TOKEN
                                           - GITLAB_TOKEN
                                           - GITEA_TOKEN
                                           - BITBUCKET_TOKEN
                                           - GH_TOKEN
  --push-tag                               Whether to push the tag to the remote repository.
                                           This will simply execute "git push && git push --tags" so make sure you have configured git for pushing properly beforehand.
  --no-push-tag                            Whether to push the tag to the remote repository.
                                           This will simply execute "git push && git push --tags" so make sure you have configured git for pushing properly beforehand.
  --github-release                         Note that this is only supported if "--git-host-variant" is set to "github"
                                           Whether to create a release on GitHub, requires "--push-tag" to be enabled, otherwise there will be no tag to create a release from
                                           For the repository the release is created on the value from "--git-repo" will be used
                                           If the changelog section from git-cliff is empty, the release notes will be auto-generated by GitHub.
  --no-github-release                      Note that this is only supported if "--git-host-variant" is set to "github"
                                           Whether to create a release on GitHub, requires "--push-tag" to be enabled, otherwise there will be no tag to create a release from
                                           For the repository the release is created on the value from "--git-repo" will be used
                                           If the changelog section from git-cliff is empty, the release notes will be auto-generated by GitHub.
  --github-release-draft                   Note that this is only supported if "--git-host-variant" is set to "github"
                                           Whether the release should be a draft
  --github-release-pre-release             Note that this is only supported if "--git-host-variant" is set to "github"
                                           Whether the release should be a pre-release
  --github-release-latest                  Note that this is only supported if "--git-host-variant" is set to "github"
                                           Whether the release should be marked as the latest release, will try to read this value, then the value of --github-release, and then
                                           default to false. Please note that when setting --github-release-pre-release to `true` GitHub will prevent the release to be marked
                                           as latest an this option will essentially be ignored.
  --github-release-name-template [string]  Note that this is only supported if "--git-host-variant" is set to "github"
                                           A GitHub release name template to use. Defaults to an empty string, which means GitHub will use the tag name as the release name.
                                           You can use "{{new-version}}" in your template which will be dynamically replaced with whatever the new version is that will be
                                           published.
                                           You can use "{{org}}" in your template, this will be replaced with the org provided through "-o", "--org" or the same value set in
                                           your config file.
                                           You can use "{{name}}" in your template, this will be replaced with the name provided through "-n", "--name" or the same value set in
                                           your config file.
                                           You can use "{{full-name}}" in your template, this will be replaced "{{name}}" (when "org" is not provided), or "@{{org}}/{{name}}"
                                           (when "org" is provided).
  -v, --verbose                            Whether to print verbose information (default: false)
  -h, --help                               display help for command

Or, you can set most of these options through a configuration file. This file should be located at your current working directory (where you're calling this package). It should be named .cliff-jumperrc, optionally suffixed with .json, .yaml, or .yml.

Config file fields

  • --name maps to name
  • --package-path maps to packagePath
  • --dry-run maps to dryRun
  • --skip-automatic-bump maps to skipAutomaticBump
  • --mono-repo and --no-mono-repo map to monoRepo
  • --org maps to org
  • --preid maps to preid
  • --identifier-base and --no-identifier-base map to identifierBase
  • --commit-message-template maps to commitMessageTemplate
  • --tag-template maps to tagTemplate
  • --install map to install
  • --skip-changelog and --no-skip-changelog map to skipChangelog
  • --skip-tag and --no-skip-tag map to skipTag
  • --changelog-prepend-file maps to changelogPrependFile
  • --skip-commit maps to skipCommit
  • --git-host-variant maps to gitHostVariant
  • --git-repo maps to gitRepo
  • --git-token maps to gitToken
  • --push-tag and --no-push-tag map to pushTag
  • --github-release and --no-github-release map to githubRelease
  • --github-release-draft maps to githubReleaseDraft
  • --github-release-pre-release maps to githubReleasePrerelease
  • --github-release-latest maps to githubReleaseLatest
  • --github-release-name-template maps to githubReleaseNameTemplate
  • --verbose maps to verbose

When using .cliff-jumperrc or .cliff-jumperrc.json as your config file you can also use the JSON schema to get schema validation. To do so, add the following to your config file:

{
  "$schema": "https://raw.githubusercontent.com/favware/cliff-jumper/main/assets/cliff-jumper.schema.json"
}

Alternatively you can reference the local schema in node_modules:

{
  "$schema": "./node_modules/@favware/cliff-jumper/assets/cliff-jumper.schema.json"
}

Example JSON file:

{
  "$schema": "https://raw.githubusercontent.com/favware/cliff-jumper/main/assets/cliff-jumper.schema.json",
  "name": "my-package",
  "packagePath": ".",
  "verbose": true
}

Example YAML file:

name: my-package
packagePath: .
verbose: true

Default values

This library has opinionated defaults for its options. These are as follows:

  • --dry-run will default to undefined.
  • --skipAutomaticBump will default to undefined.
  • --org will default to undefined.
  • --preid will default to undefined.
  • --identifier-base will default to undefined. Alternatively, you can force this to false by providing --no-identifier-base.
  • --install will default to undefined.
  • --skip-changelog will default to false (true when CI environment variable is 'true'). Alternatively you can force this to false by providing --no-skip-changelog.
  • --skip-tag will default to false (true when CI environment variable is 'true'). Alternatively you can force this to false by providing --no-skip-tag.
  • --mono-repo will default to true when org is set, or false when it's not. Alternatively you can force this to false by providing --no-mono-repo.
  • --commit-message-template will default to chore({{name}}): release {{full-name}}@{{new-version}}
    • {{new-version}} will be replaced with the new version that will be published
    • {{name}} will be replaced with the name provided through -n, --name or the same value set in your config file
    • {{full-name}} will be replaced with {{name}} (when org is not provided), or @{{org}}/{{name}} (when org is provided).
  • --tag-template will default to {{full-name}}@{{new-version}} (when org is provided) or v{{new-version}} (when org is not provided)
    • {{new-version}} will be replaced with the new version that will be published
    • {{name}} will be replaced with the name provided through -n, --name or the same value set in your config file
    • {{org}} will be replaced with the org provided through -o, --org or the same value set in your config file
    • {{full-name}} will be replaced with {{name}} (when org is not provided), or @{{org}}/{{name}} (when org is provided).
  • --changelog-prepend-file will default to ./CHANGELOG.md.
  • --skip-commit will default to [] (an empty array).
  • --git-host-variant will default to 'github'.
  • --git-repo will default to undefined.
  • --git-token will default to undefined.
  • --push-tag will default to false. Alternatively you can force this to false by providing --no-push-tag.
  • --github-release will default to false. Alternatively you can force this to false by providing --no-github-release.
  • --github-release-draft will default to false.
  • --github-release-pre-release will default to false.
  • --github-release-latest will default to true.
  • --github-release-name-template will default to an empty string.
  • --verbose will default to false.

Merging of config file, defaults and CLI provided flags

When you have a config file the options in the file are merged with the default options and with any other provided CLI flags. Which source takes highest priority depends on the type of the option. The priority is as follows (lower means it gets lower priority):

  1. CLI flags
  2. Default values
  3. Config file

This means that the CLI flags will always have the highest priority. This way you can have a config file for base options, then overwrite that with CLI flags, such as in a CI environment.

Creating a GitHub release

This package provides the options --push-tag and --github-release to automatically create a release on GitHub using the output from git-cliff as the release notes. In order to use this feature you have to provide --git-host-variant=github, --git-repo, and --git-token (or set the latter respective environment variables). Alternatively, if you want to run this step from a GitHub workflow you can base your step on the following example.

It is very important that if your main branch is protected by branch protection you have to provide a Personal Access Token (this can be both a classic or a fine-grained one) for a user who can bypass branch protections as token: ${{ secrets.YOUR_TOKEN_VAR }} to actions/checkout!

- name: Checkout Project
  uses: actions/checkout@v4
  with:
    fetch-depth: 0
    ref: main
- name: Use Node.js v20
  uses: actions/setup-node@v4
  with:
    node-version: 20
    cache: yarn
- name: Configure Git
  run: |
    git remote set-url origin "https://${GITHUB_TOKEN}:x-oauth-basic@github.com/${GITHUB_REPOSITORY}.git"
    git config --local user.email "${GITHUB_EMAIL}"
    git config --local user.name "${GITHUB_USER}"
  env:
    GITHUB_USER: github-actions[bot]
    GITHUB_EMAIL: 41898282+github-actions[bot]@users.noreply.github.com
    GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Bump Versions & Publish
  run: npx @favware/cliff-jumper
  env:
    GITHUB_TOKEN: ${{ secrets.BOT_TOKEN }}

This will create a GitHub commit, release, and tag using the GitHub Actions bot account. This ensures that you do not need a Personal Access Token to create a release. The GITHUB_TOKEN secret is provided by GitHub Actions and is a token that has the necessary permissions to create a release. It also be noted that classic Personal Access Tokens will not even work for this, you will at least need a Fine-Grained Personal Access Token which is at time of writing (2024-06-03) a beta feature. You can find more information about there here.

Lastly, the example above assumes a cliff-jumper config file similar to the one in this repository (.cliff-jumperrc). As an alternative example for a package that is not scoped by an npm/github org here is another example. Replace the values in between <> with your desired values.

name: <package-name>
packagePath: .
pushTag: true
gitRepo: <repo-owner>/<repo-name>
githubRelease: true
githubReleaseLatest: true

Example Configuration setups

Following are JSON examples of how you can configure this package based on different situations.

Scoped packages in a non-mono repo

This is for versioning @my-org/my-package that does not reside in a mono repo, for example sapphiredev/shapeshift

{
  "name": "package-name",
  "packagePath": ".",
  "org": "my-org",
  "monoRepo": false,
  "commitMessageTemplate": "chore(release): release {{new-version}}",
  "tagTemplate": "v{{new-version}}"
}

Scoped packages in a mono repo

This is for versioning @my-org/my-package that resides in a mono repo, for example sapphiredev/utilities

{
  "name": "package-name",
  "org": "my-org",
  "packagePath": "packages/decorators"
}

Non-scoped packages in a non-mono repo

This is for versioning my-package that does not reside in a mono repo, for example favware/esbuild-plugin-version-injector

{
  "name": "my-package",
  "packagePath": ".",
  "commitMessageTemplate": "chore(release): release {{new-version}}",
  "tagTemplate": "v{{new-version}}"
}

Non-scoped packages in a mono repo

This is for versioning my-package that resides in a mono repo, for example discord.js/discordjs

{
  "name": "my-package",
  "packagePath": "packages/discord.js",
  "tagTemplate": "{{new-version}}"
}

Git Cliff commands executed

The following commands are executed by git-cliff after options are parsed, depending on the scenario:

In a regular repository

git cliff --tag "TAG_TEMPLATE_OPTION" --prepend ./CHANGELOG.md --unreleased --config ./cliff.toml

For example this could be:

git cliff --tag "@favware/cliff-jumper@1.0.0" --prepend ./CHANGELOG.md --unreleased --config ./cliff.toml

In a mono repository

git cliff --tag "TAG_TEMPLATE_OPTION" --prepend ./CHANGELOG.md --unreleased --config ./cliff.toml --repository RELATIVE_PATH_TO_REPOSITORY_ROOT --include-path "PACKAGE_PATH_OPTIONS/*"

For example this could be:

git cliff --tag "@sapphire/utilities@1.0.0" --prepend ./CHANGELOG.md --unreleased --config ./cliff.toml --repository ../../ --include-path "packages/utilities/*"

Buy us some doughnuts

Favware projects are and always will be open source, even if we don't get donations. That being said, we know there are amazing people who may still want to donate just to show their appreciation. Thank you very much in advance!

We accept donations through Ko-fi, Paypal, Patreon, GitHub Sponsorships, and various cryptocurrencies. You can use the buttons below to donate through your method of choice.

Donate With Address
Ko-fi Click Here
Patreon Click Here
PayPal Click Here
GitHub Sponsors Click Here
Bitcoin 1E643TNif2MTh75rugepmXuq35Tck4TnE5
Ethereum 0xF653F666903cd8739030D2721bF01095896F5D6E
LiteCoin LZHvBkaJqKJRa8N7Dyu41Jd1PDBAofCik6

Contributors

Please make sure to read the Contributing Guide before making a pull request.

Thank you to all the people who already contributed to Sapphire!

contributors

changelog

Changelog

All notable changes to this project will be documented in this file.

@favware/cliff-jumper@6.0.0 - (2025-01-05)

🏠 Refactor

  • Remove various single dash aliases for commander v13 compatibility (ec2f91c) (#226)
    • 💥 BREAKING CHANGE: Removed -sab as alias for --skip-automatic-bump
    • 💥 BREAKING CHANGE: Removed -cpf as alias for --changelog-prepend-file
    • 💥 BREAKING CHANGE: Removed -pt as alias for --push-tag
    • 💥 BREAKING CHANGE: Removed -npt as alias for --no-push-tag
    • 💥 BREAKING CHANGE: Removed -ghr as alias for --github-release
    • 💥 BREAKING CHANGE: Removed -nghr as alias for --no-github-release
    • 💥 BREAKING CHANGE: Removed -ghrd as alias for --github-release-draft
    • 💥 BREAKING CHANGE: Removed -ghrpr as alias for --github-release-pre-release
    • 💥 BREAKING CHANGE: Removed -ghrl as alias for --github-release-latest
    • 💥 BREAKING CHANGE: Removed -ghrnt as alias for --github-release-name-template

🐛 Bug Fixes

  • deps: Update dependency commander to v13 (50bc424)
  • deps: Update all non-major dependencies (d55d42c) (#225)
  • deps: Update all non-major dependencies (5634a2d) (#221)
  • deps: Update dependency smol-toml to v1.3.1 [security] (fe8e888) (#218)
  • deps: Update all non-major dependencies (58680f1) (#215)
  • deps: Update all non-major dependencies (8140b95) (#212)
  • deps: Update dependency execa to ^9.5.0 (d50a4e6) (#211)

@favware/cliff-jumper@5.0.0 - (2024-10-19)

🐛 Bug Fixes

  • Check commits array to be defined before reading it (50478d0)
  • deps: Update dependency git-cliff to ^2.6.0 (31a525c) (#205)
  • deps: Update all non-major dependencies (3e07ebb) (#204)

🚀 Features

  • Support gitlab, gitea, and bitbucket for git-cliff (a4b30d0) (#208)
    • 💥 BREAKING CHANGE: --github-repo has been renamed to --git-repo
    • 💥 BREAKING CHANGE: githubRepo has been renamed to gitRepo
    • 💥 BREAKING CHANGE: --github-token has been renamed to gitToken
    • 💥 BREAKING CHANGE: githubToken has been renamed to gitToken
    • 💥 BREAKING CHANGE: The environment variables TOKEN_GITHUB and TOKEN_GH are no longer supported
    • 💥 BREAKING CHANGE: environment variables GITLAB_TOKEN, GITEA_TOKEN, and BITBUCKET_TOKEN are now supported for --git-token
    • 💥 BREAKING CHANGE: A new option --git-host-variant was added, which defaults to 'github'. To release to GitHub, this has to be set to 'github'.
  • Add commit skipping (22a51d9) (#201)

@favware/cliff-jumper@4.1.0 - (2024-08-24)

🐛 Bug Fixes

  • deps: Update all non-major dependencies (5e1f161) (#190)

🚀 Features

  • Update to git-cliff 2.5.0 (fb33eba)

@favware/cliff-jumper@4.0.3 - (2024-07-23)

🐛 Bug Fixes

  • install: Add --mode=update-lockfile for yarn v2/v3/v4 (ef02496)

@favware/cliff-jumper@4.0.2 - (2024-06-03)

🐛 Bug Fixes

  • Add a verbose logging entry for github release payload (a15e2b4)

@favware/cliff-jumper@4.0.1 - (2024-06-03)

🏠 Refactor

  • Remove dependency on conventional-changelog-angular and inline whatBump code (684b29f)

🐛 Bug Fixes

  • Fixed a grammar typo in preflight checks (9129a67)

📝 Documentation

  • Cleanup changelog (4c6377e)
  • Further specify github releasing (b59595b)

@favware/cliff-jumper@4.0.0 - (2024-06-03)

🏠 Refactor

  • Rename first-release to skip-automatic-bump (fe244a0)
    • 💥 BREAKING CHANGE: first-release has been renamed to skip-automatic-bump in order to better describe what it does
  • Remove automatic CI env detection (775f02e)
    • 💥 BREAKING CHANGE: Previously when running with CI env --skip-changelog and --skip-tag were automatically enabled. This is no longer the case, because the new GitHub releasing feature makes it more appealing to run this tool in CI. To restore the old functionality for your pipelines please explicitly add these tags to your command line.
  • deps: Update dependency conventional-recommended-bump to v10 (da1d45d)
    • 💥 BREAKING CHANGE: Node 18 is now required as per the new version of conventional-recommended-bump
    • 💥 BREAKING CHANGE: The base conventional-changelog-angular is now used instead of a customization of it. This should not affect the semver resolution, but if it does please create a GitHub issue

🐛 Bug Fixes

  • Respect the tag-template for github releases (85f4272)
  • deps: Update all non-major dependencies (93640e2)
  • deps: Update dependency execa to v9 (07e39ae) (#175)

📝 Documentation

  • readme: Document github releases (32208f2)
  • Update readme with missing flags (ffaf31a)
  • readme: Document which git-cliff commands get executed (7527ae9)

🚀 Features

  • Add --no-push-tag to override config file for prereleases (6f5d748)
  • Add --no-github-release to override config file for prereleases (656c8ec)
  • Add option --changelog-prepend-file to customize to which file the changelog is prepended (35e9731)
  • Add --push-tag and --github-release to automatically push a Git tag and create a release on GitHub (b66bfa1)

@favware/cliff-jumper@3.0.3 - (2024-04-23)

🏠 Refactor

🐛 Bug Fixes

  • commit-release: Remove quotes from commit message template (9fcab96) (#169)
  • Add GH_TOKEN, TOKEN_GITHUB and TOKEN_GH to the list possible env vars for github token (0ab906a)

@favware/cliff-jumper@3.0.2 - (2024-04-11)

🐛 Bug Fixes

  • deps: Update dependency git-cliff to ^2.2.1 (1acd9b2) (#166)

@favware/cliff-jumper@3.0.1 - (2024-03-03)

🏠 Refactor

  • Switch to execa for a full async code (74c09c7)
  • Add spinner for cli command progress (6945d21)
  • Git cliff programmatic api (d542c51)

🐛 Bug Fixes

  • Bump git-cliff for windows github integration support, remove warning for the same (a68359d) (#158)

@favware/cliff-jumper@3.0.0 - (2024-03-01)

🐛 Bug Fixes

🚀 Features

  • Implement a press enter to continue system for GH integration for windows (22737c6)
  • Add support for --github-repo and --github-token (7ec4f9d)

@favware/cliff-jumper@2.2.3 - (2023-11-14)

🐛 Bug Fixes

  • Actually support yarn v4 oops (8e25acd)

@favware/cliff-jumper@2.2.2 - (2023-11-14)

🐛 Bug Fixes

  • Add support for yarn v4 (35af4dc)

@favware/cliff-jumper@2.2.1 - (2023-11-05)

🐛 Bug Fixes

  • Update to git cliff v1.4.0 (46f1357)

@favware/cliff-jumper@2.2.0 - (2023-09-22)

🚀 Features

  • Add support for identifierBase (#117) (37c919e)

@favware/cliff-jumper@2.1.3 - (2023-09-10)

🏠 Refactor

  • Bump conventional-recommended-bump and remove manual promisify (fe1dc29)

@favware/cliff-jumper@2.1.2 - (2023-08-29)

🏠 Refactor

🐛 Bug Fixes

  • deps: Update dependency commander to v11 (#94) (a80e63e)

@favware/cliff-jumper@2.1.1 - (2023-06-13)

🐛 Bug Fixes

  • Fixed finding of package lock file (8c9905b)

@favware/cliff-jumper@2.1.0 - (2023-06-09)

🐛 Bug Fixes

  • Include JSON schema in published tarball (e106743)
  • Update conventional-recommended-bump to v7 (27691f9)
  • Update non major dependencies (fc68720)
  • Do not check for git cliff in preflish as the lib provides it (2a2a8b4)

📝 Documentation

🚀 Features

  • Add --install option which runs package manager install before staging files (63b13d4)

@favware/cliff-jumper@2.0.1 - (2023-05-27)

🐛 Bug Fixes

  • Move typescript to dev dependencies (3396e8c)
  • deps: Update all non-major dependencies (f8b8476)
  • Update dependencies (83134e7)
  • deps: Update all non-major dependencies (1981fa6)

@favware/cliff-jumper@2.0.0 - (2023-03-05)

🐛 Bug Fixes

  • Fixed npx executable for git-cliff (cde7e4c)
  • changelog-angular: Updated source files to latest from mirror (a831453)
  • deps: Update dependency commander to v10 (#65) (f725495)
    • 💥 BREAKING CHANGE: @favware/cliff-jumper v2 requires Node.js v14 or higher due to the dependency of Commander@10.x

🚀 Features

  • deps: Use git-cliff from npm instead of relying on native install (#68) (0494e92)
    • 💥 BREAKING CHANGE: @favware/cliff-jumper v2 uses v1.1.2 of git-cliff, refer to the changelog of git cliff for their breaking changes at v1.x

@favware/cliff-jumper@1.10.0 - (2023-01-08)

🚀 Features

  • Change to @favware/conventional-changelog-angular to solve issue with breaking change headers (96c885b)

@favware/cliff-jumper@1.9.0 - (2022-11-19)

🐛 Bug Fixes

  • deps: Update dependency @sapphire/result to ^2.6.0 (9ed7289)
  • deps: Update dependency @sapphire/utilities to v3.11.0 (0919bf6)
  • Bump @sapphire/utilities (50ec6ac)

📝 Documentation

  • Add imranbarbhuiya as a contributor for code (#54) (00e8c2f)
  • readme: Add configuration examples (5e891b0)

🚀 Features

  • Create an empty changelog file when it does not yet exist and first release was provided (#31) (90acb2a)

@favware/cliff-jumper@1.8.8 - (2022-10-02)

🐛 Bug Fixes

  • deps: Update dependency @sapphire/result to ^2.5.0 (02bcb09)
  • deps: Update sapphire dependencies (e230602)

@favware/cliff-jumper@1.8.7 - (2022-08-20)

🐛 Bug Fixes

  • Bump dependencies (5b2e69a)
  • deps: Update sapphire dependencies (431ed48)

@favware/cliff-jumper@1.8.6 - (2022-07-30)

🐛 Bug Fixes

  • Update dependecies (93eab72)
  • deps: Update dependency @sapphire/result to ^2.0.1 (cc26aa0)
  • deps: Update dependency @sapphire/utilities to ^3.7.0 (e9bfa0a)

@favware/cliff-jumper@1.8.5 - (2022-06-29)

🐛 Bug Fixes

  • Use resolved new version if available (eacdb59)

@favware/cliff-jumper@1.8.4 - (2022-06-26)

🏠 Refactor

  • Update to sapphire result v2 (eaeb14a)

@favware/cliff-jumper@1.8.3 - (2022-06-06)

🏠 Refactor

  • Change dry run method for comitting (40190cd)
  • Deduplicate tag template resolver (ad95276)

🐛 Bug Fixes

  • Ensure --dry-run goes through the whole process while not writing anything (1dc7709)
  • Use tagTemplate for git cliff (5a59274)
  • deps: Update all non-major dependencies (9f55cb5)

@favware/cliff-jumper@1.8.2 - (2022-06-03)

🏠 Refactor

  • Stop using npm to read new version and instead read and parse JSON (7207e45)

🐛 Bug Fixes

  • Properly resolve pre-releases (cc760af)
  • Stop using npm version to bump package and instead use semver directly (662b90e)

📝 Documentation

  • Add @renovate[bot] as a contributor (75da1b1)
  • Add @renovate-bot as a contributor (a3558eb)
  • Fix JSON schema (df316de)

@favware/cliff-jumper@1.8.0 - (2022-05-13)

🚀 Features

  • Allow forcing skipChangelog and skipTag to false with --no-* flags (99ffe13)

@favware/cliff-jumper@1.7.0 - (2022-05-07)

🐛 Bug Fixes

  • Log the package and version and bumping the version (c50a27e)

🚀 Features

  • Revert b4bc73d99482416e73a69320ad09f2b853a26509 (do not auto disable changelog generation in CI) (41fb85a)

@favware/cliff-jumper@1.6.0 - (2022-05-07)

🐛 Bug Fixes

  • Do not auto disable changelog generation in CI (b4bc73d)

🚀 Features

  • Log the package and version after generating the changelog (71ab681)

🪞 Styling

  • Change emoji from 📦 to 📝 (6304346)

@favware/cliff-jumper@1.5.1 - (2022-05-07)

🐛 Bug Fixes

  • List tag template in verbose options log (87393a2)
  • Only require options.monoRepo to use mono repo detection for conventional recommended bump (f1548f3)

@favware/cliff-jumper@1.5.0 - (2022-05-07)

🚀 Features

  • Add tag template option (1e047b6)

@favware/cliff-jumper@1.4.0 - (2022-04-28)

Features

  • Log yarn npm publish when the package is using Yarn v3 (983b191)
  • Introduce new flag --skip-changelog and separate skip-tag from it. Follows same behaviour to ensure non-breaking (b21b772)

@favware/cliff-jumper@1.3.1 - (2022-04-26)

Bug Fixes

  • tag: Only tag with package name in mono repos (bb73dc3)

@favware/cliff-jumper@1.3.0 - (2022-04-26)

Features

  • Add --mono-repo and --no-mono-repo flags (6d86477)

@favware/cliff-jumper@1.2.0 - (2022-04-21)

Features

  • Add commitMessageTemplate (933a6e5)

@favware/cliff-jumper@1.1.3 - (2022-04-18)

Bug Fixes

  • Fixed commit message being invalid after execa->execSync change (37ed667)
  • Switch from execa to execSync (4f26562)

@favware/cliff-jumper@1.1.2 - (2022-04-18)

Bug Fixes

  • Properly check if git cliff exists or not (5ab2727)

@favware/cliff-jumper@1.1.1 - (2022-04-18)

Bug Fixes

  • Only check for changelog and git-cliff when skip-tag is false (7d3a2c8)
  • Fixed bundle published to npm (c1d996d)

@favware/cliff-jumper@1.1.0 - (2022-04-18)

Features

  • Add notice once done about pushing and publishing (a9a54a5)

Refactor

  • Improve checking for git cliff (82c9500)

@favware/cliff-jumper@1.0.2 - (2022-04-18)

Bug Fixes

  • Add missing conventional-changelog-angular dependency (f3efcc8)

@favware/cliff-jumper@1.0.1 - (2022-04-18)

Bug Fixes

  • github-release: Use yarn publish (8453aa4)

[@favware/cliff-jumper@1.0.0]

(https://github.com/favware/cliff-jumper/tree/@favware/cliff-jumper@1.0.0) - (2022-04-17)

Bug Fixes

  • commit: Remove wrapping quotes from commit (9891524)
  • Fixed tag in changelog (14ac52f)
  • Fixed resolving git-cliff options (ae7eb84)
  • Fixed resolving repository root (7fb9f72)
  • Better fix for parsing options (867abe1)
  • Resolved issue with merging of options (b1abe16)
  • Fixed boolean options (4bf2b0b)
  • Ensure git-cliff can properly be detected (bea671a)
  • Manually check required options (8d54298)

Features

Refactor