Skip to main content

A CLI utility for bumping the version of any file type

Project description

Bump Anything

Copyright 2019-2025 Caleb Evans
Released under the MIT license

tests Coverage Status

Bump Anything is a command-line utility for incrementing the version It serves as a more-flexible alternative to npm version and similar tools because Bump Anything can handle any arbitrary text file and has built-in support for different types of projects.

Features

  • Bump the version number in any arbitrary file
  • Supports most project types (if no paths are supplied, automatically detects package.json in Node, setup.py or pyproject.toml in Python, style.css for WordPress themes, etc.)

Installation

Bump Anything requires Python 3.9 or newer to run, so please ensure you have it installed.

pip3 install bump-anything

Usage

Bump Anything exposes to your shell a bump-anything command (also aliased to bump). The only required argument is a keyword indicating how you want to increment each version. It can be either major, minor, or patch.

bump major # 1.2.3 -> 2.0.0
bump minor # 1.2.3 -> 1.3.0
bump patch # 1.2.3 -> 1.2.4
bump prerelease # 1.2.3-beta.1 -> 1.2.3-beta.2
bump 2.3.4
bump v2.3.4 # same as `bump 2.3.4`

With this syntax, Bump Anything will do its best to find the relevant files to bump. However, Bump Anything can also accept an optional list of one or more file paths whose versions to bump. Only the first occurrence of the version field in each file will be updated.

bump minor subdir/myfile1.json subdir/myfile2.toml

Git Integration

The bump command will automatically create a tagged commit if the current directory is a Git repository. Only the files that have been modified by bump will be staged.

Custom commit message

You can explicitly specify the commit message with --commit-message or -m. The default is Prepare v<new_version> release. You can use the {new_version} placeholder to represent the new version (without any prefix).

bump --commit-message 'Release v{new_version}' major
bump -m 'Release v{new_version}' major

Custom tag name

You can explicitly specify the tag name with --tag-name or -t (default: v<new_version>). You can use the {new_version} placeholder to represent the new version (without any prefix).

bump --tag-name 'release/{new_version}' patch
bump -t 'release/{new_version}' patch

Disabling committing and/or tagging

If you do not wish for bump to automatically create a commit and tag, you can pass the --no-commit flag (alias: -n):

bump --no-commit minor
bump -n minor

Disabling tagging only

If you wish to disable the automatic tag creation but still create a commit, you can pass the --no-tag flag:

bump --no-tag patch

Auto-Detected Files

  • package.json (Node)
  • package-lock.json (Node)
  • setup.py (Python)
  • setup.cfg (Python)
  • pyproject.toml (Python)
  • style.css (WordPress Theme)
  • Cargo.toml (Rust package manifest)
  • <cwd name>.php (WordPress Plugin)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bump_anything-2.3.0.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bump_anything-2.3.0-py3-none-any.whl (6.4 kB view details)

Uploaded Python 3

File details

Details for the file bump_anything-2.3.0.tar.gz.

File metadata

  • Download URL: bump_anything-2.3.0.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.8.14

File hashes

Hashes for bump_anything-2.3.0.tar.gz
Algorithm Hash digest
SHA256 840d6eaebffbea01f037c52dc719837fb7758f4371a9f6e06deb21e8e8b8dd7b
MD5 71d5e3c92e7cba0f19868cb8585c3924
BLAKE2b-256 f269fff8fc751226f560f5bed5b7824d376099039498f462a4ce1778daf8cc33

See more details on using hashes here.

File details

Details for the file bump_anything-2.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for bump_anything-2.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 576e83e6805cb3aaffa4d9196bf6f31d37416080138da455211828463f9b1949
MD5 81a87fcb271cb94141611c371d23f69f
BLAKE2b-256 395532673018be31cdd9b5c6797f217e71422a738073619a70d3ba861d3d5e8d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page