Skip to main content

Bump your semantic version of any software using regex

Project description

bump semver anywhere

PyPI version

This is a library intented to replace all semversion bumpers and finally be agnostic of the language / use case for your semantic versioning. This is achieved by providing the regex pattern to the place and filename of the string that contains the semantic version.

usage

  • install pip install bump_semver_anywhere
  • create a bump_semver_anywhere.toml in the root of your project (see config example) or run bump_semver_anywhere init
  • run bump_semver_anywhere bump -p patch
Hello there. Today I want to show you a library I have been working on. I was inspired by necessity of changing all the versions in every file: `pyproject.toml`, `__init__.py`, `docker-compose.yaml`, `package.json`, etc. I searched for packages that do this but either they are specific to the language (Python or Javascript) or I did not like the customization for it. At the end I decided to create `bump_semver_anywhere`. This is inspired in [bump2version](https://github.com/c4urself/bump2version/) but with a much simpler approach. It uses TOML for configuration.

> This is a library intended to replace all semantic version bumpers and finally be agnostic of the language. This is achieved by providing the regex pattern to the place and filename of the string that contains the version.

configuration example:
```toml
# bump_semver_anywhere.toml

[general]
current_version = "0.1.2"

[vcs]
commit = true
commit_msg = "release({part}): bump {current_version} -> {new_version}"

[files]

[files.python-module]
filename = "bump_semver_anywhere/__init__.py"
pattern = '__version__ ?= ?"(.*?)"'

[files.python-pyproject]
filename = "pyproject.toml"
pattern = 'version ?= ?"(.*?)"'

It can be run as CLI bump_semver_anywhere bump -p patch or triggered via a Github action by commenting /release patch

❯ python -m bump_semver_anywhere bump -p patch
[-] Loading config from bump_semver_anywhere.toml and bumping patch
[=] config loaded
[ ] files to update
 • bump_semver_anywhere/__init__.py: 0.1.1
 • pyproject.toml: 0.1.1
 • bump_semver_anywhere.toml: 0.1.1
[ ] VCS enabled with git
[-] bumping patch version
 • bump_semver_anywhere/__init__.py -> 0.1.2
 • pyproject.toml -> 0.1.2
 • bump_semver_anywhere.toml -> 0.1.2
[*] saving files to disk
[*] staging
[*] commiting: release(patch): bump 0.1.1 -> 0.1.2
black....................................................................Passed
isort....................................................................Passed
flake8...................................................................Passed
[main 5092515] release(patch): bump 0.1.1 -> 0.1.2
 3 files changed, 3 insertions(+), 3 deletions(-)
[+] bye bye

PS: If you have any suggestions for changing the name to a much simpler one I will be grateful. PS2: I accept PR and any feedback.

cli

❯ bump_semver_anywhere --help
Usage: python -m bump_semver_anywhere [OPTIONS] COMMAND [ARGS]...

Options:
  --help  Show this message and exit.

Commands:
  bump  Bump your semantic version of any software using regex
  init  Initialize the config
❯ bump_semver_anywhere bump --help
Usage: python -m bump_semver_anywhere bump [OPTIONS]

  Bump your semantic version of any software using regex

Options:
  -c, --config FILE               the config file  [default:
                                  bump_semver_anywhere.toml]
  -p, --part [major|minor|patch|prerelease]
                                  the version part to bump  [required]
  -n, --dry-run                   do not modify files
  --help                          Show this message and exit.
❯ bump_semver_anywhere init --help
Usage: python -m bump_semver_anywhere init [OPTIONS]

  Initialize the config

Options:
  -o, --output PATH  the output config file path  [default:
                     bump_semver_anywhere.toml]
  --help             Show this message and exit.

config example

The following example will bump the version for docker and a python or javascript package.

# bump_semver_anywhere.toml

[general]
current_version = "0.1.0"

[vcs]
commit = true
commit_msg = "release({part}): bump {current_version} -> {new_version}"

[files]

[files.docker]
filename = "docker-compose.yaml"
pattern = 'image:.*?:(.*?)"'

[files.python-module]
filename = "__init__.py"
pattern = '__version__ ?= ?"(.*?)"'

[files.python-pyproject]
filename = "pyproject.toml"
pattern = 'version ?= ?"(.*?)"'

[files.javascript]
filename = "package.json"
pattern = '"version": ?"(.*?)"'

github action

See .github/workflows/bump_semver_anywhere.yaml to integrate the action to your repo.

The current behaviour is to comment /release <part> (e.g. /release patch) in a pull request. Per default it pushes the bump commit to the branch the PR points to. Therefore it should be commented after accepting the PR

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_semver_anywhere-0.3.0.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

bump_semver_anywhere-0.3.0-py3-none-any.whl (7.9 kB view details)

Uploaded Python 3

File details

Details for the file bump_semver_anywhere-0.3.0.tar.gz.

File metadata

  • Download URL: bump_semver_anywhere-0.3.0.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.11 CPython/3.8.12 Linux/5.11.0-1020-azure

File hashes

Hashes for bump_semver_anywhere-0.3.0.tar.gz
Algorithm Hash digest
SHA256 99e55cc08219aaca2c4aa44a209c5d2c0728f82dbfdd4ae51e99f03b483f80bd
MD5 64922cc599eafa1648331db400f36606
BLAKE2b-256 4e5ad6f2c555d4c50e8fee2018ce6d0cd747e5e31f92dc762d8e892f021a1c57

See more details on using hashes here.

File details

Details for the file bump_semver_anywhere-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for bump_semver_anywhere-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cf2b12ec83d516afea6c8db0c403b112e8644806d40c848ca5045242667893fd
MD5 a87fcee993966d7b85f4d994587e9f2c
BLAKE2b-256 d5cfbd7eaff25444b4f035fcf5e01b1bc5bfcda958cd7989ac2a65727a7d7599

See more details on using hashes here.

Supported by

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