diff --git a/reference/api/SUMMARY/index.html b/reference/api/SUMMARY/index.html index 9046809e..02094c73 100644 --- a/reference/api/SUMMARY/index.html +++ b/reference/api/SUMMARY/index.html @@ -1976,7 +1976,7 @@

SUMMARY

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/aliases/index.html b/reference/api/bumpversion/aliases/index.html index ae12a4f3..6e0f0cab 100644 --- a/reference/api/bumpversion/aliases/index.html +++ b/reference/api/bumpversion/aliases/index.html @@ -2175,7 +2175,7 @@

Functions - June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/autocast/index.html b/reference/api/bumpversion/autocast/index.html index db44e3bc..ace7be20 100644 --- a/reference/api/bumpversion/autocast/index.html +++ b/reference/api/bumpversion/autocast/index.html @@ -2277,7 +2277,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/bump/index.html b/reference/api/bumpversion/bump/index.html index f7f39f2f..28174b6a 100644 --- a/reference/api/bumpversion/bump/index.html +++ b/reference/api/bumpversion/bump/index.html @@ -2370,7 +2370,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/cli/index.html b/reference/api/bumpversion/cli/index.html index 980222ce..cd337459 100644 --- a/reference/api/bumpversion/cli/index.html +++ b/reference/api/bumpversion/cli/index.html @@ -2322,7 +2322,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/config/create/index.html b/reference/api/bumpversion/config/create/index.html index d6ffb651..fafd07e6 100644 --- a/reference/api/bumpversion/config/create/index.html +++ b/reference/api/bumpversion/config/create/index.html @@ -2179,7 +2179,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/config/files/index.html b/reference/api/bumpversion/config/files/index.html index 01a3db1a..96f5cc58 100644 --- a/reference/api/bumpversion/config/files/index.html +++ b/reference/api/bumpversion/config/files/index.html @@ -2381,7 +2381,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/config/files_legacy/index.html b/reference/api/bumpversion/config/files_legacy/index.html index a086b3eb..47ded932 100644 --- a/reference/api/bumpversion/config/files_legacy/index.html +++ b/reference/api/bumpversion/config/files_legacy/index.html @@ -2223,7 +2223,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/config/index.html b/reference/api/bumpversion/config/index.html index 6601709d..b2dddb8e 100644 --- a/reference/api/bumpversion/config/index.html +++ b/reference/api/bumpversion/config/index.html @@ -2174,7 +2174,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/config/models/index.html b/reference/api/bumpversion/config/models/index.html index bfbbf324..dd66e5db 100644 --- a/reference/api/bumpversion/config/models/index.html +++ b/reference/api/bumpversion/config/models/index.html @@ -2364,7 +2364,7 @@

Functions - June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/config/utils/index.html b/reference/api/bumpversion/config/utils/index.html index 5c18eb59..dcb664c7 100644 --- a/reference/api/bumpversion/config/utils/index.html +++ b/reference/api/bumpversion/config/utils/index.html @@ -2207,7 +2207,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/context/index.html b/reference/api/bumpversion/context/index.html index 80c390d3..d5f3bd65 100644 --- a/reference/api/bumpversion/context/index.html +++ b/reference/api/bumpversion/context/index.html @@ -2232,7 +2232,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/exceptions/index.html b/reference/api/bumpversion/exceptions/index.html index 75494c49..fcac2fc1 100644 --- a/reference/api/bumpversion/exceptions/index.html +++ b/reference/api/bumpversion/exceptions/index.html @@ -2406,7 +2406,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/files/index.html b/reference/api/bumpversion/files/index.html index 4cf78fdf..89afa3ff 100644 --- a/reference/api/bumpversion/files/index.html +++ b/reference/api/bumpversion/files/index.html @@ -2677,7 +2677,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/indented_logger/index.html b/reference/api/bumpversion/indented_logger/index.html index 03355dd1..f7cca72f 100644 --- a/reference/api/bumpversion/indented_logger/index.html +++ b/reference/api/bumpversion/indented_logger/index.html @@ -2359,7 +2359,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/index.html b/reference/api/bumpversion/index.html index cf337c54..e5cdf1de 100644 --- a/reference/api/bumpversion/index.html +++ b/reference/api/bumpversion/index.html @@ -1985,7 +1985,7 @@

Index

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/scm/index.html b/reference/api/bumpversion/scm/index.html index 99baf1dd..9cdfb273 100644 --- a/reference/api/bumpversion/scm/index.html +++ b/reference/api/bumpversion/scm/index.html @@ -2891,7 +2891,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/show/index.html b/reference/api/bumpversion/show/index.html index 41819bb5..83fe71b7 100644 --- a/reference/api/bumpversion/show/index.html +++ b/reference/api/bumpversion/show/index.html @@ -2322,7 +2322,7 @@

noqa: DAR401 - June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/ui/index.html b/reference/api/bumpversion/ui/index.html index 727e9db7..6a771f67 100644 --- a/reference/api/bumpversion/ui/index.html +++ b/reference/api/bumpversion/ui/index.html @@ -2226,7 +2226,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/utils/index.html b/reference/api/bumpversion/utils/index.html index 3007f833..abde5261 100644 --- a/reference/api/bumpversion/utils/index.html +++ b/reference/api/bumpversion/utils/index.html @@ -2413,7 +2413,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/version_part/index.html b/reference/api/bumpversion/version_part/index.html index 0897e880..de935dc7 100644 --- a/reference/api/bumpversion/version_part/index.html +++ b/reference/api/bumpversion/version_part/index.html @@ -2296,7 +2296,7 @@

Functions - June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/versioning/conventions/index.html b/reference/api/bumpversion/versioning/conventions/index.html index 16f4a857..5ee52cf4 100644 --- a/reference/api/bumpversion/versioning/conventions/index.html +++ b/reference/api/bumpversion/versioning/conventions/index.html @@ -2144,7 +2144,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/versioning/functions/index.html b/reference/api/bumpversion/versioning/functions/index.html index d6362013..cb85402a 100644 --- a/reference/api/bumpversion/versioning/functions/index.html +++ b/reference/api/bumpversion/versioning/functions/index.html @@ -2445,7 +2445,7 @@

Functions - June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/versioning/index.html b/reference/api/bumpversion/versioning/index.html index 7a4e0970..e4c21491 100644 --- a/reference/api/bumpversion/versioning/index.html +++ b/reference/api/bumpversion/versioning/index.html @@ -2019,7 +2019,7 @@

Index

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/versioning/models/index.html b/reference/api/bumpversion/versioning/models/index.html index 6dbe3759..129fac9a 100644 --- a/reference/api/bumpversion/versioning/models/index.html +++ b/reference/api/bumpversion/versioning/models/index.html @@ -2734,7 +2734,7 @@

Functions - June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/versioning/serialization/index.html b/reference/api/bumpversion/versioning/serialization/index.html index 0c51832d..a222a1b7 100644 --- a/reference/api/bumpversion/versioning/serialization/index.html +++ b/reference/api/bumpversion/versioning/serialization/index.html @@ -2353,7 +2353,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/visualize/index.html b/reference/api/bumpversion/visualize/index.html index a91ada95..bca7447f 100644 --- a/reference/api/bumpversion/visualize/index.html +++ b/reference/api/bumpversion/visualize/index.html @@ -2507,7 +2507,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/reference/api/bumpversion/yaml_dump/index.html b/reference/api/bumpversion/yaml_dump/index.html index d028678a..764c0ce8 100644 --- a/reference/api/bumpversion/yaml_dump/index.html +++ b/reference/api/bumpversion/yaml_dump/index.html @@ -2439,7 +2439,7 @@

- June 26, 2024 + July 1, 2024 diff --git a/search/search_index.json b/search/search_index.json index 5e59e2f2..4eb26e34 100644 --- a/search/search_index.json +++ b/search/search_index.json @@ -1 +1 @@ -{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"Bump My Version","text":""},{"location":"#overview","title":"Overview","text":"

Bump My Version\u2019s purpose is to:

  • Work as a part of an automated build system
  • Manage project versioning through the project\u2019s development life cycle - Incrementing version numbers - serializing version numbers - parsing version numbers - supporting SemVer, CalVer, and other versioning schemes
  • Modify project files as part of the project\u2019s development life cycle
  • Work with the project\u2019s source control system - Committing changes - Tagging releases - Reading version numbers from tags
"},{"location":"#installation","title":"Installation","text":"

You can download and install the latest version of this software from the Python package index (PyPI) as follows:

pip install --upgrade bump-my-version\n
"},{"location":"#changelog","title":"Changelog","text":"

Please find the changelog here: CHANGELOG.md

"},{"location":"#semantic-versioning-example","title":"Semantic versioning example","text":""},{"location":"#create-a-default-configuration","title":"Create a default configuration","text":"

The default configuration uses a simplified version of semantic versioning.

Generating a default configuration
$ bump-my-version sample-config --no-prompt --destination .bumpversion.toml\n$ cat .bumpversion.toml\n[tool.bumpversion]\ncurrent_version = \"0.1.0\"\nparse = \"(?P<major>\\\\d+)\\\\.(?P<minor>\\\\d+)\\\\.(?P<patch>\\\\d+)\"\nserialize = [\"{major}.{minor}.{patch}\"]\nsearch = \"{current_version}\"\nreplace = \"{new_version}\"\nregex = false\nignore_missing_version = false\ntag = false\nsign_tags = false\ntag_name = \"v{new_version}\"\ntag_message = \"Bump version: {current_version} \u2192 {new_version}\"\nallow_dirty = false\ncommit = false\nmessage = \"Bump version: {current_version} \u2192 {new_version}\"\ncommit_args = \"\"\n
"},{"location":"#visualize-the-versioning-path","title":"Visualize the versioning path","text":"

You can see the potential versioning paths with the show-bump subcommand.

Showing the potential versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0\n               \u251c\u2500 minor \u2500 0.2.0\n               \u2570\u2500 patch \u2500 0.1.1\n$ bump-my-version show-bump 1.2.3\n1.2.3 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0\n               \u251c\u2500 minor \u2500 1.3.0\n               \u2570\u2500 patch \u2500 1.2.4\n

The default configuration only allows bumping the major, minor, or patch version. What if you wanted to support pre-release versions?

"},{"location":"#add-support-for-pre-release-versions","title":"Add support for pre-release versions","text":"

Alter the parse configuration to support pre-release versions. This parse option uses an extended (or verbose) regular expression to extract the version parts from the current version.

New parse configuration
parse = \"\"\"(?x)\n    (?P<major>0|[1-9]\\\\d*)\\\\.\n    (?P<minor>0|[1-9]\\\\d*)\\\\.\n    (?P<patch>0|[1-9]\\\\d*)\n    (?:\n        -                             # dash separator for pre-release section\n        (?P<pre_l>[a-zA-Z-]+)         # pre-release label\n        (?P<pre_n>0|[1-9]\\\\d*)        # pre-release version number\n    )?                                # pre-release section is optional\n\"\"\"\n

Alter the serialize configuration to support pre-release versions.

New serialize configuration
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{pre_n}\",\n    \"{major}.{minor}.{patch}\",\n]\n

Add a new configuration section for the pre_l part.

New pre_l configuration
[tool.bumpversion.parts.pre_l]\nvalues = [\"dev\", \"rc\", \"final\"]\noptional_value = \"final\"\n
"},{"location":"#visualize-the-new-versioning-path","title":"Visualize the new versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u251c\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n               \u2570\u2500 pre_n \u2500 0.1.0-final1\n

The pre_l is not bump-able because it is already at the maximum value. The pre_n is bump-able because it is not at the maximum value.

If we run bump-my-version show-bump 1.0.0-dev0, we can see the new versioning path for a dev starting version.

Showing the new versioning path for a dev version
$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u251c\u2500 pre_l \u2500 1.0.0-rc0\n                    \u2570\u2500 pre_n \u2500 1.0.0-dev1\n

Finally, we can see the new versioning path for a rc starting version.

Showing the new versioning path for an rc version
$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u251c\u2500 pre_l \u2500 1.0.0\n                   \u2570\u2500 pre_n \u2500 1.0.0-rc1\n

The full development and release path is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
  • bump pre_n \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
  • bump pre_n \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase using bump-my-version bump pre_n.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidates increase using bump-my-version bump pre_n.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"#automate-the-pre-release-numbering","title":"Automate the pre-release numbering","text":"

The pre_n or pre-release number is a number that increases with each pre-release. You can automate this my changing the serialization configuration.

Serialize configuration with pre_n automation
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{distance_to_latest_tag}\",\n    \"{major}.{minor}.{patch}\",\n]\n

The distance_to_latest_tag is a special value that is replaced with the number of commits since the last tag. This is a good value to use for the pre_n because it will always increase with each commit.

"},{"location":"#visualize-the-pre_n-versioning-path","title":"Visualize the pre_n versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path with pre_n automation
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u2570\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u2570\u2500 pre_l \u2500 1.0.0-rc0\n$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u2570\u2500 pre_l \u2500 1.0.0\n

The pre_n path is now missing because it is automated.

The full development and release path now is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
    • each commit will increase \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
    • each commit will increase \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase automatically with each commit.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidate versions increase automatically with each commit.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"#development-contributing","title":"Development & Contributing","text":"

Thank you, contributors! You can find a full list here: https://github.com/callowayproject/bump-my-version/graphs/contributors

See also our CONTRIBUTING.md

Development of this happens on GitHub, patches including tests, and documentation are very welcome, as well as bug reports! Please open an issue if this tool does not support every aspect of bumping versions in your development workflow, as it is intended to be very versatile.

"},{"location":"#license","title":"License","text":"

Bump My Version is licensed under the MIT License - see the LICENSE file for details

"},{"location":"CHANGELOG/","title":"Changelog","text":""},{"location":"CHANGELOG/#changelog","title":"Changelog","text":""},{"location":"CHANGELOG/#0241-2024-06-26","title":"0.24.1 (2024-06-26)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes","title":"Fixes","text":"
  • Refactor error handling in SCM and add error handling test. 7ca6356

    This commit includes a new test in test_scm.py to verify the correct formatting and raising of subprocess errors in the SCM module. Additionally, the subprocess error handling has been refactored in the SCM module to include a new method, format_and_raise_error, for improved code readability and reusability.

  • [pre-commit.ci] pre-commit autoupdate. 60acc2d

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.9 \u2192 v0.4.10

"},{"location":"CHANGELOG/#other","title":"Other","text":""},{"location":"CHANGELOG/#0240-2024-06-25","title":"0.24.0 (2024-06-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new","title":"New","text":"
  • Add VersionNotFoundError test in test_bump.py. cb050a8

    The code in test_bump.py file has been modified to include a test for VersionNotFoundError exception. This ensures that the implementation properly handles cases where a specified version could not be found. - Add test for no commit on modification error. 7527029

    A test has been added to the bumpversion library to ensure that no commit and tag is made if there is an error modification. Specifically, the test checks the \u201cdo_bump\u201d function and asserts that \u201cmock_commit_and_tag\u201d and \u201cmock_update_config_file\u201d are not called under these conditions.

  • [pre-commit.ci] pre-commit autoupdate. 0e3a154

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.8 \u2192 v0.4.9

"},{"location":"CHANGELOG/#other_1","title":"Other","text":""},{"location":"CHANGELOG/#updates","title":"Updates","text":"
  • Improve error message for SCM command failures. 8f72f86

    The error message for failures in the SCM command execution has been enhanced. Now it displays not only the command\u2019s return code but also the standard output and error, improving the debugging process.

"},{"location":"CHANGELOG/#0230-2024-06-14","title":"0.23.0 (2024-06-14)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_1","title":"Fixes","text":"
  • Refactor valid_bumps and invalid_bumps to include_bumps and exclude_bumps. 2df57cc

    The configuration parameters valid_bumps and invalid_bumps were renamed to include_bumps and exclude_bumps respectively. This new naming better denotes their function, and the changes were consistently applied across all related files and tests. Numerous fixture outputs were also updated to reflect these changes. - Fixed spelling in CODE_OF_CONDUCT.md. 254ea44

"},{"location":"CHANGELOG/#new_1","title":"New","text":"
  • Add file filtering based on valid and invalid bumps. f9f7f96

    This commit introduces the ability to filter files based on whether the specified bump type is valid or not. It adds valid_bumps and invalid_bumps lists in the file configurations and adjusts the bumping process to consider these configurations. Tests are updated to reflect these new handling of valid and invalid bumps. - Add new files to .gitignore. 34e4dc1

    Several new file types have been added to .gitignore for ignoring during commits. These include \u2018.python-version\u2019, \u2018requirements-dev.lock\u2019, and \u2018requirements.lock\u2019 files. - Add valid_bumps and invalid_bumps to file configuration. 9458851

    Updated the configuration file model to support valid_bumps and invalid_bumps. This feature provides control over which version section updates can trigger file changes. Adjusted various test fixtures and cleaned up tests to match these changes. Also, some updates were made to the documentation accordingly.

  • [pre-commit.ci] pre-commit autoupdate. e44f6af

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.4 \u2192 v0.4.8

"},{"location":"CHANGELOG/#other_2","title":"Other","text":""},{"location":"CHANGELOG/#updates_1","title":"Updates","text":"
  • Update documentation for clarification. 2224808

    The changes made update the wording in the documentation to clarify the roles of include_bumps and exclude_bumps in the bump-my-version configuration. Additionally, unnecessary repetition was removed and overlapping examples were also corrected. - Update docs/reference/configuration.md. 7c801c0

    co-authored-by: wkoot 3715211+wkoot@users.noreply.github.com

"},{"location":"CHANGELOG/#0220-2024-06-11","title":"0.22.0 (2024-06-11)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_2","title":"New","text":"
  • Add extensive documentation for the \u2018show\u2019 subcommand. 91409d8

    This commit adds extensive documentation for the show subcommand in the program\u2019s reference. It also includes smaller updates and corrections to other parts of the documentation. An in-depth example usage of show is added both to the dedicated show.md file and in the function\u2019s docstring.

  • Renamed version workflow to release. 68f9eee
"},{"location":"CHANGELOG/#updates_2","title":"Updates","text":""},{"location":"CHANGELOG/#0211-2024-05-16","title":"0.21.1 (2024-05-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#other_3","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 1b57c2b

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. e813eda

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.3 \u2192 v0.4.4

  • [pre-commit.ci] pre-commit autoupdate. 05a0dd6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.2 \u2192 v0.4.3

"},{"location":"CHANGELOG/#updates_3","title":"Updates","text":"
  • Update README.md. cad7096
"},{"location":"CHANGELOG/#0210-2024-05-01","title":"0.21.0 (2024-05-01)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_2","title":"Fixes","text":"
  • Fixed a bug in the glob tests. 1041fe9

    Was not properly looking in the correct relative directories. - Fixed test for Windows glob paths. ea45c4c

  • Fixed exclusion logic with wcmatch. 1c391be
  • Refactored glob matching to use the wcmatch library. bbf4ae0
"},{"location":"CHANGELOG/#new_3","title":"New","text":"
  • Adds glob_exclude file specification parameter. 420e3bd

    User can prune the files resolved via the glob parameter.

    Fixes #184

  • [pre-commit.ci] pre-commit autoupdate. ce02aa7

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.1 \u2192 v0.4.2

"},{"location":"CHANGELOG/#other_4","title":"Other","text":""},{"location":"CHANGELOG/#0203-2024-04-26","title":"0.20.3 (2024-04-26)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_3","title":"Fixes","text":"
  • Fixed test logging setup. 3777f27
  • Fixed the indentation problem. ec3cd99

    • Added a dedent when a file does not match the change pattern.
    • Fixes #181
  • [pre-commit.ci] pre-commit autoupdate. e916f87

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.7 \u2192 v0.4.1

"},{"location":"CHANGELOG/#other_5","title":"Other","text":""},{"location":"CHANGELOG/#0202-2024-04-23","title":"0.20.2 (2024-04-23)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_4","title":"Fixes","text":"
  • Fixed the rendering of numeric version components. c522c75

    • Numeric version components now will attempt to render its value as an integer and fall back to the parsed value.
    • Fixed code block in the README. b4ff9f3
"},{"location":"CHANGELOG/#other_6","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 9b09da8

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.5 \u2192 v0.3.7

"},{"location":"CHANGELOG/#0201-2024-04-13","title":"0.20.1 (2024-04-13)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_5","title":"Fixes","text":"
  • Fix typos discovered by codespell. d5c33a3
  • Fixed relative references. 2aa1011
  • Refactored the docs. b63a9e7
"},{"location":"CHANGELOG/#other_7","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. f438bc6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.4 \u2192 v0.3.5

  • Pre-commit: Discover typos with codespell. 2509fc7

    Related to: * #168 - [pre-commit.ci] pre-commit autoupdate. be5cb79

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.3 \u2192 v0.3.4

"},{"location":"CHANGELOG/#0200-2024-03-27","title":"0.20.0 (2024-03-27)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_6","title":"Fixes","text":"
  • Refactored context into its own module. 5a3e05d
"},{"location":"CHANGELOG/#new_4","title":"New","text":"
  • Added always_increment attribute for parts. 53ee848

    This is a requirement for CalVer to ensure they always increment with each bump, but it will work for any type. - Added CalVer function and formatting. 7a0e639

    • Version parts now have a calver_format attribute for CalVer parts.
  • Updated the documentation. 607609d
"},{"location":"CHANGELOG/#updates_4","title":"Updates","text":""},{"location":"CHANGELOG/#0193-2024-03-23","title":"0.19.3 (2024-03-23)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_7","title":"Fixes","text":"
  • Fixed packaging of dev releases. 84254e0
  • Fixed platform-dependent encoding. f8b4d65

    • Added encoding=\"utf-8\" to all writes.
    • Fixed version.yaml workflow. 10b007c
"},{"location":"CHANGELOG/#other_8","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. e92000a

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.2 \u2192 v0.3.3

  • Bump the github-actions group with 3 updates. a422c58

    Bumps the github-actions group with 3 updates: actions/checkout, actions/setup-python and codecov/codecov-action.

    Updates actions/checkout from 3 to 4 - Release notes - Changelog - Commits

    Updates actions/setup-python from 4 to 5 - Release notes - Commits

    Updates codecov/codecov-action from 3 to 4 - Release notes - Changelog - Commits

    updated-dependencies: - dependency-name: actions/checkout dependency-type: direct:production update-type: version-update:semver-major dependency-group: github-actions

    signed-off-by: dependabot[bot] support@github.com

  • Keep GitHub Actions up to date with GitHub\u2019s Dependabot. 2e55fa1

    • https://docs.github.com/en/code-security/dependabot/working-with-dependabot/keeping-your-actions-up-to-date-with-dependabot
    • https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#package-ecosystem
"},{"location":"CHANGELOG/#0192-2024-03-16","title":"0.19.2 (2024-03-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_8","title":"Fixes","text":"
  • Fixed bad options not returning an error code. e88f0a9

    Fixes #153 - Fix issue on version.yaml. 7d14065

"},{"location":"CHANGELOG/#0191-2024-03-16","title":"0.19.1 (2024-03-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_9","title":"Fixes","text":"
  • Fix commas in legacy multiline options. 62dfe8e
"},{"location":"CHANGELOG/#new_5","title":"New","text":"
  • Added manual version bumping in the GitHub action. c9d67b5
"},{"location":"CHANGELOG/#other_9","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. be1a568

    updates: - github.com/astral-sh/ruff-pre-commit: v0.2.2 \u2192 v0.3.2

"},{"location":"CHANGELOG/#0190-2024-03-12","title":"0.19.0 (2024-03-12)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_10","title":"Fixes","text":"
  • Fixing version hint generation. ae1732b
"},{"location":"CHANGELOG/#updates_5","title":"Updates","text":"
  • Removes ability to call the CLI without subcommand. e56c944

    BREAKING CHANGE: You must use bump-my-version bump

"},{"location":"CHANGELOG/#0183-2024-02-25","title":"0.18.3 (2024-02-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_11","title":"Fixes","text":"
  • Fixed \u2013ignore-missing-version and \u2013ignore-missing-files options. 7635873

    The CLI options were defaulting to False when missing. This overrode the configuration.

    Fixes #140

"},{"location":"CHANGELOG/#0182-2024-02-25","title":"0.18.2 (2024-02-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_12","title":"Fixes","text":"
  • Fixed docs and cli help. 8ac1087
"},{"location":"CHANGELOG/#0181-2024-02-24","title":"0.18.1 (2024-02-24)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_13","title":"Fixes","text":"
  • Fixed type annotation in config. 2988ede
  • Fixed naming issue for docs. 2850aa7

    • renamed changelog.md and contributing.md
  • Added how-to doc. 68643a9

    • \u201cHow to update a date in a file\u201d
  • [pre-commit.ci] pre-commit autoupdate. c495d3d

    updates: - github.com/astral-sh/ruff-pre-commit: v0.2.1 \u2192 v0.2.2

"},{"location":"CHANGELOG/#new_6","title":"New","text":""},{"location":"CHANGELOG/#other_10","title":"Other","text":""},{"location":"CHANGELOG/#updates_6","title":"Updates","text":"
  • Updated docs and styles. f4f75fa
"},{"location":"CHANGELOG/#0180-2024-02-18","title":"0.18.0 (2024-02-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_7","title":"New","text":"
  • Added --ignore-missing-files option to bump. fcfaac7
  • Added configuration option ignore_missing_files. b473a19
"},{"location":"CHANGELOG/#other_11","title":"Other","text":"
  • Convert docs to MkDocs. f805c33
  • Converted documentation to use MkDocs. 1b8c6b3
"},{"location":"CHANGELOG/#0174-2024-02-10","title":"0.17.4 (2024-02-10)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_14","title":"Fixes","text":"
  • Fixed linting errors. 9515afc
  • Fix encoding when reading text. c03476a

    Fixes #68

"},{"location":"CHANGELOG/#other_12","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 491b4aa

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.14 \u2192 v0.2.0

"},{"location":"CHANGELOG/#0173-2024-01-29","title":"0.17.3 (2024-01-29)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_15","title":"Fixes","text":"
  • Refactored VersionComponentConfig to VersionComponentSpec. b538308

    More consistent with VersionSpec

"},{"location":"CHANGELOG/#new_8","title":"New","text":"
  • Added mental model documentation. 5cbd250
"},{"location":"CHANGELOG/#other_13","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. a2a3fe6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.11 \u2192 v0.1.14

"},{"location":"CHANGELOG/#updates_7","title":"Updates","text":"
  • Updated more documentation. 779c84c
"},{"location":"CHANGELOG/#0172-2024-01-27","title":"0.17.2 (2024-01-27)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_16","title":"Fixes","text":"
  • Fixed some tests. 593a4ee
  • Refactored serialization. 0ac2cd8

    • Moved serialization from VersionConfig to version.serialization
    • Fixed extra capture group in PEP440 parser. 384fd99
  • Refactored verioning models. 88e7f71

    • created a \u201cconventions\u201d module for future release
    • added an optional depends_on version component configuration
    • The depends_on is required for PEP440 versioning
    • Fixed None as value for a function. f8c4d05
    • Turns None into an empty string
    • Fixed bad imports. 5c86d51
  • Refactored versioning models and tests. 7d05414
  • Refactored version parsing. 5ed546b
  • Refactored versioning functions and version parts. be87721
  • Fixed timezone of a test. 0e01253
"},{"location":"CHANGELOG/#0171-2024-01-25","title":"0.17.1 (2024-01-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_17","title":"Fixes","text":"
  • Fixed bad error checking with SCM. 10e5d7d
  • Fix missing current version within the context. a5dca4c
"},{"location":"CHANGELOG/#0170-2024-01-22","title":"0.17.0 (2024-01-22)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_18","title":"Fixes","text":"
  • Fixed Py3.8 type annotation. c15b23b
  • Fixed some output in visualizing. 406f97a
  • Fixed bad type annotation. 8f4bedf
  • Fixed bad test imports. a74342b
  • Refactored the create subcommand. f529d28

    • Also organized the CLI tests
"},{"location":"CHANGELOG/#new_9","title":"New","text":"
  • Added show-bump subcommand. 0bbd814

    • Shows possible resulting versions of the bump command
    • Added sample-config feature. 3d0f67d
    • Initial implementation
"},{"location":"CHANGELOG/#updates_8","title":"Updates","text":"
  • Updated documentation. 4f90348
"},{"location":"CHANGELOG/#0162-2024-01-13","title":"0.16.2 (2024-01-13)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_19","title":"Fixes","text":"
  • Fixed a bad import. 46c9c48
  • Fixed extra whitespace added when updating pyproject.toml. 839f17f

    • Removed dotted-notation from requirements. There is an issue on how dotted-notation sets values in the TOMLkit data structure.
    • Added get_nested_value and set_nested_value as replacements for dotted-notation.
"},{"location":"CHANGELOG/#other_14","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. ee4d2f3

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.9 \u2192 v0.1.11

"},{"location":"CHANGELOG/#0161-2024-01-06","title":"0.16.1 (2024-01-06)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_20","title":"Fixes","text":"
  • Fixed empty string replacement bug. d9965ab

    Only a missing replacement value will trigger one of the fallback options.

    Fixes #117

"},{"location":"CHANGELOG/#0160-2024-01-05","title":"0.16.0 (2024-01-05)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_10","title":"New","text":"
  • Add support for legacy multiline search options (refs #98). 278eae5
"},{"location":"CHANGELOG/#other_15","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 2e9a400

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.7 \u2192 v0.1.9

"},{"location":"CHANGELOG/#0154-2023-12-29","title":"0.15.4 (2023-12-29)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_21","title":"Fixes","text":"
  • Fix not being able to tag without also committing. 753c990
  • Fixed testing automation. 19215f1

    • The new commit/tag decoupling requires the --no-tag flag
"},{"location":"CHANGELOG/#0153-2023-12-18","title":"0.15.3 (2023-12-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_22","title":"Fixes","text":"
  • Fix miscast of current_version. b8ea252

    • When using the legacy configuration format, a single-digit version is parsed as an int

    Fixes #99

"},{"location":"CHANGELOG/#0152-2023-12-18","title":"0.15.2 (2023-12-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_23","title":"Fixes","text":"
  • Fixed regression in config update. 2bbbd74

    Fixes #108

"},{"location":"CHANGELOG/#new_11","title":"New","text":"
  • Added a test case for line-start regexes. ef4823c
"},{"location":"CHANGELOG/#0151-2023-12-18","title":"0.15.1 (2023-12-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_24","title":"Fixes","text":"
  • Fixes workflow triggers. 690452e
  • Fixes mismatched artifact up/downloading versions. 3f61742
  • Fixed PR_NUMBER retrieval. 85a8b48
  • Fixes committing and download-artifact. 12ba54f
  • Refactored workflows. d2f30a8
"},{"location":"CHANGELOG/#other_16","title":"Other","text":"
  • Testing PR acquisition. 67ab83d
  • Put in temporary debugging steps. 6ac064e
"},{"location":"CHANGELOG/#updates_9","title":"Updates","text":"
  • Changed the triggers to cause runs. 23e6c18
"},{"location":"CHANGELOG/#0150-2023-12-16","title":"0.15.0 (2023-12-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_25","title":"Fixes","text":"
  • Fixed requirements for github action. d96e07a
"},{"location":"CHANGELOG/#updates_10","title":"Updates","text":"
  • Changed default regex CLI value to None. 93191f3

    Fixes #64

    The default value of False was overriding other values.

"},{"location":"CHANGELOG/#0140-2023-12-15","title":"0.14.0 (2023-12-15)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_26","title":"Fixes","text":"
  • Fixed issue when adding files. 84556f8
  • Fixed missing requirement in GH action. 42bab83
  • Fixed regression regarding multiple changes in one file. e7a7629

    Changed the method of marking changes from a dict keyed by the file name to a list of FileChanges.

    FileChanges encapsulate a single change to a file. - Refactored logging to provide indented output. 4e68214

  • Refactored FileConfig to FileChange. 249a999

    This better describes what the class does: describe a file change.

    Also moved get_search_pattern to the class, since it is specific to each instance - Refactored config file management. a4c90b2

    Moved the INI format stuff into files_legacy.py - Fixes generate-requirements.sh to upgrade. 121ef69

"},{"location":"CHANGELOG/#new_12","title":"New","text":"
  • Added caching to the resolved filemap. c96e0bd
  • Added custom GitHub action. 4ce17a9
  • Added indented logger to improve console output. d1d19e3
"},{"location":"CHANGELOG/#updates_11","title":"Updates","text":"
  • Changed the management of file changes. 909396d

    File changes are hashable to weed out duplication. - Removed some commented lines. 89686b8

"},{"location":"CHANGELOG/#0130-2023-12-06","title":"0.13.0 (2023-12-06)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_27","title":"Fixes","text":"
  • Fixed import of extract_regex_flags. a980670
  • Fixed logging and regex regression in 3.11. cae12dc
  • Fixed issue with tag name. e218264

    Fixes #74

    current_version and tag_name now do not need to match exactly - Fixed logic in auto bump workflow. 909a53f

  • Fixes https://github.com/callowayproject/bump-my-version/issues/85. 97049e0

    HG returns the tags in the order they were created so we want the last one in the list - Fixed autoversioning. a308a35

"},{"location":"CHANGELOG/#new_13","title":"New","text":"
  • Added key_path to FileConfig. e160b40

    • Also made all attributes required except filename, glob, and key_path
"},{"location":"CHANGELOG/#other_17","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 8188a42

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. 4c81ad4

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.3 \u2192 v0.1.5

  • [pre-commit.ci] pre-commit autoupdate. 7109d70

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.3 \u2192 v0.1.6

"},{"location":"CHANGELOG/#updates_12","title":"Updates","text":"
  • Refactored configuration file updating. e407974

    TOML files are parsed, specific values are updated, and re-written to avoid updating the wrong data.

    It uses a two-way parser, so all formatting and comments are maintained.

    INI-type configuration files use the old way, since that format is deprecated.

"},{"location":"CHANGELOG/#0120-2023-11-04","title":"0.12.0 (2023-11-04)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_28","title":"Fixes","text":"
  • Fixed versioning. 8769671
  • Fix dev versioning with PR number. 463082b
  • Fix dev versioning. 1eed99b

    • added an echo of the PR_NUMBER
    • Fix versioning of development versions. e89599f
  • Fixes workflows. 5ebb0d7
  • Fixed bug #65 where glob\u2019d files weren\u2019t used. 357b9dc
"},{"location":"CHANGELOG/#new_14","title":"New","text":"
  • Add -h for help option. fda71b0

    Fixes #67

"},{"location":"CHANGELOG/#other_18","title":"Other","text":"
  • Drop Python3.7 as compatible version. 890edc8

    Since this is no longer tested, it\u2019s safer to start at 3.8. - [pre-commit.ci] auto fixes from pre-commit.com hooks. fbcef03

    for more information, see https://pre-commit.ci - Recommend calling \u2018bump-my-version\u2019 instead of \u2018bumpversion\u2019. 9fb1a1d

  • [pre-commit.ci] pre-commit autoupdate. e2579d6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.290 \u2192 v0.0.292

  • [pre-commit.ci] pre-commit autoupdate. e21fdd9

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.290 \u2192 v0.1.1

  • [pre-commit.ci] pre-commit autoupdate. 7e5d1bc

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.290 \u2192 v0.1.3

"},{"location":"CHANGELOG/#updates_13","title":"Updates","text":"
  • Changed the default regex search to non-regex. 0034716

    Fixes #59

    • Changed the flags to \u2013regex/\u2013no-regex
    • updated tests and docs
"},{"location":"CHANGELOG/#0110-2023-09-26","title":"0.11.0 (2023-09-26)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#other_19","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 4a3d046

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.285 \u2192 v0.0.290

"},{"location":"CHANGELOG/#updates_14","title":"Updates","text":"
  • Removed bumpversion as a duplicate of the bump-my-version script. a59ced8
  • Updated dependency from Pydantic 1 to 2. 577aa4c
"},{"location":"CHANGELOG/#0100-2023-09-05","title":"0.10.0 (2023-09-05)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#updates_15","title":"Updates","text":"
  • Refactored file resolution, inclusion, and exclusion. 646af54

    • Fixes #61
    • Config now includes resolved_filemap property
    • resolved filemap expands all globs
    • Config now includes files_to_modify property
    • files to modify resolves inclusions and exclutions
    • Improved Config.add_files property
"},{"location":"CHANGELOG/#093-2023-08-25","title":"0.9.3 (2023-08-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_29","title":"Fixes","text":"
  • Fixed file configuration overrides. c1ef3b2

    Fixes #55

    The file config was ignoring falsey values when constructing the dict.

    It now ignores None values. - Fixed documentation regarding regex config. cd71a1a

    • TOML requires the double backslash while INI doesn\u2019t
    • Fixed requirements for docs. 7856ee0
"},{"location":"CHANGELOG/#new_15","title":"New","text":"
  • Added documentation building workflow. 48980d7
"},{"location":"CHANGELOG/#other_20","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 7c38c40

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.284 \u2192 v0.0.285

  • [pre-commit.ci] pre-commit autoupdate. c30bd12

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.282 \u2192 v0.0.284

  • [pre-commit.ci] pre-commit autoupdate. 95c89fb

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.281 \u2192 v0.0.282

"},{"location":"CHANGELOG/#updates_16","title":"Updates","text":"
  • Removed mentions of Python 3.7. a91f690
"},{"location":"CHANGELOG/#092-2023-08-07","title":"0.9.2 (2023-08-07)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_30","title":"Fixes","text":"
  • Fixed modified context when committing. 130bbe0

    • Resets the context before committing and tagging
    • Fixes #14
"},{"location":"CHANGELOG/#091-2023-08-03","title":"0.9.1 (2023-08-03)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#other_21","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 4b457d0

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. adb7e4c

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.277 \u2192 v0.0.281

"},{"location":"CHANGELOG/#updates_17","title":"Updates","text":"
  • Remove pygments_style from docsrc/conf.py. 32798a9

    The theme defaults, subjectively, look better.

"},{"location":"CHANGELOG/#090-2023-08-03","title":"0.9.0 (2023-08-03)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_16","title":"New","text":"
  • Added documentation about regular expressions. 449b70a
  • Added configuration and command-line no_regex option. a295a32

    • Global and individual file configurations available for no_regex
    • Command-line flag --no-regex flag added for bump and replace sub-commands
    • Adds regular expression searching ability. 0210d74
    • Search strings are treated as regular expressions after the initial substitution
    • Added deprecation warning on .cfg files. a0481b7
"},{"location":"CHANGELOG/#080-2023-07-13","title":"0.8.0 (2023-07-13)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_17","title":"New","text":"
  • Added documentation for ignore missing version. e0731c3
  • Added --ignore-missing-version flag to bump and replace. a5bd008
  • Added ignore-missing-version configuration. 45c85be

    • Defaults to False
    • File configurations can also override this value
    • Added deprecation warnings. 733438b
    • --list option will go bye-bye in 1.0
    • calling bumpversion without a subcomand will leave in 1.0
"},{"location":"CHANGELOG/#071-2023-07-12","title":"0.7.1 (2023-07-12)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_31","title":"Fixes","text":"
  • Fix search and replace options for replace. 781e8d8

    • The --search and --replace options now completely override any other search and replace logic.

    Fixes #34

"},{"location":"CHANGELOG/#other_22","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 531738d

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.276 \u2192 v0.0.277

  • [pre-commit.ci] pre-commit autoupdate. 61e6747

    updates: - https://github.com/charliermarsh/ruff-pre-commit \u2192 https://github.com/astral-sh/ruff-pre-commit

"},{"location":"CHANGELOG/#070-2023-07-10","title":"0.7.0 (2023-07-10)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_32","title":"Fixes","text":"
  • Fixed test coverage. 3fe96f0
  • Fixed wrong pydantic version pinning. d4b125e
  • Fixed typing issue. bfe5306

    • Declared SourceCodeManager attributes as ClassVar[List[str]]
    • _TEST_USABLE_COMMAND, _COMMIT_COMMAND, and _ALL_TAGS_COMMAND affected
"},{"location":"CHANGELOG/#new_18","title":"New","text":"
  • Added tests for CLI replace command. a53cddc
  • Added and re-organized documentation. c62d65e
  • Added replace subcommand. 8722a0f

    • Works just like bump but
      • doesn\u2019t do any version incrementing
      • Will not change the configuration file
      • Will not commit or tag
    • Can use bumpversion show new_version --increment <versionpart> to see what the new version would be
    • Adds short_branch_name to version rendering context. 7f7e50c
    • short_branch_name is the branch name, lower case, containing only a-z and 0-9, and truncated to 20 characters.

    Fixes #28

"},{"location":"CHANGELOG/#other_23","title":"Other","text":"
  • Check config before tagging. 3a6e3ee
  • Format version parts. ee43bdb
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 5e6f566

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. f1acd35

    updates: - github.com/charliermarsh/ruff-pre-commit: v0.0.272 \u2192 v0.0.275

"},{"location":"CHANGELOG/#060-2023-06-23","title":"0.6.0 (2023-06-23)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_33","title":"Fixes","text":"
  • Fixed --help and bump invocations. 9d965e5

    • --help works for individual sub-commands, but not for the command
    • bump now works and fixed tests
    • Fixed issue regarding TOML types. 8960d24
    • tomlkit.parse() returns a TOMLDocument.
    • unwrap() converts it into a dict
"},{"location":"CHANGELOG/#new_19","title":"New","text":"
  • Adds branch_name to SCM information. 173be1a
  • Added documentation for the show command. d537274
  • Adds --increment option to show subcommand. b01fffc

    • when specified it increments the current version and adds new_version to the available output.
    • Added show subcommand. 9bce887
    • supersedes the --list option
    • provides much more capability
    • Can output in YAML, JSON, and default
    • Can specify one or more items to display
    • Can use dotted-notation to pull items from nested data structures.
"},{"location":"CHANGELOG/#updates_18","title":"Updates","text":"
  • Changes bump-my-version into subcommands. 31ffbcf

    • Is backwards-compatible with previous versions
    • bump-my-version forwards command to bump-my-version bump subcommand
    • Only problem is that Click will not show help automatically, must provide --help
"},{"location":"CHANGELOG/#051-2023-06-14","title":"0.5.1 (2023-06-14)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_34","title":"Fixes","text":"
  • Fixes reporting the wrong version missing in a file. efb04e9

    • Fixes issue #20
    • Renders the correct current_version for each file being modified.
"},{"location":"CHANGELOG/#other_24","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 5476cdf

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. 6e500c2

    updates: - github.com/charliermarsh/ruff-pre-commit: v0.0.270 \u2192 v0.0.272

"},{"location":"CHANGELOG/#050-2023-06-12","title":"0.5.0 (2023-06-12)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_35","title":"Fixes","text":"
  • Fixed ruff complaints about subprocess. c429c68
  • Fixed issue with formatting. da7544f

    There is an underlying edge case where the deriving previous environment variables with multiple ways of formatting version numbers will fail.

  • Add test to reproduce issue #14. d78ff46
  • Added documentation for replacing strings in different files. 893ec03

    Fixes #6

"},{"location":"CHANGELOG/#new_20","title":"New","text":""},{"location":"CHANGELOG/#other_25","title":"Other","text":"
  • Made VERSION_PART optional. f236b7d

    • Fixes #16
    • VERSION_PART is detected from the arguments based on the configuration
"},{"location":"CHANGELOG/#updates_19","title":"Updates","text":"
  • Updated docs indicated VERSION_PART is optional. 22edeac
  • Updated tests for bad version parts. 23be62d
  • Changed exception type raised when bad version part is detected. 1e3ebc5

    • ValueError -> click.BadArgumentUsage
    • Updated readme. 7780265

    Fixes #7

"},{"location":"CHANGELOG/#041-2023-06-09","title":"0.4.1 (2023-06-09)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_36","title":"Fixes","text":"
  • Fixes release.yaml. 01870d5

    Outputs the notes to a file instead of an environment variable.

"},{"location":"CHANGELOG/#other_26","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 266002f

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. edc444f

    updates: - github.com/charliermarsh/ruff-pre-commit: v0.0.261 \u2192 v0.0.270

"},{"location":"CHANGELOG/#040-2023-04-20","title":"0.4.0 (2023-04-20)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_37","title":"Fixes","text":"
  • Fixed pre-commit hook for dependency checking. 3d5c253
  • Fixed installing test dependencies. c1034eb
  • Fixed dependency spec. 4782745
  • Fixed missing python in pypi test. e5ed27d
  • Fixed some CI issues. d4b03d7
  • Fixed vague commit and tagging info. 4fb5158

    • If commit is configured false, it will report that it will not commit
    • If commit is configured false, tagging is disabled and it reports that
    • If tagging is configured false, it will report it is not tagging
    • Fixes test package. 7c12072
    • The build-and-inspect action didn\u2019t save the dist packages
"},{"location":"CHANGELOG/#new_21","title":"New","text":"
  • Added tests for logging branches. f8f0278
  • Added path restrictions on release-hints. e1af658
  • Added test build to CI. 8738f3f
  • Added doc files to table of contents. 49858c0
"},{"location":"CHANGELOG/#other_27","title":"Other","text":"
  • Completely migrated setuptools to use pyproject.toml. f10f8b2
  • [pre-commit.ci] pre-commit autoupdate. d626f7d

    updates: - https://github.com/python/black \u2192 https://github.com/psf/black

"},{"location":"CHANGELOG/#updates_20","title":"Updates","text":"
  • Removed pre-commit dependency hook. ac6cdd0
  • Changed the version serialization. c529452

    • can bump \u201cdev\u201d to get a development release
    • Updated formatting documentation. 8006f3e
"},{"location":"CHANGELOG/#030-2023-04-17","title":"0.3.0 (2023-04-17)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_38","title":"Fixes","text":"
  • Fixed bug in SCMInfo setup. e8fddc9
  • Fixed missing xml coverage report. 696503f
  • Fixed assertion in failing test. 7afe58c
  • Fixes issue when new version equals current version. 64b0de3

    • Now it reports they are the same and exits.
    • Fixes issue of duplicate tags. c025650
    • Now it checks if the tag exists and reports a warning
    • Fixed automation tooling. 19f13b7
    • changed name to bump-my-version in setup.cfg
    • added PAT in release pipeline to (hopefully) allow committing and tagging to master without issue.
"},{"location":"CHANGELOG/#new_22","title":"New","text":"
  • Added codecov to workflow. a5009e0
"},{"location":"CHANGELOG/#other_28","title":"Other","text":"
  • Migrated setuptools metadata to pyproject.toml. 0bd54dc
"},{"location":"CHANGELOG/#updates_21","title":"Updates","text":"
  • Updated the readme. 1b1d910
  • Updated documentation. 6c3b4fe
"},{"location":"CHANGELOG/#020-2023-04-14","title":"0.2.0 (2023-04-14)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_39","title":"Fixes","text":"
  • Fixed configuration to allow_dirty in bumpversion. b042e31
  • Fixes issue with generate-changelog and git. 2a977af
  • Fixes the quoting in the bumpversion expressions. 9a55d6d
  • Fixed issue with windows testing. b8abc44

    • different methods for reporting paths was resolved by casting them the pathlib.Paths
    • Fixes windows testing error. 556853b
    • the differences in path specifications seems to be causing problems.
    • Fixed type issue in Python 3.7, 3.8. ddfd3bf
  • Fixed configuration file detection. fbf85c2

    Doesn\u2019t just stop when it finds one, it checks for the existence of the header. - Fixed logging output and output in general. 0aea9dc

"},{"location":"CHANGELOG/#new_23","title":"New","text":"
  • Added additional option to manual runs: verbose. 81eb097
  • Added new workflows. a9cac5b

    • Added bumpversion.yaml to increase the version when a PR is closed
    • Added release.yaml to create a github release and upload things to PyPI
  • Added PYTHONUTF8 mode. 91a73e2

    • see https://docs.python.org/3/using/windows.html#utf-8-mode
  • Added explicit environment variable declarations. 80fe7ef
  • Added a github CI workflow. 2b3b358
  • Added files for coverage to ignore. cfbba08

    • main.py
    • aliases.py
  • Added LICENSE. 34a9be5
  • Added tests for version parsing errors. 71a204b
  • Added utf8 test in files. 9cb8f60
  • Added more tests for scm. fe794dd
  • Added \u2013list function. 88709fd
"},{"location":"CHANGELOG/#other_29","title":"Other","text":"
  • Removing testing for Python 3.7. 19eaeef
  • Moved configuration to pyproject.toml. d339007
  • Initial conversion. f5d1cab
  • Initial commit. d7dec79
"},{"location":"CHANGELOG/#updates_22","title":"Updates","text":"
  • Updated workflows. 857835d

    • Added better changelog parsing
    • Added workflow dispatch inputs for manual runs
    • Improved documentation. f3b7a0f
  • Renamed tox job to test. a9b6db3
  • Updated README and other documentation. e0cebb3
  • Improved Mercurial support. 560999d
  • Improved logging output. 6ccfa7d
  • Changed errors to subclass UsageError. a447651
  • Changed BaseVCS to SourceCodeManager. 11c5609

    Just for consistency. - Modified the group command back to a single command. 6d4179b

    Will eventually change to a group command, but later.

"},{"location":"CHANGELOG/#010-2023-03-24","title":"0.1.0 (2023-03-24)","text":"
  • Initial creation
"},{"location":"CONTRIBUTING/","title":"Contributing","text":""},{"location":"CONTRIBUTING/#contributing-to-bump-my-version","title":"Contributing to Bump My Version","text":"

First off, thanks for taking the time to contribute! \u2764\ufe0f

All types of contributions are encouraged and valued. See the Table of Contents for different ways to help and details about how this project handles them. Please make sure to read the relevant section before making your contribution. It will make it much easier for us maintainers and smooth out the experience for all involved. The community looks forward to your contributions. \ud83c\udf89

If you like the project but don\u2019t have time to contribute, that\u2019s fine. There are other easy ways to support the project and show your appreciation, which we would also be very happy about: - Star the project - Tweet about it - Refer to this project in your project\u2019s readme - Mention the project at local meetups and tell your friends/colleagues

"},{"location":"CONTRIBUTING/#table-of-contents","title":"Table of Contents","text":"
  • Code of Conduct
  • I Have a Question
  • Reporting Bugs
  • Suggesting Enhancements
  • Your First Code Contribution
  • Improving The Documentation
  • Styleguides
  • Join The Project Team
"},{"location":"CONTRIBUTING/#code-of-conduct","title":"Code of Conduct","text":"

This project and everyone participating in it are governed by the Bump My Version Code of Conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to coreyoordt@gmail.com.

"},{"location":"CONTRIBUTING/#i-have-a-question","title":"I Have a Question","text":"

If you want to ask a question, we assume that you have read the available Documentation.

Before you ask a question, it is best to search for existing Issues that might help you. In case you have found a suitable issue and still need clarification, you can write your question in this issue. It is also advisable to search the internet for answers first.

If you then still feel the need to ask a question and need clarification, we recommend the following:

  • Open an Issue.
  • Provide as much context as you can about what you\u2019re running into.
  • Provide project and platform versions (nodejs, npm, etc), depending on what seems relevant.

We will then take care of the issue as soon as possible.

"},{"location":"CONTRIBUTING/#reporting-bugs","title":"Reporting Bugs","text":""},{"location":"CONTRIBUTING/#before-submitting-a-bug-report","title":"Before Submitting a Bug Report","text":"

A good bug report shouldn\u2019t leave others needing to chase you up for more information. Therefore, we ask you to investigate carefully, collect information, and describe the issue in detail in your report. Please complete the following steps in advance to help us fix any potential bug as fast as possible.

  • Make sure that you are using the latest version.
  • Determine if your bug is really a bug and not an error on your side e.g. using incompatible environment components/versions (Make sure that you have read the documentation. If you are looking for support, you might want to check this section).
  • To see if other users have experienced (and potentially already solved) the same issue you are having, check if there is not already a bug report existing for your bug or error in the bug tracker.
  • Also, make sure to search the internet (including Stack Overflow) to see if users outside of the GitHub community have discussed the issue.
  • Collect information about the bug:
    • Stack trace (Traceback)
    • OS, Platform, and Version (Windows, Linux, macOS, x86, ARM)
    • The version of Python
    • Possibly your input and the output
    • Can you reliably reproduce the issue? And can you also reproduce it with older versions?
"},{"location":"CONTRIBUTING/#how-do-i-submit-a-good-bug-report","title":"How Do I Submit a Good Bug Report?","text":"

You must never report security-related issues, vulnerabilities, or bugs that include sensitive information to the issue tracker or elsewhere in public. Instead, sensitive bugs must be sent by email to coreyoordt@gmail.com.

We use GitHub issues to track bugs and errors. If you run into an issue with the project:

  • Open an Issue. (Since we can\u2019t be sure at this point whether it is a bug or not, we ask you not to talk about a bug yet and not to label the issue.)
  • Explain the behavior you would expect and the actual behavior.
  • Please provide as much context as possible and describe the reproduction steps that someone else can follow to recreate the issue on their own. This usually includes your code. For good bug reports, you should isolate the problem and create a reduced test case.
  • Provide the information you collected in the previous section.

Once it\u2019s filed:

  • The project team will label the issue accordingly.
  • A team member will try to reproduce the issue with your provided steps. If there are no reproduction steps or no obvious way to reproduce the issue, the team will ask you for those steps and will not address them until they are included.
  • If the team is able to reproduce the issue, the issue will be left to be implemented by someone.
"},{"location":"CONTRIBUTING/#suggesting-enhancements","title":"Suggesting Enhancements","text":"

This section guides you through submitting an enhancement suggestion for Bump My Version, including completely new features and minor improvements to existing functionality. Following these guidelines will help maintainers and the community to understand your suggestion and find related suggestions.

"},{"location":"CONTRIBUTING/#before-submitting-an-enhancement","title":"Before Submitting an Enhancement","text":"
  • Make sure that you are using the latest version.
  • Read the documentation carefully and find out if the functionality is already covered, maybe by an individual configuration.
  • Perform a search to see if the enhancement has already been suggested. If it has, add a comment to the existing issue instead of opening a new one.
  • Find out whether your idea fits with the scope and aims of the project. It\u2019s up to you to make a strong case to convince the project\u2019s developers of the merits of this feature. Keep in mind that we want features that will be useful to the majority of our users and not just a small subset. If you\u2019re just targeting a minority of users, consider writing an add-on/plugin library.
"},{"location":"CONTRIBUTING/#how-do-i-submit-a-good-enhancement-suggestion","title":"How Do I Submit a Good Enhancement Suggestion?","text":"

Enhancement suggestions are tracked as GitHub issues.

  • Use a clear and descriptive title for the issue to identify the suggestion.
  • Describe the problem or use case this enhancement solves or the new benefit it provides.
  • Explain why this enhancement would be useful to most Bump My Version users. You may also want to point out the other projects that solved it better and which could serve as inspiration.
  • Provide a step-by-step description of the suggested enhancement in as many details as possible.
  • You may also tell how current alternatives do not work for you, if appropriate
"},{"location":"CONTRIBUTING/#your-first-code-contribution","title":"Your First Code Contribution","text":""},{"location":"CONTRIBUTING/#legal-notice","title":"Legal Notice","text":"

When contributing to this project, you must agree that you have authored 100% of the content, that you have the necessary rights to the content and that the content you contribute may be provided under the project license.

"},{"location":"CONTRIBUTING/#setup","title":"Setup","text":"

There are several ways to create an isolated Python development environment. This is the default method.

Run the following in a terminal:

# Clone the repository\ngit clone https://github.com/callowayproject/bump-my-version.git\n\n# Enter the repository\ncd bump-my-version\n\n# Create, then activate a virtual environment\npython -m venv env\nsource env/bin/activate\n\n# Install the development requirements\npython -m pip install -r requirements/dev.txt\n
"},{"location":"CONTRIBUTING/#run-tests","title":"Run tests","text":"

Once setup, you should be able to run tests:

pytest\n
"},{"location":"CONTRIBUTING/#install-pre-commit-hooks","title":"Install Pre-commit Hooks","text":"

Pre-commit hooks are scripts that run every time you make a commit. If any of the scripts fail, it stops the commit. You can see a listing of the checks in the .pre-commit-config.yaml file.

pre-commit install\n
"},{"location":"CONTRIBUTING/#improving-the-documentation","title":"Improving The Documentation","text":"

Please, please help us here.

"},{"location":"CONTRIBUTING/#styleguides","title":"Styleguides","text":""},{"location":"CONTRIBUTING/#coding-style","title":"Coding Style","text":"

All of the basic coding styles are configured into tools for fixing and checking them. Pre-commit is used to automate the process.

"},{"location":"CONTRIBUTING/#commit-messages","title":"Commit Messages","text":"

Commit messages are used to generate the change log.

New changes

Commit messages are categorized as \u201cnew\u201d if the commit message starts with:

  • new
  • add

For example: Added this cool new feature or New document type added.

Updates

Commit messages are categorized as \u201cupdates\u201d if the commit message starts with:

  • update
  • change
  • rename
  • remove
  • delete
  • improve
  • refacto
  • chg
  • modif

For example: Modified the taxonomy schema or Improves performance by 419%

Fixes

Commit messages are categorizes as \u201cfixes\u201d if the commit message starts with:

  • fix

For example: Fixes bug #123

Other

All other commit messages are categorized as \u201cother.\u201d

Ignoring commit messages

To have the change log generator ignore this commit, add to the summary line:

  • @minor
  • !minor
  • @cosmetic
  • !cosmetic
  • @refactor
  • !refactor
  • @wip
  • !wip
"},{"location":"CONTRIBUTING/#join-the-project-team","title":"Join The Project Team","text":"

If you would like to be a maintainer, reach out to coreyoordt@gmail.com.

"},{"location":"CONTRIBUTING/#attribution","title":"Attribution","text":"

This guide is based on the contributing-gen. Make your own!

"},{"location":"explanation/","title":"Explanation","text":""},{"location":"explanation/mental-model/","title":"The mental model used by Bump My Version","text":""},{"location":"explanation/mental-model/#overview","title":"Overview","text":"

There are four main concepts in Bump My Version:

  1. Configuration
  2. Version handling
  3. File changing
  4. Source control management interface
"},{"location":"explanation/mental-model/#configuration","title":"Configuration","text":"

The predecessor to Bump My Version, bumpversion, was designed to have the configuration file optional. All configuration values could be specified on the command line. This only worked in the simplest of version schemes.

While Bump My Version can do many things without a configuration file, it is designed to have a configuration file. The configuration file is required to specify the version scheme. The configuration file also specifies the files to change and how to change them.

"},{"location":"explanation/mental-model/#version-handling","title":"Version handling","text":"

Bump My Version abstracts the version handling into a few concepts:

A version spec defines the rules for incrementing a version.

A version component spec defines how a single part of a version spec, such as major, minor, or patch, works. It defines the types of values, how to increment the component, and how to reset it.

A version parser is a regular expression used in several ways. Its named capture groups define the possible components in a version spec and the order in which they appear. It also parses a version string into version component names and their values.

A version is the concrete representation of a version spec. It is a mapping of version component names to version components.

A version component is the concrete representation of a version component spec. It is a version component spec with a specific value.

A version serialization format is a list of format strings used to serialize a version into a string.

"},{"location":"explanation/mental-model/#how-a-version-spec-is-generated","title":"How a version spec is generated","text":"How a configuration file is used to generate a version spec.

The most important part of the configuration file is the version parser. It defines the structure of the version spec.

If the configuration file contains a version component spec that matches a named capture group in the version parser, then that version component spec is used in the version spec. The yellow and green named capture groups in the diagram demonstrate this.

If the configuration file does not contain a version component spec that matches a named capture group in the version parser, then a default version component spec is used. The blue named capture group in the diagram demonstrates this.

The component dependency graph determines the order in which the version components are incremented and reset. For example, in the diagram, the patch component depends on the minor component, which depends on the major component. Therefore, when the major component is incremented, the minor component is reset, which cascades to the patch component.

"},{"location":"explanation/mental-model/#how-a-version-is-generated","title":"How a version is generated","text":"How a version spec is used to generate a version.

The version spec has a create_version method that takes a mapping of version component names to values.

Each version component spec has a create_component method that takes a value. The create_version method calls the create_component method for each version component spec in the version spec with the value from the mapping.

The create_component assembles its version spec_ with the version components to create a version.

"},{"location":"explanation/mental-model/#how-a-version-is-serialized","title":"How a version is serialized","text":"

Optional value rule. Version component specs can define an optional value. For example, numeric components have 0 as an optional value. Optional values may be omitted from the serialization as long as all dependent components also have optional values.

Required value rule. Version component specs is required if its value or the value of any of its dependent components is not optional.

A valid serialization contains all the required components in the version spec based on the required value rule.

An invalid serialization does not contain all the required components in the version spec based on the required value rule.

The optimal serialization is the valid serialization that uses the fewest components.

The serialize method of the version spec returns either the optimal serialization or the first invalid serialization.

"},{"location":"explanation/mental-model/#version-serialization-examples","title":"Version serialization examples","text":"

No optional values

In this example, the major component is 1, the minor component is 2, and patch component is 3. Since none of the values are optional (0), only one serialization format is valid. This one valid format is the optimal format.

One optional value

A version with values major=1, minor=2, and patch=0 has two valid serializations. The optimal serialization is the one that uses the fewest components. 1.2 in this example.

Two optional values

A version with values major=1, minor=0, and patch=0 has three valid serializations. The optimal serialization is the one that uses the fewest components. 1 in this example.

No valid serialization options

A version with values major=1, minor=2, and patch=3 has no valid serializations in this example. The serialize method returns the first invalid serialization.

"},{"location":"howtos/","title":"How-To Guides","text":"
  • Avoid incorrect replacements
  • Custom version formats by file
  • Multiple replacements
"},{"location":"howtos/avoid-incorrect-replacements/","title":"Avoiding incorrect replacements","text":"

In files that have multiple version strings, Bump My Version may find the wrong string and replace it. Given this requirements.txt for MyProject:

Django>=1.5.6,<1.6\nMyProject==1.5.6\n

The default search and replace templates will replace the wrong text. Instead of changing MyProject\u2019s version from 1.5.6 to 1.6.0, it changes Django\u2019s version:

Django>=1.6.0,<1.6\nMyProject==1.5.6\n

Providing search and replace templates for the requirements.txt file will avoid this.

This .bumpversion.toml will ensure only the line containing MyProject will be changed:

[tool.bumpversion]\ncurrent_version = \"1.5.6\"\n\n[[tool.bumpversion.files]]\nfilename = \"requirements.txt\"\nsearch = \"MyProject=={current_version}\"\nreplace = \"MyProject=={new_version}\"\n

If the string to be replaced includes literal quotes, the search and replace patterns must include them to match. Given the file version.sh:

MY_VERSION=\"1.2.3\"\n

Then the following search and replace patterns (including quotes) would be required:

[[tool.bumpversion.files]]\nfilename = \"version.sh\"\nsearch = \"MY_VERSION=\\\"{current_version}\\\"\"\nreplace = \"MY_VERSION=\\\"{new_version}\\\"\"\n
"},{"location":"howtos/calver/","title":"Using Calendar Versioning (CalVer)","text":"

Calendar Versioning (CalVer) is a versioning scheme that uses a date-based version number.

For this example, we will use the following format: YYYY.MM.DD.patch. It will yield numbers like:

  • 2022.2.1 for the first patch of February 1, 2022
  • 2022.2.1.1 for the second patch of February 1, 2022
"},{"location":"howtos/calver/#initial-configuration","title":"Initial configuration","text":".bumpversion.toml
[tool.bumpversion]\ncurrent_version = \"2024.3.1.4\"\nparse = \"\"\"(?x)                     # Verbose mode\n    (?P<release>                    # The release part\n        (?:[1-9][0-9]{3})\\\\.        # YYYY.\n        (?:1[0-2]|[1-9])\\\\.         # MM.\n        (?:3[0-1]|[1-2][0-9]|[1-9]) # DD\n    )\n    (?:\\\\.(?P<patch>\\\\d+))?         # .patch, optional\n\"\"\"\nserialize = [\"{release}.{patch}\", \"{release}\"]\n\n[tool.bumpversion.parts.release]\ncalver_format = \"{YYYY}.{MM}.{DD}\"\n

You can look up the regular expressions for the CalVer format in the CalVer reference.

"},{"location":"howtos/calver/#expected-behavior","title":"Expected behavior","text":"

You can find out more about the logic behind the CalVer incrementing in the CalVer reference.

"},{"location":"howtos/calver/#bumping-the-release-resets-the-patch-part","title":"Bumping the release resets the patch part","text":"

When you bump the calendar version, the patch is reset to 0 even if the release did not change.

Bumping the release resets patch
$ date -I      \n2024-03-1\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.1\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.1.5\n

The next day:

Bumping the release resets patch, the next day
$ date -I      \n2024-03-2\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.2\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.2\n
"},{"location":"howtos/calver/#the-result-of-a-bump-to-patch-depends-on-the-date","title":"The result of a bump to patch depends on the date","text":"

Calendar Versioned parts are updated with every bump, regardless of the part being bumped. If you are bumping the version within the same time period (in this example, the same day), the release part will not change. So bumping the patch part will increment the patch part only.

Bumping patch on the same day
$ date -I      \n2024-03-1\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.1\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.1.5\n

However, if you bump the version on the next day, the release part will also be updated.

Bumping patch on the next day
$ date -I      \n2024-03-2\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.2\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.2\n
"},{"location":"howtos/custom-version-formats-by-file/","title":"Custom version formats in different files","text":"

You can use file configurations to replace the version in multiple files, even if each file has the version formatted differently.

In a module-aware Go project, when you create a major version of your module beyond v1, your module name must include the major version number (e.g., github.com/myorg/myproject/v2). However, you also have the full version in a YAML file named release-channels.yaml.

go.mod file:

module github.com/myorg/myproject/v2\n\ngo 1.12\n\nrequire (\n    ...\n)\n

release-channels.yaml file:

stable: \"v2.21.4\"\n

You can use Bump My Version to maintain the major version number within the go.mod file by using the parse and serialize options, as in this example:

.bumpversion.toml file:

[tool.bumpversion]\ncurrent_version = \"2.21.4\"\n\n[[tool.bumpversion.files]]\nfilename = \"go.mod\"\nparse = \"(?P<major>\\\\d+)\"\nserialize = \"{major}\"\nsearch = \"module github.com/myorg/myproject/v{current_version}\"\nreplace = \"module github.com/myorg/myproject/v{new_version}\"\n\n[[tool.bumpversion.files]]\nfilename = \"release-channels.yaml\"\n

While all the version bumps are minor or patch, the go.mod file doesn\u2019t change, while the release-channels.yaml file will. As soon as you do a major version bump, the go.mod file now contains this module directive:

module github.com/myorg/myproject/v3\n
"},{"location":"howtos/multiple-replacements/","title":"Multiple replacements within the same file","text":"

To make several replacements in the same file, you must configure multiple [[tool.bumpversion.files]] sections for the same file with different configuration options.

In this example, the changelog is generated before the version bump. It uses Unreleased as the heading and includes a link to GitHub to compare this version (HEAD) with the previous version.

To change Unreleased to the current version, we have an entry with search set to Unreleased. The default replace value is {new_version}, so changing it is unnecessary.

To change the link, another entry has its search set to {current_version}...HEAD and the replace set to {current_version}...{new_version}.

[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"Unreleased\"\n\n[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"{current_version}...HEAD\"\nreplace = \"{current_version}...{new_version}\"\n
"},{"location":"howtos/update-a-date/","title":"How to update a date in a file","text":"

Many times when bumping a version, you will also want to update a date in a file. This is a common use case for changelogs, but it could be any file that contains a date. In this example, we have an __init__.py that looks like this:

my_package/__init__.py
__date__ = '2022-12-19'\n__version__ = '0.4.0'\n

The desired outcome is to update the date to the current date. For example, if today is February 23, 2024, the init.py file should look like this after a minor bump:

my_package/__init__.py
__date__ = '2024-02-23'\n__version__ = '0.5.0'\n
"},{"location":"howtos/update-a-date/#setting-up-the-file-configurations","title":"Setting up the file configurations","text":"

We need Bump My Version to update the __init__.py file twice: once for the version and once for the date. Here is the necessary configuration:

.bumpversion.toml or other config file
[[tool.bumpversion.files]]\nfilename = '__init__.py'\nsearch = \"__date__ = '\\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}'\"\nreplace = \"__date__ = '{now:%Y-%m-%d}'\"\nregex = true\n\n[[tool.bumpversion.files]]\nfilename = '__init__.py'\n
"},{"location":"reference/","title":"Reference","text":"
  • Subcommands
  • Command-line interface
  • Configuration
  • Calendar versioning reference
  • Formatting context
  • Version parts
  • Search and replace configuration
  • API
"},{"location":"reference/calver_reference/","title":"Calendar versioning reference","text":""},{"location":"reference/calver_reference/#calendar-versioning-codes","title":"Calendar versioning codes","text":"

The following table lists the available format codes for calendar versioning (CalVer) schemes. The codes can be used to define the version format in the calver_format configuration options. Formatting codes, surrounded by { } can be combined to create a custom version format. For example, the format YYYY.MM.DD can be defined as \"{YYYY}.{MM}.{DD}\".

Code Example(s) Comment YYYY 2000, 2001, \u2026, 2099 Full year YY 0, 1, 2, \u2026, 99 Short year as integer 0Y 00, 01, 02, \u2026, 99 Short Year, zero-padded MMM Jan, Feb, jan, f\u00e9v Month abbreviation, locale-based MM 1, 2, \u2026, 12 Month as integer 0M 01, 02, \u2026, 12 Month, zero-padded DD 1, 2, \u2026, 31 Day of month as integer 0D 01, 02, \u2026, 31 Day of month, zero-padded JJJ 1, 2, 3, \u2026, 366 Day of year as integer 00J 001, 002, \u2026, 366 Day of year, zero-padded Q 1, 2, 3, 4 Quarter WW 0, 1, 2, \u2026, 53 Week number, Monday is first day 0W 00, 01, 02, \u2026, 53 Week number, Monday is first day, zero-padded UU 0, 1, 2, \u2026, 53 Week number, Sunday is first day 0U 00, 01, 02, \u2026, 53 Week number, Sunday is first day, zero-padded VV 1, 2, \u2026, 53 ISO 8601 week number as integer 0V 01, 02, \u2026, 53 ISO 8601 week number, zero-padded GGGG 2000, 2001, \u2026, 2099 ISO 8601 week-based year GG 0, 1, 2, \u2026, 99 ISO 8601 short week-based year as integer 0G 01, 02, \u2026, 99 ISO 8601 short week-based year, zero-padded Example configuration
[tool.bumpversion.parts.release]\ncalver_format = \"{YYYY}.{MM}.{DD}\"\n
"},{"location":"reference/calver_reference/#parsing-calver-versions","title":"Parsing CalVer versions","text":"

Using the following chart, we can set up the version parsing:

Code Regex YYYY (?:[1-9][0-9]{3}) YY (?:[1-9][0-9]?) 0Y (?:[0-9]{2}) MMM See below MM (?:1[0-2]\\|[1-9]) 0M (?:1[0-2]\\|0[1-9]) DD (?:3[0-1]\\|[1-2][0-9]\\|[1-9]) 0D (?:3[0-1]\\|[1-2][0-9]\\|0[1-9]) JJJ (?:36[0-6]\\|3[0-5][0-9]\\|[1-2][0-9][0-9]\\|[1-9][0-9]\\|[1-9]) 00J (?:36[0-6]\\|3[0-5][0-9]\\|[1-2][0-9][0-9]\\|0[1-9][0-9]\\|00[1-9]) Q (?:[1-4]) WW (?:5[0-3]\\|[1-4][0-9]\\|[0-9]) 0W (?:5[0-3]\\|[0-4][0-9]) UU (?:5[0-3]\\|[1-4][0-9]\\|[0-9]) 0U (?:5[0-3]\\|[0-4][0-9]) VV (?:5[0-3]\\|[1-4][0-9]\\|[1-9]) 0V (?:5[0-3]\\|[1-4][0-9]\\|0[1-9]) GGGG (?:[1-9][0-9]{3}) GG (?:[0-9][0-9]?) 0G (?:[0-9]{2})

Month abbreviations

The month abbreviation is locale-based. Here are some examples:

(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec) for English

(?:jan|f\u00e9v|mar|avr|mai|jui|jui|ao\u00fb|sep|oct|nov|d\u00e9c) for French

You can use these regular expressions to parse CalVer versions in your project. For example, the following parse configuration can be used to parse a version string in the format YYYY.MM.DD as the release part of the version string:

[tool.bumpversion]\nparse = \"\"\"(?x)                      # Verbose mode\n    (?P<release>\n        (?:[1-9][0-9]{3})\\\\.         # YYYY.\n        (?:1[0-2]|[1-9])\\\\.          # MM.\n        (?:3[0-1]|[1-2][0-9]|[1-9])  # DD\n    )\n\"\"\"\n
"},{"location":"reference/calver_reference/#calver-incrementing-logic","title":"CalVer incrementing logic","text":"
  • CalVer version components are marked as always_increment by default.
  • When bumping a version, you specify which component to increment. It is called the target component.
  • When bumping a version, the components marked as always_increment are incremented first.
  • If an always_increment component\u2019s value changed, its dependent components are marked for reset to their default values.
  • If the target component is in the set of components marked for reset, the target component is reset to its default value.
  • If the target component is not in the set of components marked for reset, the target component is incremented and its dependent components are reset to their default values.
"},{"location":"reference/cli/","title":"CLI Reference","text":""},{"location":"reference/cli/#bump-my-version","title":"bump-my-version","text":"

Version bump your Python project.

Usage:

bump-my-version [OPTIONS] COMMAND [ARGS]...\n

Options:

Name Type Description Default --version boolean Show the version and exit. False --help boolean Show this message and exit. False

Subcommands

  • bump:
  • replace:
  • sample-config: Print a sample configuration file.
  • show:
  • show-bump: Show the possible versions resulting from the bump subcommand.
"},{"location":"reference/cli/#bump-my-version-bump","title":"bump-my-version bump","text":"

Change the version.

ARGS may contain any of the following:

VERSION_PART is the part of the version to increase, e.g. minor. Valid values include those given in the --serialize / --parse option.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

Usage:

bump-my-version bump [OPTIONS] [ARGS]...\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None -v, --verbose integer range (0 and above) Print verbose logging to stderr. Can specify several times for more verbosity. 0 --allow-dirty / --no-allow-dirty boolean Don\u2019t abort if working directory is dirty, or explicitly abort if dirty. None --current-version text Version that needs to be updated None --new-version text New version that should be in the files None --parse text Regex parsing the version string None --serialize text How to format what is parsed back to a version None --search text Template for complete string to search None --replace text Template for complete string to replace None --regex / --no-regex boolean Treat the search parameter as a regular expression or explicitly do not treat it as a regular expression. None --no-configured-files boolean Only replace the version in files specified on the command line, ignoring the files from the configuration file. False --ignore-missing-files / --no-ignore-missing-files boolean Ignore any missing files when searching and replacing in files. None --ignore-missing-version / --no-ignore-missing-version boolean Ignore any Version Not Found errors when searching and replacing in files. None --dry-run, -n boolean Don\u2019t write any files, just pretend. False --commit / --no-commit boolean Commit to version control None --tag / --no-tag boolean Create a tag in version control None --sign-tags / --no-sign-tags boolean Sign tags if created None --tag-name text Tag name (only works with \u2013tag) None --tag-message text Tag message None -m, --message text Commit message None --commit-args text Extra arguments to commit command None --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-replace","title":"bump-my-version replace","text":"

Replace the version in files.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

Usage:

bump-my-version replace [OPTIONS] [FILES]...\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None -v, --verbose integer range (0 and above) Print verbose logging to stderr. Can specify several times for more verbosity. 0 --allow-dirty / --no-allow-dirty boolean Don\u2019t abort if working directory is dirty, or explicitly abort if dirty. None --current-version text Version that needs to be updated None --new-version text New version that should be in the files. If not specified, it will be None. None --parse text Regex parsing the version string None --serialize text How to format what is parsed back to a version None --search text Template for complete string to search None --replace text Template for complete string to replace None --regex / --no-regex boolean Treat the search parameter as a regular expression or explicitly do not treat it as a regular expression. False --no-configured-files boolean Only replace the version in files specified on the command line, ignoring the files from the configuration file. False --ignore-missing-version boolean Ignore any Version Not Found errors when searching and replacing in files. False --ignore-missing-files boolean Ignore any missing files when searching and replacing in files. False --dry-run, -n boolean Don\u2019t write any files, just pretend. False --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-sample-config","title":"bump-my-version sample-config","text":"

Print a sample configuration file.

Usage:

bump-my-version sample-config [OPTIONS]\n

Options:

Name Type Description Default --prompt / --no-prompt boolean Ask the user questions about the configuration. True --destination choice (stdout | .bumpversion.toml | pyproject.toml) Where to write the sample configuration. stdout --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-show","title":"bump-my-version show","text":"

Show current configuration information.

ARGS may contain one or more configuration attributes. For example:

  • bump-my-version show current_version
  • bump-my-version show files.0.filename
  • bump-my-version show scm_info.branch_name
  • bump-my-version show current_version scm_info.distance_to_latest_tag

Usage:

bump-my-version show [OPTIONS] [ARGS]...\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None -f, --format choice (default | yaml | json) Config file to read most of the variables from. default -i, --increment text Increment the version part and add new_version to the configuration. None --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-show-bump","title":"bump-my-version show-bump","text":"

Show the possible versions resulting from the bump subcommand.

Usage:

bump-my-version show-bump [OPTIONS] [VERSION]\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None --ascii boolean Use ASCII characters only. False --help boolean Show this message and exit. False"},{"location":"reference/configuration/","title":"Configuration","text":"

Bump My Version looks in three places for configuration information (in order of precedence):

  1. command line
  2. configuration file
  3. environment variables
"},{"location":"reference/configuration/#configuration-files","title":"Configuration files","text":"

Bump My Version looks in four places for the configuration file to parse (in order of precedence):

  1. --config-file <FILE> (command line argument)
  2. BUMPVERSION_CONFIG_FILE=file (environment variable)
  3. .bumpversion.cfg (legacy)
  4. .bumpversion.toml
  5. setup.cfg (legacy)
  6. pyproject.toml

.toml files are recommended. We will likely drop support for ini-style formats in the future. You should add your configuration file to your source code management system.

By using a configuration file, you no longer need to specify those options on the command line. The configuration file also allows greater flexibility in specifying how files are modified.

"},{"location":"reference/configuration/#global-configuration","title":"Global Configuration","text":"

The general configuration is grouped in a [tool.bumpversion] or [bumpversion] section, depending on if it is a TOML or INI file, respectfully.

"},{"location":"reference/configuration/#allow_dirty","title":"allow_dirty","text":"required No default False type boolean command line option --allow-dirty | --no-allow-dirty environment var BUMPVERSION_ALLOW_DIRTY

Bump-my-version\u2019s default behavior is to abort if the working directory has uncommitted changes. This protects you from releasing unversioned files and overwriting unsaved changes.

"},{"location":"reference/configuration/#commit","title":"commit","text":"required No default False (Don\u2019t create a commit) type boolean command line option --commit | --no-commit environment var BUMPVERSION_COMMIT

Whether to create a commit using git or Mercurial.

If you have pre-commit hooks, add an option to commit_args to turn off your pre-commit hooks. For Git, use --no-verify and use --config hooks.pre-commit= for Mercurial.

"},{"location":"reference/configuration/#commit_args","title":"commit_args","text":"required No default \"\" type string command line option --commit-args environment var BUMPVERSION_COMMIT_ARGS

Extra arguments to pass to commit command. This is only used when the commit option is set to True.

If you have pre-commit hooks, add an option to turn off your pre-commit hooks. For Git, use --no-verify and use --config hooks.pre-commit= for Mercurial.

"},{"location":"reference/configuration/#current_version","title":"current_version","text":"required Yes default \"\" type string command line option --current-version environment var BUMPVERSION_CURRENT_VERSION

The current version of the software package before bumping. A value for this is required.

"},{"location":"reference/configuration/#ignore_missing_files","title":"ignore_missing_files","text":"required No default False type boolean command line option --ignore-missing-files environment var BUMPVERSION_IGNORE_MISSING_FILES

If True, don\u2019t fail if the configured file is missing.

"},{"location":"reference/configuration/#ignore_missing_version","title":"ignore_missing_version","text":"required No default False type boolean command line option --ignore-missing-version environment var BUMPVERSION_IGNORE_MISSING_VERSION

If True, don\u2019t fail if the version string to be replaced is not found in the file.

"},{"location":"reference/configuration/#message","title":"message","text":"required No default Bump version: {current_version} \u2192 {new_version} type string command line option --message environment var BUMPVERSION_MESSAGE

The commit message template to use when creating a commit. This is only used when the commit option is set to True.

This string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

"},{"location":"reference/configuration/#parse","title":"parse","text":"required No default (?P<major>\\d+)\\.(?P<minor>\\d+)\\.(?P<patch>\\d+) type string command line option --parse environment var BUMPVERSION_PARSE

This is the default regular expression (Python regular expression syntax) for finding and parsing the version string into its components. Individual part or file configurations may override this.

The regular expression must be able to parse all strings produced by the configured serialize value. Named matching groups (\u201c(?P<name>...)\u201d) indicate the version part the matched value belongs to.

"},{"location":"reference/configuration/#regex","title":"regex","text":"required No default False type boolean command line option --regex | --no-regex environment var BUMPVERSION_REGEX

Treat the search string as a regular expression.

"},{"location":"reference/configuration/#replace","title":"replace","text":"required No default {new_version} type string command line option --replace environment var BUMPVERSION_REPLACE

This is the template to create the string that will replace the current version number in the file.

"},{"location":"reference/configuration/#search","title":"search","text":"required No default {current_version} type string command line option --search environment var BUMPVERSION_SEARCH

This is the template string for searching. It is rendered using the formatting context for searching in the file. Individual file configurations may override this. This can span multiple lines and is templated using Python Format String Syntax. The formatting context reference describes the available variables.

This is useful if there is the remotest possibility that the current version number might be present multiple times in the file and you mean to bump only one of the occurrences.

"},{"location":"reference/configuration/#serialize","title":"serialize","text":"required No default [\"{major}.{minor}.{patch}\"] type an array of strings command line option --serialize environment var BUMPVERSION_SERIALIZE

This is the default list of templates specifying how to serialize the version parts back to a version string. Individual part or file configurations may override this.

Since version parts can be optional, bumpversion will try the serialization formats beginning with the first and choose the last one where all values can all non-optional values are represented.

In this example (in TOML):

serialize = [\n    \"{major}.{minor}.{patch}\",\n    \"{major}.{minor}\",\n    \"{major}\"\n]\n

Since 0 is optional by default, Version 1.8.9 will serialize to 1.8.9, 1.9.0 will serialize to 1.9, and version 2.0.0 will serialize as 2.

Each string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

"},{"location":"reference/configuration/#sign_tags","title":"sign_tags","text":"required No default False (Don\u2019t sign tags) type boolean command line option --sign-tags | --no-sign-tags environment var BUMPVERSION_SIGN_TAGS

If True, sign the created tag, when tag is True.

"},{"location":"reference/configuration/#tag","title":"tag","text":"required No default False (Don\u2019t create a tag) type boolean command line option --tag | --no-tag environment var BUMPVERSION_TAG

If True, create a tag after committing the changes. The tag is named using the tag_name option.

If you are using git, don\u2019t forget to git-push with the --tags flag when you are done.

"},{"location":"reference/configuration/#tag_message","title":"tag_message","text":"required No default Bump version: {current_version} \u2192 {new_version} type string command line option --tag-message environment var BUMPVERSION_TAG_MESSAGE

The tag message template to use when creating a tag when tag is True

This string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

Bump My Version creates an annotated tag in Git by default. To turn this off and create a lightweight tag, you must explicitly set an empty tag_message value.

"},{"location":"reference/configuration/#tag_name","title":"tag_name","text":"required No default v{new_version} type string command line option --tag-name environment var BUMPVERSION_TAG_NAME

The template used to render the tag when tag is True.

This string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

"},{"location":"reference/configuration/#examples","title":"Examples","text":"TOMLCFG
[tool.bumpversion]\nallow_dirty = false\ncommit = false\nmessage = \"Bump version: {current_version} \u2192 {new_version}\"\ncommit_args = \"\"\ntag = false\nsign_tags = false\ntag_name = \"v{new_version}\"\ntag_message = \"Bump version: {current_version} \u2192 {new_version}\"\ncurrent_version = \"1.0.0\"\nparse = \"(?P<major>\\\\d+)\\\\.(?P<minor>\\\\d+)\\\\.(?P<patch>\\\\d+)\"\nserialize = [\n    \"{major}.{minor}.{patch}\"\n]\nsearch = \"{current_version}\"\nreplace = \"{new_version}\"\n
[bumpversion]\nallow_dirty = False\ncommit = False\nmessage = Bump version: {current_version} \u2192 {new_version}\ncommit_args = \ntag = False\nsign_tags = False\ntag_name = v{new_version}\ntag_message = Bump version: {current_version} \u2192 {new_version}\ncurrent_version = 1.0.0\nparse = (?P<major>\\d+)\\.(?P<minor>\\d+)\\.(?P<patch>\\d+)\nserialize =\n    {major}.{minor}.{patch}\nsearch = {current_version}\nreplace = {new_version}\n
"},{"location":"reference/configuration/#version-part-specific-configuration","title":"Version part-specific configuration","text":"

Version part configuration is grouped in a [tool.bumpversion.parts.<partname>] or [bumpversion:part:<partname>] section, depending on if it is a TOML or INI file, respectfully.

You only need to configure version parts if they deviate from the default, and then you only need to specify the overridden options.

"},{"location":"reference/configuration/#values","title":"values","text":"required No default numeric (i.e. 0, 1, 2, \u2026) type array of strings

An explicit list of all values to iterate through when bumping this part. An empty array is treated as indicating numeric values.

"},{"location":"reference/configuration/#optional_value","title":"optional_value","text":"required No default The first entry in values, 0 when using numeric values type string

When the version part matches this value, it is considered optional when serializing the final version string.

Note

Numeric values are still treated as strings internally, so when specifying an optional value, you must use a string.

"},{"location":"reference/configuration/#first_value","title":"first_value","text":"required No default The first entry in values, 0 when using numeric values type string

When the part is reset, the value will be set to the value specified here.

Note

Numeric values are still treated as strings internally, so when specifying a first value, you must use a string.

"},{"location":"reference/configuration/#independent","title":"independent","text":"required No default False type boolean

When this value is set to True, the part is not reset when other parts are incremented. Its incrementation is independent of the other parts. It is useful when you have a build number in your version that is incremented independently of the actual version.

"},{"location":"reference/configuration/#always_increment","title":"always_increment","text":"required No default False (True if calver_format is set) type boolean

When this value is set to True, the part is always incremented when the version is bumped, regardless of the target part.

"},{"location":"reference/configuration/#calver_format","title":"calver_format","text":"required No default empty type string

The calver_format is a string that specifies the format of the version part. It is used to determine the next value when bumping the version. The format is a string that uses the placeholders defined in the CalVer reference.

"},{"location":"reference/configuration/#examples_1","title":"Examples","text":"TOMLCFG
[tool.bumpversion.parts.release]\nvalues = [\n    \"alpha\",\n    \"beta\",\n    \"gamma\"\n]\noptional_value = \"gamma\"\n
[bumpversion:part:release]\noptional_value = gamma\nvalues =\n    alpha\n    beta\n    gamma\n
"},{"location":"reference/configuration/#file-specific-configuration","title":"File-specific configuration","text":"

This section configures which files Bump My Version should update by replacing their current version with the newly bumped version.

"},{"location":"reference/configuration/#filename","title":"filename","text":"required Yes\u2021 default empty type string

The name of the file to modify.

Note

\u2021 This is only used with TOML configuration and is only required if glob is not specified. INI-style configuration files specify the file name as part of the grouping.

"},{"location":"reference/configuration/#glob","title":"glob","text":"required Yes\u2021 default empty type string

The glob pattern specifying the files to modify.

Note

\u2021 This is only used with TOML configuration, and is only required if filename is not specified. INI-style configuration files specify the glob pattern as part of the grouping.

"},{"location":"reference/configuration/#glob_exclude","title":"glob_exclude","text":"required No default empty type list of string

A list of glob patterns to exclude from the files found via the glob parameter. Does nothing if filename is specified.

"},{"location":"reference/configuration/#parse_1","title":"parse","text":"required No default the value configured in the global parse field type string

This is an override to the default pattern to parse the version number from this file.

"},{"location":"reference/configuration/#serialize_1","title":"serialize","text":"required No default the value configured in the global serialize field type an array of strings

This is an override to the default templates to serialize the new version number in this file.

"},{"location":"reference/configuration/#search_1","title":"search","text":"required No default the value configured in the global search field type string

This is an override to the default template string how to search for the string to be replaced in the file.

"},{"location":"reference/configuration/#regex_1","title":"regex","text":"required No default the value configured in the global regex field type boolean

If True, treat the search parameter as a regular expression.

"},{"location":"reference/configuration/#replace_1","title":"replace","text":"required No default the value configured in the global replace field type string

This is an override to the template to create the string that will replace the current version number in the file.

"},{"location":"reference/configuration/#ignore_missing_version_1","title":"ignore_missing_version","text":"required No default The value configured in the global ignore_missing_version field type boolean

If True, don\u2019t fail if the version string to be replaced is not found in the file.

"},{"location":"reference/configuration/#ignore_missing_file","title":"ignore_missing_file","text":"required No default The value configured in the global ignore_missing_file field type boolean

if True, don\u2019t fail if the configured file is missing.

"},{"location":"reference/configuration/#include_bumps","title":"include_bumps","text":"required No default all version components type list of strings

The include_bumps file configuration allows you to control when bump-my-version includes this file for changes. Its alternative is the exclude_bumps configuration. When a bump <version component> command is issued, this file is changed only if the version component is in this list and not in exclude_bumps. The parse configuration defines version components.

The default value, or an empty list, includes all version components.

"},{"location":"reference/configuration/#exclude_bumps","title":"exclude_bumps","text":"required No default [] type list of strings

The exclude_bumps file configuration allows you to control when bump-my-version excludes this file for changes. Its alternative is the include_bumps configuration. When a bump <version component> command is issued, this file is only changed if the version component is not in this list. The parse configuration defines version components.

The default value does not exclude anything.

"},{"location":"reference/configuration/#examples_2","title":"Examples","text":"TOMLCFG

TOML allows us to specify the files using an array of tables. TOML configuration adds two fields to each file configuration: filename and glob. These fields are mutually exclusive: if you specify a value for both, only the glob value is used.

For example, to change coolapp/__init__.py with the defaults and alter CHANGELOG.md twice:

[[tool.bumpversion.files]]\nfilename = \"coolapp/__init__.py\"\n\n[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"Unreleased\"\n\n[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"{current_version}...HEAD\"\nreplace = \"{current_version}...{new_version}\"\n

INI-style configuration is in the section: [bumpversion:file:<filename>] or [bumpversion:glob:<glob pattern>].

Both, file: and glob: are configured the same. Their difference is that file will match file names directly like requirements.txt. While glob also matches multiple files via wildcards like **/pom.xml.

Note

The configuration file format requires each section header to be unique. If you want to process a certain file multiple times, you may append a description between parens to the file keyword: [bumpversion:file (special one):\u2026].

For example, to change coolapp/__init__.py with the defaults and alter CHANGELOG.md twice:

[bumpversion:file:coolapp/__init__.py]\n\n[bumpversion:file(version heading):CHANGELOG.md]\nsearch = Unreleased\n\n[bumpversion:file(previous version):CHANGELOG.md]\nsearch = {current_version}...HEAD\nreplace = {current_version}...{new_version}\n
"},{"location":"reference/formatting-context/","title":"Formatting context","text":"

These fields are available for

  • version serializing
  • searching and replacing in files
  • commit messages
  • tag names
  • tag annotations
"},{"location":"reference/formatting-context/#escaped-characters","title":"Escaped characters","text":"# The literal hash or octothorpe character. ; The literal semicolon character."},{"location":"reference/formatting-context/#date-and-time-fields","title":"Date and time fields","text":"now A Python datetime object representing the current local time, without a time zone reference. utcnow A Python datetime object representing the current local time in the UTC time zone.

You can provide additional formatting guidance for datetime objects using formatting codes. Put the formatting codes after the field and a colon. For example, {now:%Y-%m-%d} would output the current local time as 2023-04-20.

"},{"location":"reference/formatting-context/#source-code-management-fields","title":"Source code management fields","text":"

These fields will only have values if the code is in a Git or Mercurial repository.

commit_sha The latest commit reference. distance_to_latest_tag The number of commits since the latest tag. dirty A boolean indicating if the current repository has pending changes. branch_name The current branch name. short_branch_name The current branch name, converted to lowercase, with non-alphanumeric characters removed and truncated to 20 characters. For example, feature/MY-long_branch-name would become featuremylongbranchn."},{"location":"reference/formatting-context/#version-fields","title":"Version fields","text":"current_version The current version serialized as a string current_<version part> Each version part defined by the version configuration parsing regular expression. The default configuration would have current_major, current_minor, and current_patch available. new_version The new version serialized as a string new_<version part> Each version part defined by the version configuration parsing regular expression. The default configuration would have new_major, new_minor, and new_patch available.

Note

The following fields are only available when serializing a version.

<version part> Each version part defined by the version configuration parsing regular expression. The default configuration would have major, minor, and patch available."},{"location":"reference/formatting-context/#environment-variables","title":"Environment variables","text":"

Every environment variable available at runtime is included with a $ prefix. For example if USER was in the environment, {$USER} would render that value.

Tip

If you use environment variables in your version serialization, you might want to ensure they are set by executing export VAR=value before running the bump-my-version command.

"},{"location":"reference/search-and-replace-config/","title":"Search and replace configuration","text":"

Bump-my-version uses a combination of template strings using a formatting context and regular expressions to search the configured files for the old or current version and replace the text with the new version.

Bump My Version defaults to using a simple string search. If the search template is not a valid regular expression or if the no-regex flag is True. The search template is always rendered using the formatting context. The basic logic is:

  1. Escape the formatting context for use in a regular expression.
  2. Render the search string using the escaped formatting context.
  3. Attempt to compile the rendered search string as a regular expression.
  4. If the rendered search string is a valid regular expression, use it.
  5. If the rendered search string is not a valid regular expression or the no-regex flag is True, use the search string rendered with the unescaped context.
"},{"location":"reference/search-and-replace-config/#using-template-strings","title":"Using template strings","text":"

Both the search and replace templates are rendered using the formatting context. However, only the search template is also treated as a regular expression. The replacement fields available in the formatting context are enclosed in curly braces {}.

The search and replace templates can be multiple lines, like so:

[tool.bumpversion]\ncurrent_version = \"1.2.3\"\n\n[[tool.bumpversion.files]]\nfilename = \"config.ini\"\nsearch = \"[myproject]\\nversion={current_version}\"\nreplace = \"[myproject]\\nversion={new_version}\"\n

Alternatively, using TOML\u2019s multiline strings:

[tool.bumpversion]\ncurrent_version = \"1.2.3\"\n\n[[tool.bumpversion.files]]\nfilename = \"config.ini\"\nsearch = \"\"\"\n[myproject]\nversion={current_version}\"\"\"\n\nreplace = \"\"\"\n[myproject]\nversion={new_version}\"\"\"\n
"},{"location":"reference/search-and-replace-config/#using-regular-expressions","title":"Using regular expressions","text":"

Only the search template will use Python\u2019s regular expression syntax with minor changes. The template string is rendered using the formatting context. The resulting string is treated as a regular expression for searching unless configured otherwise.

Curly braces ({}) must be doubled in the regular expression to escape them from the string-formatting process.

If you are using a TOML-formatted configuration file, you must also escape backslashes (\\) in the regular expression. The TOML parser will treat a single backslash as an escape character.

The following template:

TOMLCFG
search = \"{current_version} date-released: \\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}\"\n
search = \"{current_version} date-released: \\d{{4}}-\\d{{2}}-\\d{{2}}\"\n

Gets rendered to:

1\\.2\\.3 date-released: \\d{4}-\\d{2}-\\d{2}\n

This string is used as a regular expression pattern to search.

"},{"location":"reference/search-and-replace-config/#regular-expression-special-characters","title":"Regular expression special characters","text":"

The ., ^, $, *, +, ?, (), [], {}, \\, | characters are special characters in regular expressions. If your search string contains these characters, you must escape them with a backslash (\\) to treat them as literal characters or set the no-regex flag to True.

For example, if you are looking for this string in a file:

[Unreleased] 2023-07-17\n

and you use this search pattern:

[Unreleased] \\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}\n

Bump My Version will not find the string. While the rendered regular expression [Unreleased] \\d{4}-\\d{2}-\\d{2} is valid, it is not searching for the literal [Unreleased]. Instead, it matches a single character in the list U, n, r, e, l, a, s, d.

You must escape the [ and ] to treat them as literal characters:

\\[Unreleased\\] \\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}\n
"},{"location":"reference/version-parts/","title":"Version parts","text":"
  • The version string is the rendering of some or all version parts.
  • While the version string may be rendered differently in various places, the value for all parts is maintained in Bump My Version\u2019s configuration.
  • The version parts are typically dependent on each other. Incrementing one part might change other elements.
  • You can compare two version strings (of the same project) and know which is more recent.
"},{"location":"reference/version-parts/#version-configuration","title":"Version configuration","text":"

A version configuration consists of the following:

  • A regular expression that will parse all the possible parts and name them
  • A list of one or more serialization formats

A version string consists of one or more parts; e.g., version 1.0.2 has three parts, separated by a dot (.) character.

The names of these parts are defined in the named groups within the parse regular expression. The default configuration calls them major, minor, and patch.

The serialize configuration value is a list of default formats. You have the option for multiple serialization formats to omit optional values. For example, the following configuration:

serialize = [\n    \"{major}.{minor}.{patch}\",\n    \"{major}.{minor}\",\n]\n

Bump-my-version will serialize using the first format if the patch value is not 0. If the patch value is 0, Bump My Version will use the second format.

"},{"location":"reference/version-parts/#version-part-configuration","title":"Version part configuration","text":"

A version part configuration consists of the following:

  • An incrementing function
  • An optional value
  • A first value
  • A flag indicating its dependence or independence of changes to other version parts
"},{"location":"reference/version-parts/#incrementing-functions","title":"Incrementing functions","text":"

There are two incrementing functions: numeric and value. The numeric function uses integer values and returns the next integer value. The values function uses a sequence of values and returns the next value until finished.

By default, parts use the numeric function starting at 0.

You can configure a part using the values function by providing a list of values in the version part\u2019s configuration. For example, for the release_name part:

[tool.bumpversion.parts.release_name]\nvalues = [\n    \"witty-warthog\", \n    \"ridiculous-rat\", \n    \"marvelous-mantis\",\n]\n
"},{"location":"reference/version-parts/#optional-values","title":"Optional values","text":"

By default, the first value of a version part is considered optional. An optional value may be omitted from the version serialization. Using the example from above:

serialize = [\n    \"{major}.{minor}.{patch}\",\n    \"{major}.{minor}\",\n]\n

Version 1.4.0 is rendered as 1.4 since the patch is 0; as the first value, it is optional.

Optional values are helpful for non-numeric version parts that indicate development stages, such as alpha or beta.

Example:

[tool.bumpversion]\ncurrent_version = \"1.0.0\"\nparse = \"\"\"(?x)\n    (?P<major>[0-9]+)\n    \\\\.(?P<minor>[0-9]+)\n    \\\\.(?P<patch>[0-9]+)\n    (?:\n        -(?P<pre_label>alpha|beta|stable)\n        (?:-(?P<pre_n>[0-9]+))?\n    )?\n\"\"\"\nserialize = [\n    \"{major}.{minor}.{patch}-{pre_label}-{pre_n}\",\n    \"{major}.{minor}.{patch}\",\n]\n\n[tool.bumpversion.parts.pre_label]\noptional_value = \"stable\"\nvalues =[\n    \"alpha\",\n    \"beta\",\n    \"stable\",\n]\n

Bumping the patch part of version 1.0.0 would change the version to 1.0.1-alpha-0. Bumping the pre_label part would change the version to 1.0.1-beta-0. Bumping the pre_label part again would change the version to 1.0.1. The stable-0 is not serialized because both stable and 0 are optional.

"},{"location":"reference/version-parts/#first-values","title":"First Values","text":"

You can specify the starting number with the first_value configuration for numeric version parts.

For example, if we added the following to the above configuration:

[tool.bumpversion.parts.pre_n]\nfirst_value = \"1\"\n

Bumping the patch value of version 1.0.0 would change the version to 1.0.1-alpha-1 instead of 1.0.1-alpha-0.

"},{"location":"reference/version-parts/#independent-values","title":"Independent Values","text":"

In the pattern {major}.{minor}.{patch}-{pre_label}-{pre_n}, each version part resets to its first value when the element preceding it changes. All these version parts are dependent.

You can include a value that incremented independently from the other parts, such as a build part: {major}.{minor}.{patch}-{pre_label}-{pre_n}+{build}\u2014in the configuration for that part, set independent=true.

[tool.bumpversion.parts.build]\nindependent = true\n
"},{"location":"reference/version-parts/#reference","title":"Reference","text":"
  • https://devopedia.org/semantic-versioning
  • https://semver.org
  • https://calver.org
"},{"location":"reference/api/SUMMARY/","title":"SUMMARY","text":"
  • bumpversion * aliases * autocast * bump * cli * config * create * files * files_legacy * models * utils * context * exceptions * files * indented_logger * scm * show * ui * utils * version_part * versioning * conventions * functions * models * serialization * visualize * yaml_dump
"},{"location":"reference/api/bumpversion/","title":"Index","text":""},{"location":"reference/api/bumpversion/aliases/","title":" aliases","text":"

Utilities for handling command aliases.

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup","title":"AliasedGroup","text":"

Bases: RichGroup

This following example implements a subclass of Group that accepts a prefix for a command.

If there were a command called push, it would accept pus as an alias (so long as it was unique)

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup.get_command","title":"get_command","text":"
get_command(\n    ctx: Context, cmd_name: str\n) -> Optional[click.Command]\n

Given a context and a command name, this returns a Command object if it exists or returns None.

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup.resolve_command","title":"resolve_command","text":"
resolve_command(ctx: Context, args: List[str]) -> tuple\n

Find the command and make sure the full command name is returned.

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/autocast/","title":" autocast","text":"

Automatically detect the true Python type of a string and cast it to the correct type.

Based on https://github.com/cgreer/cgAutoCast/blob/master/cgAutoCast.py

Only used by Legacy configuration file parser.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.autocast_value","title":"autocast_value","text":"
autocast_value(var: Any) -> Any\n

Guess the string representation of the variable\u2019s type.

Parameters:

var

Value to autocast.

TYPE: Any

Returns:

Any

The autocasted value.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.boolify","title":"boolify","text":"
boolify(s: str) -> bool\n

Convert a string to a boolean.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.listify","title":"listify","text":"
listify(s: str) -> list\n

Convert a string representation of a list into list of homogeneous basic types.

Type of elements in list is determined via first element. Successive elements are cast to that type.

Parameters:

s

String representation of a list.

TYPE: str

Raises:

ValueError

If string does not represent a list.

TypeError

If string does not represent a list of homogeneous basic types.

Returns:

list

List of homogeneous basic types.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.noneify","title":"noneify","text":"
noneify(s: str) -> None\n

Convert a string to None.

"},{"location":"reference/api/bumpversion/bump/","title":" bump","text":"

Version changing methods.

"},{"location":"reference/api/bumpversion/bump/#bumpversion.bump-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/bump/#bumpversion.bump-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/bump/#bumpversion.bump.commit_and_tag","title":"commit_and_tag","text":"
commit_and_tag(\n    config: Config,\n    config_file: Optional[Path],\n    configured_files: List[ConfiguredFile],\n    ctx: ChainMap,\n    dry_run: bool = False,\n) -> None\n

Commit and tag the changes if a tool is configured.

Parameters:

config

The configuration

TYPE: Config

config_file

The configuration file to include in the commit, if it exists

TYPE: Optional[Path]

configured_files

A list of files to commit

TYPE: List[ConfiguredFile]

ctx

The context used to render the tag and tag message

TYPE: ChainMap

dry_run

True if the operation should be a dry run

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/bump/#bumpversion.bump.do_bump","title":"do_bump","text":"
do_bump(\n    version_part: Optional[str],\n    new_version: Optional[str],\n    config: Config,\n    config_file: Optional[Path] = None,\n    dry_run: bool = False,\n) -> None\n

Bump the version_part to the next value or set the version to new_version.

Parameters:

version_part

The version part to bump

TYPE: Optional[str]

new_version

The explicit version to set

TYPE: Optional[str]

config

The configuration to use

TYPE: Config

config_file

The configuration file to update

TYPE: Optional[Path]

DEFAULT: None

dry_run

True if the operation should be a dry run

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/bump/#bumpversion.bump.get_next_version","title":"get_next_version","text":"
get_next_version(\n    current_version: Version,\n    config: Config,\n    version_part: Optional[str],\n    new_version: Optional[str],\n) -> Version\n

Bump the version_part to the next value.

Parameters:

current_version

The current version

TYPE: Version

config

The current configuration

TYPE: Config

version_part

Optional part of the version to bump

TYPE: Optional[str]

new_version

Optional specific version to bump to

TYPE: Optional[str]

Returns:

Version

The new version

Raises:

ConfigurationError

If it can\u2019t generate the next version.

"},{"location":"reference/api/bumpversion/cli/","title":" cli","text":"

bump-my-version Command line interface.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/cli/#bumpversion.cli-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.bump","title":"bump","text":"
bump(\n    args: list,\n    config_file: Optional[str],\n    verbose: int,\n    allow_dirty: Optional[bool],\n    current_version: Optional[str],\n    new_version: Optional[str],\n    parse: Optional[str],\n    serialize: Optional[List[str]],\n    search: Optional[str],\n    replace: Optional[str],\n    regex: Optional[bool],\n    no_configured_files: bool,\n    ignore_missing_files: bool,\n    ignore_missing_version: bool,\n    dry_run: bool,\n    commit: Optional[bool],\n    tag: Optional[bool],\n    sign_tags: Optional[bool],\n    tag_name: Optional[str],\n    tag_message: Optional[str],\n    message: Optional[str],\n    commit_args: Optional[str],\n) -> None\n

Change the version.

ARGS may contain any of the following:

VERSION_PART is the part of the version to increase, e.g. minor. Valid values include those given in the --serialize / --parse option.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.cli","title":"cli","text":"
cli(ctx: Context) -> None\n

Version bump your Python project.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.replace","title":"replace","text":"
replace(\n    files: list,\n    config_file: Optional[str],\n    verbose: int,\n    allow_dirty: Optional[bool],\n    current_version: Optional[str],\n    new_version: Optional[str],\n    parse: Optional[str],\n    serialize: Optional[List[str]],\n    search: Optional[str],\n    replace: Optional[str],\n    regex: bool,\n    no_configured_files: bool,\n    ignore_missing_version: bool,\n    ignore_missing_files: bool,\n    dry_run: bool,\n) -> None\n

Replace the version in files.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.sample_config","title":"sample_config","text":"
sample_config(prompt: bool, destination: str) -> None\n

Print a sample configuration file.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.show","title":"show","text":"
show(\n    args: List[str],\n    config_file: Optional[str],\n    format_: str,\n    increment: Optional[str],\n) -> None\n

Show current configuration information.

ARGS may contain one or more configuration attributes. For example:

  • bump-my-version show current_version
  • bump-my-version show files.0.filename
  • bump-my-version show scm_info.branch_name
  • bump-my-version show current_version scm_info.distance_to_latest_tag
"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.show_bump","title":"show_bump","text":"
show_bump(\n    version: str, config_file: Optional[str], ascii: bool\n) -> None\n

Show the possible versions resulting from the bump subcommand.

"},{"location":"reference/api/bumpversion/context/","title":" context","text":"

Context for rendering messages and tags.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/context/#bumpversion.context-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/context/#bumpversion.context.base_context","title":"base_context","text":"
base_context(\n    scm_info: Optional[SCMInfo] = None,\n) -> ChainMap\n

The default context for rendering messages and tags.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.calver_string_to_regex","title":"calver_string_to_regex","text":"
calver_string_to_regex(calver_format: str) -> str\n

Convert the calver format string to a regex pattern.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.get_context","title":"get_context","text":"
get_context(\n    config: Config,\n    current_version: Optional[Version] = None,\n    new_version: Optional[Version] = None,\n) -> ChainMap\n

Return the context for rendering messages and tags.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.get_datetime_info","title":"get_datetime_info","text":"
get_datetime_info(current_dt: datetime.datetime) -> dict\n

Return the full structure of the given datetime for formatting.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.prefixed_environ","title":"prefixed_environ","text":"
prefixed_environ() -> dict\n

Return a dict of the environment with keys wrapped in ${}.

"},{"location":"reference/api/bumpversion/exceptions/","title":" exceptions","text":"

Custom exceptions for BumpVersion.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.BadInputError","title":"BadInputError","text":"
BadInputError(message: str, ctx: Optional[Context] = None)\n

Bases: BumpVersionError

User input was bad.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.BumpVersionError","title":"BumpVersionError","text":"
BumpVersionError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: UsageError

Custom base class for all BumpVersion exception types.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.ConfigurationError","title":"ConfigurationError","text":"
ConfigurationError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

A configuration key-value is missing or in the wrong type.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.DirtyWorkingDirectoryError","title":"DirtyWorkingDirectoryError","text":"
DirtyWorkingDirectoryError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

The working directory is dirty, and it is not allowed.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.FormattingError","title":"FormattingError","text":"
FormattingError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

We are unable to represent a version required by a format.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.InvalidVersionPartError","title":"InvalidVersionPartError","text":"
InvalidVersionPartError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

The specified part (e.g. \u2018bugfix\u2019) was not found.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.MissingValueError","title":"MissingValueError","text":"
MissingValueError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

A part required for a version format is empty.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.SignedTagsError","title":"SignedTagsError","text":"
SignedTagsError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

The VCS does not support signed tags.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.VersionNotFoundError","title":"VersionNotFoundError","text":"
VersionNotFoundError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

A version number was not found in a source file.

"},{"location":"reference/api/bumpversion/files/","title":" files","text":"

Methods for changing files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile","title":"ConfiguredFile","text":"
ConfiguredFile(\n    file_change: FileChange,\n    version_config: VersionConfig,\n    search: Optional[str] = None,\n    replace: Optional[str] = None,\n)\n

A file to modify in a configured way.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile.get_file_contents","title":"get_file_contents","text":"
get_file_contents() -> str\n

Return the contents of the file.

Raises:

FileNotFoundError

if the file doesn\u2019t exist

Returns:

str

The contents of the file

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile.make_file_change","title":"make_file_change","text":"
make_file_change(\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Make the change to the file.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile.write_file_contents","title":"write_file_contents","text":"
write_file_contents(contents: str) -> None\n

Write the contents of the file.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.DataFileUpdater","title":"DataFileUpdater","text":"
DataFileUpdater(\n    file_change: FileChange,\n    version_part_configs: Dict[str, VersionComponentSpec],\n)\n

A class to handle updating files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.DataFileUpdater-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.DataFileUpdater.update_file","title":"update_file","text":"
update_file(\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Update the files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.FileUpdater","title":"FileUpdater","text":"
FileUpdater(\n    file_change: FileChange,\n    version_config: VersionConfig,\n    search: Optional[str] = None,\n    replace: Optional[str] = None,\n)\n

A class to handle updating files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.FileUpdater-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.FileUpdater.update_file","title":"update_file","text":"
update_file(\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Update the files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.contains_pattern","title":"contains_pattern","text":"
contains_pattern(search: re.Pattern, contents: str) -> bool\n

Does the search pattern match any part of the contents?

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.log_changes","title":"log_changes","text":"
log_changes(\n    file_path: str,\n    file_content_before: str,\n    file_content_after: str,\n    dry_run: bool = False,\n) -> None\n

Log the changes that would be made to the file.

Parameters:

file_path

The path to the file

TYPE: str

file_content_before

The file contents before the change

TYPE: str

file_content_after

The file contents after the change

TYPE: str

dry_run

True if this is a report-only job

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.modify_files","title":"modify_files","text":"
modify_files(\n    files: List[ConfiguredFile],\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Modify the files, searching and replacing values according to the FileConfig.

Parameters:

files

The list of configured files

TYPE: List[ConfiguredFile]

current_version

The current version

TYPE: Version

new_version

The next version

TYPE: Version

context

The context used for rendering the version

TYPE: MutableMapping

dry_run

True if this should be a report-only job

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.resolve_file_config","title":"resolve_file_config","text":"
resolve_file_config(\n    files: List[FileChange],\n    version_config: VersionConfig,\n    search: Optional[str] = None,\n    replace: Optional[str] = None,\n) -> List[ConfiguredFile]\n

Resolve the files, searching and replacing values according to the FileConfig.

Parameters:

files

A list of file configurations

TYPE: List[FileChange]

version_config

How the version should be changed

TYPE: VersionConfig

search

The search pattern to use instead of any configured search pattern

TYPE: Optional[str]

DEFAULT: None

replace

The replace pattern to use instead of any configured replace pattern

TYPE: Optional[str]

DEFAULT: None

Returns:

List[ConfiguredFile]

A list of ConfiguredFiles

"},{"location":"reference/api/bumpversion/indented_logger/","title":" indented_logger","text":"

A logger adapter that adds an indent to the beginning of each message.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter","title":"IndentedLoggerAdapter","text":"
IndentedLoggerAdapter(\n    logger: logging.Logger,\n    extra: Optional[dict] = None,\n    depth: int = 2,\n    indent_char: str = \" \",\n    reset: bool = False,\n)\n

Bases: LoggerAdapter

Logger adapter that adds an indent to the beginning of each message.

Parameters:

logger

The logger to adapt.

TYPE: Logger

extra

Extra values to add to the logging context.

TYPE: Optional[dict]

DEFAULT: None

depth

The number of indent_char to generate for each indent level.

TYPE: int

DEFAULT: 2

indent_char

The character or string to use for indenting.

TYPE: str

DEFAULT: ' '

reset

True if the indent level should be reset to zero.

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.current_indent","title":"current_indent property","text":"
current_indent: int\n

The current indent level.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.indent_str","title":"indent_str property","text":"
indent_str: str\n

The indent string.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.dedent","title":"dedent","text":"
dedent(amount: int = 1) -> None\n

Decrease the indent level by amount.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.indent","title":"indent","text":"
indent(amount: int = 1) -> None\n

Increase the indent level by amount.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.process","title":"process","text":"
process(\n    msg: str, kwargs: Optional[MutableMapping[str, Any]]\n) -> Tuple[str, MutableMapping[str, Any]]\n

Process the message and add the indent.

Parameters:

msg

The logging message.

TYPE: str

kwargs

Keyword arguments passed to the logger.

TYPE: Optional[MutableMapping[str, Any]]

Returns:

Tuple[str, MutableMapping[str, Any]]

A tuple containing the message and keyword arguments.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.reset","title":"reset","text":"
reset() -> None\n

Reset the indent level to zero.

"},{"location":"reference/api/bumpversion/scm/","title":" scm","text":"

Version control system management.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git","title":"Git","text":"

Bases: SourceCodeManager

Git implementation.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.add_path","title":"add_path classmethod","text":"
add_path(path: Union[str, Path]) -> None\n

Add a path to the VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.assert_nondirty","title":"assert_nondirty classmethod","text":"
assert_nondirty() -> None\n

Assert that the working directory is not dirty.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.latest_tag_info","title":"latest_tag_info classmethod","text":"
latest_tag_info(\n    tag_name: str, parse_pattern: str\n) -> SCMInfo\n

Return information about the latest tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.tag","title":"tag classmethod","text":"
tag(\n    name: str,\n    sign: bool = False,\n    message: Optional[str] = None,\n) -> None\n

Create a tag of the new_version in VCS.

If only name is given, bumpversion uses a lightweight tag. Otherwise, it utilizes an annotated tag.

Parameters:

name

The name of the tag

TYPE: str

sign

True to sign the tag

TYPE: bool

DEFAULT: False

message

An optional message to annotate the tag.

TYPE: Optional[str]

DEFAULT: None

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial","title":"Mercurial","text":"

Bases: SourceCodeManager

Mercurial implementation.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.add_path","title":"add_path classmethod","text":"
add_path(path: Union[str, Path]) -> None\n

Add a path to the VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.assert_nondirty","title":"assert_nondirty classmethod","text":"
assert_nondirty() -> None\n

Assert that the working directory is clean.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.latest_tag_info","title":"latest_tag_info classmethod","text":"
latest_tag_info(\n    tag_name: str, parse_pattern: str\n) -> SCMInfo\n

Return information about the latest tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.tag","title":"tag classmethod","text":"
tag(\n    name: str,\n    sign: bool = False,\n    message: Optional[str] = None,\n) -> None\n

Create a tag of the new_version in VCS.

If only name is given, bumpversion uses a lightweight tag. Otherwise, it utilizes an annotated tag.

Parameters:

name

The name of the tag

TYPE: str

sign

True to sign the tag

TYPE: bool

DEFAULT: False

message

A optional message to annotate the tag.

TYPE: Optional[str]

DEFAULT: None

Raises:

SignedTagsError

If sign is True

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SCMInfo","title":"SCMInfo dataclass","text":"
SCMInfo(\n    tool: Optional[Type[SourceCodeManager]] = None,\n    commit_sha: Optional[str] = None,\n    distance_to_latest_tag: int = 0,\n    current_version: Optional[str] = None,\n    branch_name: Optional[str] = None,\n    short_branch_name: Optional[str] = None,\n    dirty: Optional[bool] = None,\n)\n

Information about the current source code manager and state.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager","title":"SourceCodeManager","text":"

Base class for version control systems.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.add_path","title":"add_path classmethod","text":"
add_path(path: Union[str, Path]) -> None\n

Add a path to the VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.assert_nondirty","title":"assert_nondirty classmethod","text":"
assert_nondirty() -> None\n

Assert that the working directory is not dirty.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.commit","title":"commit classmethod","text":"
commit(\n    message: str,\n    current_version: str,\n    new_version: str,\n    extra_args: Optional[list] = None,\n) -> None\n

Commit the changes.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.commit_to_scm","title":"commit_to_scm classmethod","text":"
commit_to_scm(\n    files: List[Union[str, Path]],\n    config: Config,\n    context: MutableMapping,\n    extra_args: Optional[List[str]] = None,\n    dry_run: bool = False,\n) -> None\n

Commit the files to the source code management system.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.format_and_raise_error","title":"format_and_raise_error classmethod","text":"
format_and_raise_error(\n    exc: Union[TypeError, subprocess.CalledProcessError]\n) -> None\n

Format the error message from an exception and re-raise it as a BumpVersionError.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.get_all_tags","title":"get_all_tags classmethod","text":"
get_all_tags() -> List[str]\n

Return all tags in VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.get_version_from_tag","title":"get_version_from_tag classmethod","text":"
get_version_from_tag(\n    tag: str, tag_name: str, parse_pattern: str\n) -> Optional[str]\n

Return the version from a tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.is_usable","title":"is_usable classmethod","text":"
is_usable() -> bool\n

Is the VCS implementation usable.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.latest_tag_info","title":"latest_tag_info classmethod","text":"
latest_tag_info(\n    tag_name: str, parse_pattern: str\n) -> SCMInfo\n

Return information about the latest tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.tag","title":"tag classmethod","text":"
tag(\n    name: str,\n    sign: bool = False,\n    message: Optional[str] = None,\n) -> None\n

Create a tag of the new_version in VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.tag_in_scm","title":"tag_in_scm classmethod","text":"
tag_in_scm(\n    config: Config,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Tag the current commit in the source code management system.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.get_scm_info","title":"get_scm_info","text":"
get_scm_info(tag_name: str, parse_pattern: str) -> SCMInfo\n

Return a dict with the latest source code management info.

"},{"location":"reference/api/bumpversion/show/","title":" show","text":"

Functions for displaying information about the version.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/show/#bumpversion.show-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/show/#bumpversion.show.do_show","title":"do_show","text":"
do_show(\n    *args,\n    config: Config,\n    format_: str = \"default\",\n    increment: Optional[str] = None\n) -> None\n

Show current version or configuration information.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.output_default","title":"output_default","text":"
output_default(value: dict) -> None\n

Output the value with key=value or just value if there is only one item.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.output_json","title":"output_json","text":"
output_json(value: dict) -> None\n

Output the value as json.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.output_yaml","title":"output_yaml","text":"
output_yaml(value: dict) -> None\n

Output the value as yaml.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.resolve_name","title":"resolve_name","text":"
resolve_name(\n    obj: Any,\n    name: str,\n    default: Any = None,\n    err_on_missing: bool = False,\n) -> Any\n

Get a key or attr name from obj or default value.

Copied and modified from Django Template variable resolutions

Resolution methods:

  • Mapping key lookup
  • Attribute lookup
  • Sequence index

Parameters:

obj

The object to access

TYPE: Any

name

A dotted name to the value, such as mykey.0.name

TYPE: str

default

If the name cannot be resolved from the object, return this value

TYPE: Any

DEFAULT: None

err_on_missing

Raise a BadInputError if the name cannot be resolved

TYPE: bool

DEFAULT: False

Returns:

Any

The value at the resolved name or the default value.

Raises:

BadInputError

If we cannot resolve the name and err_on_missing is True

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.resolve_name--noqa-dar401","title":"noqa: DAR401","text":""},{"location":"reference/api/bumpversion/ui/","title":" ui","text":"

Utilities for user interface.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/ui/#bumpversion.ui-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.get_indented_logger","title":"get_indented_logger","text":"
get_indented_logger(name: str) -> IndentedLoggerAdapter\n

Get a logger with indentation.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.print_error","title":"print_error","text":"
print_error(msg: str) -> None\n

Raise an error and exit.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.print_info","title":"print_info","text":"
print_info(msg: str) -> None\n

Echo a message to the console.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.print_warning","title":"print_warning","text":"
print_warning(msg: str) -> None\n

Echo a warning to the console.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.setup_logging","title":"setup_logging","text":"
setup_logging(verbose: int = 0) -> None\n

Configure the logging.

"},{"location":"reference/api/bumpversion/utils/","title":" utils","text":"

General utilities.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.extract_regex_flags","title":"extract_regex_flags","text":"
extract_regex_flags(regex_pattern: str) -> Tuple[str, str]\n

Extract the regex flags from the regex pattern.

Parameters:

regex_pattern

The pattern that might start with regex flags

TYPE: str

Returns:

Tuple[str, str]

A tuple of the regex pattern without the flag string and regex flag string

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.get_nested_value","title":"get_nested_value","text":"
get_nested_value(d: dict, path: str) -> Any\n

Retrieves the value of a nested key in a dictionary based on the given path.

Parameters:

d

The dictionary to search.

TYPE: dict

path

A string representing the path to the nested key, separated by periods.

TYPE: str

Returns:

Any

The value of the nested key.

Raises:

KeyError

If a key in the path does not exist.

ValueError

If an element in the path is not a dictionary.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.get_overrides","title":"get_overrides","text":"
get_overrides(**kwargs) -> dict\n

Return a dictionary containing only the overridden key-values.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.key_val_string","title":"key_val_string","text":"
key_val_string(d: dict) -> str\n

Render the dictionary as a comma-delimited key=value string.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.labels_for_format","title":"labels_for_format","text":"
labels_for_format(serialize_format: str) -> List[str]\n

Return a list of labels for the given serialize_format.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.recursive_sort_dict","title":"recursive_sort_dict","text":"
recursive_sort_dict(input_value: Any) -> Any\n

Sort a dictionary recursively.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.set_nested_value","title":"set_nested_value","text":"
set_nested_value(d: dict, value: Any, path: str) -> None\n

Sets the value of a nested key in a dictionary based on the given path.

Parameters:

d

The dictionary to search.

TYPE: dict

value

The value to set.

TYPE: Any

path

A string representing the path to the nested key, separated by periods.

TYPE: str

Raises:

ValueError

If an element in the path is not a dictionary.

"},{"location":"reference/api/bumpversion/version_part/","title":" version_part","text":"

Module for managing Versions and their internal parts.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig","title":"VersionConfig","text":"
VersionConfig(\n    parse: str,\n    serialize: Tuple[str],\n    search: str,\n    replace: str,\n    part_configs: Optional[\n        Dict[str, VersionComponentSpec]\n    ] = None,\n)\n

Hold a complete representation of a version string.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig.order","title":"order property","text":"
order: List[str]\n

Return the order of the labels in a serialization format.

Currently, order depends on the first given serialization format. This seems like a good idea because this should be the most complete format.

Returns:

List[str]

A list of version part labels in the order they should be rendered.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig.parse","title":"parse","text":"
parse(\n    version_string: Optional[str] = None,\n) -> Optional[Version]\n

Parse a version string into a Version object.

Parameters:

version_string

Version string to parse

TYPE: Optional[str]

DEFAULT: None

Returns:

Optional[Version]

A Version object representing the string.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig.serialize","title":"serialize","text":"
serialize(version: Version, context: MutableMapping) -> str\n

Serialize a version to a string.

Parameters:

version

The version to serialize

TYPE: Version

context

The context to use when serializing the version

TYPE: MutableMapping

Returns:

str

The serialized version as a string

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/visualize/","title":" visualize","text":"

Visualize the bumpversion process.

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.Border","title":"Border dataclass","text":"
Border(\n    corner_bottom_right: str,\n    corner_top_right: str,\n    corner_top_left: str,\n    corner_bottom_left: str,\n    divider_left: str,\n    divider_up: str,\n    divider_down: str,\n    divider_right: str,\n    line: str,\n    pipe: str,\n    cross: str,\n)\n

A border definition.

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.connection_str","title":"connection_str","text":"
connection_str(\n    border: Border,\n    has_next: bool = False,\n    has_previous: bool = False,\n) -> str\n

Return the correct connection string based on the next and previous.

Parameters:

border

The border definition to draw the lines

TYPE: Border

has_next

If True, there is a next line

TYPE: bool

DEFAULT: False

has_previous

If True, there is a previous line

TYPE: bool

DEFAULT: False

Returns:

str

A string that connects left-to-right and top-to-bottom based on the next and previous

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.filter_version_parts","title":"filter_version_parts","text":"
filter_version_parts(config: Config) -> List[str]\n

Return the version parts that are in the configuration.

Parameters:

config

The configuration to check against

TYPE: Config

Returns:

List[str]

The version parts that are in the configuration

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.labeled_line","title":"labeled_line","text":"
labeled_line(\n    label: str,\n    border: Border,\n    fit_length: Optional[int] = None,\n) -> str\n

Return the version part string with the correct padding.

Parameters:

label

The label to render

TYPE: str

border

The border definition to draw the lines

TYPE: Border

fit_length

The length to fit the label to

TYPE: Optional[int]

DEFAULT: None

Returns:

str

A labeled line with leading and trailing spaces

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.lead_string","title":"lead_string","text":"
lead_string(\n    version_str: str, border: Border, blank: bool = False\n) -> str\n

Return the first part of a string with the bump character or spaces of the correct amount.

Examples:

>>> lead_string(\"1.0.0\", Border(*BOX_CHARS[\"light\"]))\n'1.0.0 \u2500\u2500 bump \u2500'\n>>> lead_string(\"1.0.0\", Border(*BOX_CHARS[\"light\"]), blank=True)\n'               '\n

Parameters:

version_str

The string to render as the starting point

TYPE: str

border

The border definition to draw the lines

TYPE: Border

blank

If True, return a blank string the same length as the version bump string

TYPE: bool

DEFAULT: False

Returns:

str

The version bump string or a blank string

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.visualize","title":"visualize","text":"
visualize(\n    config: Config,\n    version_str: str,\n    box_style: str = \"light\",\n) -> None\n

Output a visualization of the bump-my-version bump process.

"},{"location":"reference/api/bumpversion/yaml_dump/","title":" yaml_dump","text":"

A simple YAML dumper to avoid extra dependencies.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.YAMLDumpers","title":"YAMLDumpers","text":"

Bases: UserDict

Registry of YAML dumpers.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.YAMLDumpers-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.YAMLDumpers.add_dumper","title":"add_dumper","text":"
add_dumper(data_type: type, dumper: DumperFunc) -> None\n

Add a YAML dumper.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.dump","title":"dump","text":"
dump(data: Any) -> str\n

Dump a value to a string buffer.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_bool","title":"format_bool","text":"
format_bool(val: bool) -> str\n

Return a YAML representation of a bool.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_date","title":"format_date","text":"
format_date(val: datetime.date) -> str\n

Return a YAML representation of a date.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_datetime","title":"format_datetime","text":"
format_datetime(val: datetime.datetime) -> str\n

Return a string representation of a value.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_dict","title":"format_dict","text":"
format_dict(val: dict) -> str\n

Return a YAML representation of a dict.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_float","title":"format_float","text":"
format_float(data: float) -> str\n

Return a YAML representation of a float.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_int","title":"format_int","text":"
format_int(val: int) -> str\n

Return a YAML representation of an int.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_none","title":"format_none","text":"
format_none(_: None) -> str\n

Return a YAML representation of None.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_sequence","title":"format_sequence","text":"
format_sequence(val: Union[list, tuple]) -> str\n

Return a string representation of a value.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_str","title":"format_str","text":"
format_str(val: str) -> str\n

Return a YAML representation of a string.

"},{"location":"reference/api/bumpversion/config/","title":"Index","text":"

Configuration management.

"},{"location":"reference/api/bumpversion/config/#bumpversion.config-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/#bumpversion.config-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/#bumpversion.config.check_current_version","title":"check_current_version","text":"
check_current_version(config: Config) -> str\n

Returns the current version.

If the current version is not specified in the config file, command line or env variable, it attempts to retrieve it via a tag.

Parameters:

config

The current configuration dictionary.

TYPE: Config

Returns:

str

The version number

Raises:

ConfigurationError

If it can\u2019t find the current version

"},{"location":"reference/api/bumpversion/config/#bumpversion.config.get_configuration","title":"get_configuration","text":"
get_configuration(\n    config_file: Union[str, Path, None] = None,\n    **overrides: Any\n) -> Config\n

Return the configuration based on any configuration files and overrides.

Parameters:

config_file

An explicit configuration file to use, otherwise search for one

TYPE: Union[str, Path, None]

DEFAULT: None

**overrides

Specific configuration key-values to override in the configuration

TYPE: Any

DEFAULT: {}

Returns:

Config

The configuration

"},{"location":"reference/api/bumpversion/config/#bumpversion.config.set_config_defaults","title":"set_config_defaults","text":"
set_config_defaults(\n    parsed_config: dict[str, Any], **overrides: Any\n) -> dict[str, Any]\n

Apply the defaults to the parsed config.

"},{"location":"reference/api/bumpversion/config/create/","title":" create","text":"

Module for creating a new config file.

"},{"location":"reference/api/bumpversion/config/create/#bumpversion.config.create-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/create/#bumpversion.config.create.create_configuration","title":"create_configuration","text":"
create_configuration(\n    destination: str, prompt: bool\n) -> TOMLDocument\n

Create a new configuration as a TOMLDocument.

Parameters:

destination

stdout or a path to a new or existing file.

TYPE: str

prompt

True if the user should be prompted for input.

TYPE: bool

Returns:

TOMLDocument

The TOMLDocument structure with the updated configuration.

"},{"location":"reference/api/bumpversion/config/create/#bumpversion.config.create.get_defaults_from_dest","title":"get_defaults_from_dest","text":"
get_defaults_from_dest(\n    destination: str,\n) -> Tuple[dict, TOMLDocument]\n

Get the default configuration and the configuration from the destination.

"},{"location":"reference/api/bumpversion/config/files/","title":" files","text":"

Contains methods for finding and reading configuration files.

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.find_config_file","title":"find_config_file","text":"
find_config_file(\n    explicit_file: Union[str, Path, None] = None\n) -> Union[Path, None]\n

Find the configuration file, if it exists.

If no explicit configuration file is passed, it will search in several files to find its configuration.

Parameters:

explicit_file

The configuration file to explicitly use.

TYPE: Union[str, Path, None]

DEFAULT: None

Returns:

Union[Path, None]

The configuration file path

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.read_config_file","title":"read_config_file","text":"
read_config_file(\n    config_file: Union[str, Path, None] = None\n) -> Dict[str, Any]\n

Read the configuration file, if it exists.

If no explicit configuration file is passed, it will search in several files to find its configuration.

Parameters:

config_file

The configuration file to explicitly use.

TYPE: Union[str, Path, None]

DEFAULT: None

Returns:

Dict[str, Any]

A dictionary of read key-values

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.read_toml_file","title":"read_toml_file","text":"
read_toml_file(file_path: Path) -> Dict[str, Any]\n

Parse a TOML file and return the bumpversion section.

Parameters:

file_path

The path to the TOML file.

TYPE: Path

Returns:

dict

A dictionary of the bumpversion section.

TYPE: Dict[str, Any]

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.update_config_file","title":"update_config_file","text":"
update_config_file(\n    config_file: Union[str, Path],\n    config: Config,\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Update the current_version key in the configuration file.

Parameters:

config_file

The configuration file to explicitly use.

TYPE: Union[str, Path]

config

The configuration to use.

TYPE: Config

current_version

The current version.

TYPE: Version

new_version

The new version.

TYPE: Version

context

The context to use for serialization.

TYPE: MutableMapping

dry_run

True if the update should be a dry run.

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/config/files_legacy/","title":" files_legacy","text":"

This module handles the legacy config file format.

"},{"location":"reference/api/bumpversion/config/files_legacy/#bumpversion.config.files_legacy-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/files_legacy/#bumpversion.config.files_legacy.read_ini_file","title":"read_ini_file","text":"
read_ini_file(file_path: Path) -> Dict[str, Any]\n

Parse an INI file and return a dictionary of sections and their options.

Parameters:

file_path

The path to the INI file.

TYPE: Path

Returns:

dict

A dictionary of sections and their options.

TYPE: Dict[str, Any]

"},{"location":"reference/api/bumpversion/config/files_legacy/#bumpversion.config.files_legacy.update_ini_config_file","title":"update_ini_config_file","text":"
update_ini_config_file(\n    config_file: Union[str, Path],\n    current_version: str,\n    new_version: str,\n    dry_run: bool = False,\n) -> None\n

Update the current_version key in the configuration file.

Instead of parsing and re-writing the config file with new information, it will use a regular expression to just replace the current_version value. The idea is it will avoid unintentional changes (like formatting) to the config file.

Parameters:

config_file

The configuration file to explicitly use.

TYPE: Union[str, Path]

current_version

The serialized current version.

TYPE: str

new_version

The serialized new version.

TYPE: str

dry_run

True if the update should be a dry run.

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/config/models/","title":" models","text":"

Bump My Version configuration models.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config","title":"Config","text":"

Bases: BaseSettings

Bump Version configuration.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.files_to_modify","title":"files_to_modify property","text":"
files_to_modify: List[FileChange]\n

Return a list of files to modify.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.resolved_filemap","title":"resolved_filemap property","text":"
resolved_filemap: Dict[str, List[FileChange]]\n

Return the cached resolved filemap.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.version_config","title":"version_config property","text":"
version_config: 'VersionConfig'\n

Return the version configuration.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.add_files","title":"add_files","text":"
add_files(filename: Union[str, List[str]]) -> None\n

Add a filename to the list of files.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.version_spec","title":"version_spec","text":"
version_spec(\n    version: Optional[str] = None,\n) -> \"VersionSpec\"\n

Return the version specification.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange","title":"FileChange","text":"

Bases: BaseModel

A change to make to a file.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange.__hash__","title":"__hash__","text":"
__hash__()\n

Return a hash of the model.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange.get_search_pattern","title":"get_search_pattern","text":"
get_search_pattern(\n    context: MutableMapping,\n) -> Tuple[re.Pattern, str]\n

Render the search pattern and return the compiled regex pattern and the raw pattern.

Parameters:

context

The context to use for rendering the search pattern

TYPE: MutableMapping

Returns:

Tuple[Pattern, str]

A tuple of the compiled regex pattern and the raw pattern as a string.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/utils/","title":" utils","text":"

Helper functions for the config module.

"},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils.get_all_file_configs","title":"get_all_file_configs","text":"
get_all_file_configs(config_dict: dict) -> List[FileChange]\n

Make sure all version parts are included.

"},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils.get_all_part_configs","title":"get_all_part_configs","text":"
get_all_part_configs(\n    config_dict: dict,\n) -> Dict[str, VersionComponentSpec]\n

Make sure all version parts are included.

"},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils.resolve_glob_files","title":"resolve_glob_files","text":"
resolve_glob_files(\n    file_cfg: FileChange,\n) -> List[FileChange]\n

Return a list of file configurations that match the glob pattern.

Parameters:

file_cfg

The file configuration containing the glob pattern

TYPE: FileChange

Returns:

List[FileChange]

A list of resolved file configurations according to the pattern.

"},{"location":"reference/api/bumpversion/versioning/","title":"Index","text":"

Module for managing Versions and their internal parts.

"},{"location":"reference/api/bumpversion/versioning/conventions/","title":" conventions","text":"

Standard version conventions.

"},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions.pep440_version_spec","title":"pep440_version_spec","text":"
pep440_version_spec() -> VersionSpec\n

Return a VersionSpec for PEP 440.

"},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions.semver_spec","title":"semver_spec","text":"
semver_spec() -> VersionSpec\n

Return a VersionSpec for SEMVER.

"},{"location":"reference/api/bumpversion/versioning/functions/","title":" functions","text":"

Generators for version parts.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.CalVerFunction","title":"CalVerFunction","text":"
CalVerFunction(calver_format: str)\n

Bases: PartFunction

This is a class that provides a CalVer function for version parts.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.CalVerFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.CalVerFunction.bump","title":"bump","text":"
bump(value: Optional[str] = None) -> str\n

Return the optional value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.IndependentFunction","title":"IndependentFunction","text":"
IndependentFunction(value: Union[str, int, None] = None)\n

Bases: PartFunction

This is a class that provides an independent function for version parts.

It simply returns the optional value, which is equal to the first value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.IndependentFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.IndependentFunction.bump","title":"bump","text":"
bump(value: Optional[str] = None) -> str\n

Return the optional value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.NumericFunction","title":"NumericFunction","text":"
NumericFunction(\n    optional_value: Union[str, int, None] = None,\n    first_value: Union[str, int, None] = None,\n)\n

Bases: PartFunction

This is a class that provides a numeric function for version parts.

It simply starts with the provided first_value (0 by default) and increases it following the sequence of integer numbers.

The optional value of this function is equal to the first value.

This function also supports alphanumeric parts, altering just the numeric part (e.g. \u2018r3\u2019 \u2013> \u2018r4\u2019). Only the first numeric group found in the part is considered (e.g. \u2018r3-001\u2019 \u2013> \u2018r4-001\u2019).

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.NumericFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.NumericFunction.bump","title":"bump","text":"
bump(value: Union[str, int]) -> str\n

Increase the first numerical value by one.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.PartFunction","title":"PartFunction","text":"

Base class for a version part function.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.PartFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.PartFunction.bump","title":"bump","text":"
bump(value: str) -> str\n

Increase the value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.ValuesFunction","title":"ValuesFunction","text":"
ValuesFunction(\n    values: List[str],\n    optional_value: Optional[str] = None,\n    first_value: Optional[str] = None,\n)\n

Bases: PartFunction

This is a class that provides a values list based function for version parts.

It is initialized with a list of values and iterates through them when bumping the part.

The default optional value of this function is equal to the first value, but may be otherwise specified.

When trying to bump a part which has already the maximum value in the list you get a ValueError exception.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.ValuesFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.ValuesFunction.bump","title":"bump","text":"
bump(value: str) -> str\n

Return the item after value in the list.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/","title":" models","text":"

Models for managing versioning of software projects.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version","title":"Version","text":"
Version(\n    version_spec: VersionSpec,\n    components: Dict[str, VersionComponent],\n    original: Optional[str] = None,\n)\n

The specification of a version and its parts.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version.bump","title":"bump","text":"
bump(component_name: str) -> 'Version'\n

Increase the value of the specified component, reset its dependents, and return a new Version.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version.required_components","title":"required_components","text":"
required_components() -> List[str]\n

Return the names of the parts that are required.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version.values","title":"values","text":"
values() -> Dict[str, VersionComponent]\n

Return the values of the parts.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent","title":"VersionComponent","text":"
VersionComponent(\n    values: Optional[list] = None,\n    optional_value: Optional[str] = None,\n    first_value: Union[str, int, None] = None,\n    independent: bool = False,\n    always_increment: bool = False,\n    calver_format: Optional[str] = None,\n    source: Optional[str] = None,\n    value: Union[str, int, None] = None,\n)\n

Represent part of a version number.

Determines the PartFunction that rules how the part behaves when increased or reset based on the configuration given.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.is_independent","title":"is_independent property","text":"
is_independent: bool\n

Is the part independent of the other parts?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.is_optional","title":"is_optional property","text":"
is_optional: bool\n

Is the part optional?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.value","title":"value property","text":"
value: str\n

Return the value of the part.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.bump","title":"bump","text":"
bump() -> 'VersionComponent'\n

Return a part with bumped value.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.copy","title":"copy","text":"
copy() -> 'VersionComponent'\n

Return a copy of the part.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.null","title":"null","text":"
null() -> 'VersionComponent'\n

Return a part with first value.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec","title":"VersionComponentSpec","text":"

Bases: BaseModel

Configuration of a version component.

This is used to read in the configuration from the bumpversion config file.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.always_increment","title":"always_increment class-attribute instance-attribute","text":"
always_increment: bool = False\n

Should the component always increment, even if it is not necessary?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.calver_format","title":"calver_format class-attribute instance-attribute","text":"
calver_format: Optional[str] = None\n

The format string for a CalVer component.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.depends_on","title":"depends_on class-attribute instance-attribute","text":"
depends_on: Optional[str] = None\n

The name of the component this component depends on.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.first_value","title":"first_value class-attribute instance-attribute","text":"
first_value: Union[str, int, None] = None\n

The first value to increment from.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.independent","title":"independent class-attribute instance-attribute","text":"
independent: bool = False\n

Is the component independent of the other components?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.optional_value","title":"optional_value class-attribute instance-attribute","text":"
optional_value: Optional[str] = None\n

The value that is optional to include in the version.

  • Defaults to first value in values or 0 in the case of numeric.
  • Empty string means nothing is optional.
  • CalVer components ignore this.
"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.values","title":"values class-attribute instance-attribute","text":"
values: Optional[list] = None\n

The possible values for the component. If it and calver_format is None, the component is numeric.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.create_component","title":"create_component","text":"
create_component(\n    value: Union[str, int, None] = None\n) -> VersionComponent\n

Generate a version component from the configuration.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.set_always_increment_with_calver","title":"set_always_increment_with_calver classmethod","text":"
set_always_increment_with_calver(data: Any) -> Any\n

Set always_increment to True if calver_format is present.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec","title":"VersionSpec","text":"
VersionSpec(\n    components: Dict[str, VersionComponentSpec],\n    order: Optional[List[str]] = None,\n)\n

The specification of a version\u2019s components and their relationships.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec.create_version","title":"create_version","text":"
create_version(values: Dict[str, str]) -> 'Version'\n

Generate a version from the given values.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec.get_dependents","title":"get_dependents","text":"
get_dependents(component_name: str) -> List[str]\n

Return the parts that depend on the given part.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/serialization/","title":" serialization","text":"

Functions for serializing and deserializing version objects.

"},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization.multisort","title":"multisort","text":"
multisort(xs: list, specs: tuple) -> list\n

Sort a list of dictionaries by multiple keys.

From https://docs.python.org/3/howto/sorting.html#sort-stability-and-complex-sorts

Parameters:

xs

The list of dictionaries to sort

TYPE: list

specs

A tuple of (key, reverse) pairs

TYPE: tuple

Returns:

list

The sorted list

"},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization.parse_version","title":"parse_version","text":"
parse_version(\n    version_string: str, parse_pattern: str\n) -> Dict[str, str]\n

Parse a version string into a dictionary of the parts and values using a regular expression.

Parameters:

version_string

Version string to parse

TYPE: str

parse_pattern

The regular expression pattern to use for parsing

TYPE: str

Returns:

Dict[str, str]

A dictionary of version part labels and their values, or an empty dictionary

Dict[str, str]

if the version string doesn\u2019t match.

Raises:

BumpVersionError

If the parse_pattern is not a valid regular expression

"},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization.serialize","title":"serialize","text":"
serialize(\n    version: Version,\n    serialize_patterns: List[str],\n    context: MutableMapping,\n) -> str\n

Attempts to serialize a version with the given serialization format.

  • valid serialization patterns are those that are renderable with the given context
  • formats that contain all required components are preferred
  • the shortest valid serialization pattern is used
  • if two patterns are equally short, the first one is used
  • if no valid serialization pattern is found, an error is raised

Parameters:

version

The version to serialize

TYPE: Version

serialize_patterns

The serialization format to use, using Python\u2019s format string syntax

TYPE: List[str]

context

The context to use when serializing the version

TYPE: MutableMapping

Raises:

FormattingError

if a serialization pattern

Returns:

str

The serialized version as a string

"},{"location":"reference/subcommands/","title":"Subcommand reference","text":"

Bump-my-version uses subcommands to focus its functionality.

  • bump triggers the version incrementing workflow
  • replace replaces the version in files without triggering a version increment.
  • sample-config helps new users configure bumpy-my-version by printing a sample configuration file.
  • show provides access to current configuration information.
  • show-bump helps developers understand the current versioning convention by showing the possible versions resulting from the bump subcommand.
"},{"location":"reference/subcommands/show/","title":"The show subcommand","text":"

The main purpose of the show subcommand is to provide access to configuration data via scripts.

"},{"location":"reference/subcommands/show/#basic-use","title":"Basic use","text":"

The configuration object is a dict containing nested data structures. The arguments and options of this command relate to extracting data from the configuration object and presenting the extracted data.

"},{"location":"reference/subcommands/show/#specifying-the-output-data","title":"Specifying the output data","text":"

The positional arguments determine the data shown. If nothing or all is passed, the entire configuration is shown.

Positional arguments are specified using a format like Django variable resolution.

Examples:

  • a.b specifies the \u201cb\u201d key in the nested dictionaries: {\"a\": {\"b\": \"value\"}}
  • a.3 specifies the 4th item (the first is 0) of the list at key \u201ca\u201d: {\"a\": [\"no\", \"nay\", \"nyet\", \"value\"]}
"},{"location":"reference/subcommands/show/#specifying-the-output-format","title":"Specifying the output format","text":"

If only one positional argument is passed, the default format only shows its value. If no positional arguments, several positional arguments, or all is passed, the output from pprint.pprint is shown.

This makes getting the current version easy:

$ bump-my-version show current_version\n1.0.1\n

You can request the output be formatted as YAML or JSON:

$ bump-my-version show --format yaml current_version\ncurrent_version: \"1.0.1\"\n$ bump-my-version show --format json current_version\n{\n  \"current_version\": \"1.0.1\"\n}\n
"},{"location":"reference/subcommands/show/#including-the-incremented-version-before-bumping","title":"Including the incremented version before bumping","text":"

Your workflow might want to know the new version before you actually do the bumping. The --increment or -i option accepts a version part to bump and adds a new_version key into the configuration.

$ bump-my-version --increment patch show\n1.0.2\n$ bump-my-version --increment minor show\n1.1.0\n$ bump-my-version --increment major show\n2.0.0\n
"},{"location":"tutorials/","title":"Tutorials","text":"
  • Versioning using semantic versioning
  • Basic usage
"},{"location":"tutorials/semantic-versioning-example/","title":"Semantic versioning example","text":""},{"location":"tutorials/semantic-versioning-example/#create-a-default-configuration","title":"Create a default configuration","text":"

The default configuration uses a simplified version of semantic versioning.

Generating a default configuration
$ bump-my-version sample-config --no-prompt --destination .bumpversion.toml\n$ cat .bumpversion.toml\n[tool.bumpversion]\ncurrent_version = \"0.1.0\"\nparse = \"(?P<major>\\\\d+)\\\\.(?P<minor>\\\\d+)\\\\.(?P<patch>\\\\d+)\"\nserialize = [\"{major}.{minor}.{patch}\"]\nsearch = \"{current_version}\"\nreplace = \"{new_version}\"\nregex = false\nignore_missing_version = false\ntag = false\nsign_tags = false\ntag_name = \"v{new_version}\"\ntag_message = \"Bump version: {current_version} \u2192 {new_version}\"\nallow_dirty = false\ncommit = false\nmessage = \"Bump version: {current_version} \u2192 {new_version}\"\ncommit_args = \"\"\n
"},{"location":"tutorials/semantic-versioning-example/#visualize-the-versioning-path","title":"Visualize the versioning path","text":"

You can see the potential versioning paths with the show-bump subcommand.

Showing the potential versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0\n               \u251c\u2500 minor \u2500 0.2.0\n               \u2570\u2500 patch \u2500 0.1.1\n$ bump-my-version show-bump 1.2.3\n1.2.3 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0\n               \u251c\u2500 minor \u2500 1.3.0\n               \u2570\u2500 patch \u2500 1.2.4\n

The default configuration only allows bumping the major, minor, or patch version. What if you wanted to support pre-release versions?

"},{"location":"tutorials/semantic-versioning-example/#add-support-for-pre-release-versions","title":"Add support for pre-release versions","text":"

Alter the parse configuration to support pre-release versions. This parse option uses an extended (or verbose) regular expression to extract the version parts from the current version.

New parse configuration
parse = \"\"\"(?x)\n    (?P<major>0|[1-9]\\\\d*)\\\\.\n    (?P<minor>0|[1-9]\\\\d*)\\\\.\n    (?P<patch>0|[1-9]\\\\d*)\n    (?:\n        -                             # dash separator for pre-release section\n        (?P<pre_l>[a-zA-Z-]+)         # pre-release label\n        (?P<pre_n>0|[1-9]\\\\d*)        # pre-release version number\n    )?                                # pre-release section is optional\n\"\"\"\n

Alter the serialize configuration to support pre-release versions.

New serialize configuration
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{pre_n}\",\n    \"{major}.{minor}.{patch}\",\n]\n

Add a new configuration section for the pre_l part.

New pre_l configuration
[tool.bumpversion.parts.pre_l]\nvalues = [\"dev\", \"rc\", \"final\"]\noptional_value = \"final\"\n
"},{"location":"tutorials/semantic-versioning-example/#visualize-the-new-versioning-path","title":"Visualize the new versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u251c\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n               \u2570\u2500 pre_n \u2500 0.1.0-final1\n

The pre_l is not bump-able because it is already at the maximum value. The pre_n is bump-able because it is not at the maximum value.

If we run bump-my-version show-bump 1.0.0-dev0, we can see the new versioning path for a dev starting version.

Showing the new versioning path for a dev version
$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u251c\u2500 pre_l \u2500 1.0.0-rc0\n                    \u2570\u2500 pre_n \u2500 1.0.0-dev1\n

Finally, we can see the new versioning path for a rc starting version.

Showing the new versioning path for an rc version
$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u251c\u2500 pre_l \u2500 1.0.0\n                   \u2570\u2500 pre_n \u2500 1.0.0-rc1\n

The full development and release path is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
  • bump pre_n \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
  • bump pre_n \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase using bump-my-version bump pre_n.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidates increase using bump-my-version bump pre_n.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"tutorials/semantic-versioning-example/#automate-the-pre-release-numbering","title":"Automate the pre-release numbering","text":"

The pre_n or pre-release number is a number that increases with each pre-release. You can automate this my changing the serialization configuration.

Serialize configuration with pre_n automation
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{distance_to_latest_tag}\",\n    \"{major}.{minor}.{patch}\",\n]\n

The distance_to_latest_tag is a special value that is replaced with the number of commits since the last tag. This is a good value to use for the pre_n because it will always increase with each commit.

"},{"location":"tutorials/semantic-versioning-example/#visualize-the-pre_n-versioning-path","title":"Visualize the pre_n versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path with pre_n automation
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u2570\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u2570\u2500 pre_l \u2500 1.0.0-rc0\n$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u2570\u2500 pre_l \u2500 1.0.0\n

The pre_n path is now missing because it is automated.

The full development and release path now is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
    • each commit will increase \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
    • each commit will increase \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase automatically with each commit.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidate versions increase automatically with each commit.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"tutorials/usage/","title":"Usage","text":"

There are two modes of operation: On the command line for single-file operation and using a configuration file (pyproject.toml or .bumpversion.toml) for more complex multi-file processes. We recommend using a configuration file for all but the simplest of projects.

Warning

The invocation of bump-my-version changed in version 0.6.0. It splits functionality into sub-commands. It remains backward-compatible with previous versions. Previous usage is discouraged and may be removed in a 1.0 release.

"},{"location":"tutorials/usage/#incrementing-a-version","title":"Incrementing a version","text":"
bump-my-version bump [OPTIONS] [ARGS]...\n

The bump sub-command triggers a version increment. The complete list of options is available. The ARGS may contain a VERSION_PART or FILES

"},{"location":"tutorials/usage/#version_part","title":"VERSION_PART","text":"

[optional]

The part of the version to increase, e.g., minor.

Valid values include those given in the --serialize / --parse option.

For example, if the current version is 0.5.1 and you want to bump it to 0.6.0:

bump-my-version bump minor\n
"},{"location":"tutorials/usage/#files","title":"FILES","text":"

[optional] default: None

The additional file(s) to modify.

This file is added to the list of files specified in the configuration file. If you want to rewrite only files specified on the command line, use --no-configured-files.

For example, if the current version is 1.1.9 and you want to bump the version to 2.0.0 and also change the version in the _version.txt file:

bump-my-version bump major _version.txt\n

If you want to bump the current version of 1.1.9 to 2.0.0\u00a0and only change the _version.txt file:

bump-my-version bump --no-configured-files major _version.txt\n
"},{"location":"tutorials/usage/#showing-configuration-information","title":"Showing configuration information","text":"
bump-my-version show [OPTIONS] [ARGS]\n

The show subcommand allows you to output the entire or parts of the configuration to the console. The default invocation will output in the default format. The default format changes if one or more than one item is requested. If more than one item is asked for, it outputs the result of Python\u2019s pprint function. If only one thing is asked for, it outputs that value only.

$ bump-my-version show current_version\n1.0.0\n$ bump-my-version show current_version commit\n{'current_version': '1.0.0', 'commit': False}\n

You can use the --increment option to enable a new_version key.

$ bump-my-version show --increment minor current_version new_version\n{'current_version': '1.0.0', 'new_version': '1.1.0'}\n

You can also specify the output to be in JSON or YAML format:

$ bump-my-version show --format yaml current_version\ncurrent_version: \"1.0.0\"\n$ bump-my-version show --format yaml current_version commit\ncurrent_version: \"1.0.0\"\ncommit: false\n$ bump-my-version show --format json current_version\n{\n  \"current_version\": \"1.0.0\"\n}\n$ bump-my-version show --format json current_version commit\n{\n  \"current_version\": \"1.0.0\",\n  \"commit\": false,\n}\n
"},{"location":"tutorials/usage/#searching-and-replacing-without-bumping","title":"Searching and replacing without bumping","text":"

More complex workflows may require you to change one or more files without changing the current_version in the configuration file.

The replace sub-command works identically to the bump sub-command except for the following:

  • It will not commit or tag any changes
  • It will not increment the version
  • It will not change the configuration file

```{admonition} NOTE

If you do not include the --new-version option, the new_version context variable will be None.

One way of providing the `--new-version` option is to use the `bump-my-version show` subcommand with an environment variable:\n\n```console\n$ export BUMPVERSION_NEW_VERSION=$(bump-my-version show new_version --increment <versionpart>)\n$ bump-my-version replace\n

"}]} \ No newline at end of file +{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"Bump My Version","text":""},{"location":"#overview","title":"Overview","text":"

Bump My Version\u2019s purpose is to:

  • Work as a part of an automated build system
  • Manage project versioning through the project\u2019s development life cycle - Incrementing version numbers - serializing version numbers - parsing version numbers - supporting SemVer, CalVer, and other versioning schemes
  • Modify project files as part of the project\u2019s development life cycle
  • Work with the project\u2019s source control system - Committing changes - Tagging releases - Reading version numbers from tags
"},{"location":"#installation","title":"Installation","text":"

You can download and install the latest version of this software from the Python package index (PyPI) as follows:

pip install --upgrade bump-my-version\n
"},{"location":"#changelog","title":"Changelog","text":"

Please find the changelog here: CHANGELOG.md

"},{"location":"#semantic-versioning-example","title":"Semantic versioning example","text":""},{"location":"#create-a-default-configuration","title":"Create a default configuration","text":"

The default configuration uses a simplified version of semantic versioning.

Generating a default configuration
$ bump-my-version sample-config --no-prompt --destination .bumpversion.toml\n$ cat .bumpversion.toml\n[tool.bumpversion]\ncurrent_version = \"0.1.0\"\nparse = \"(?P<major>\\\\d+)\\\\.(?P<minor>\\\\d+)\\\\.(?P<patch>\\\\d+)\"\nserialize = [\"{major}.{minor}.{patch}\"]\nsearch = \"{current_version}\"\nreplace = \"{new_version}\"\nregex = false\nignore_missing_version = false\ntag = false\nsign_tags = false\ntag_name = \"v{new_version}\"\ntag_message = \"Bump version: {current_version} \u2192 {new_version}\"\nallow_dirty = false\ncommit = false\nmessage = \"Bump version: {current_version} \u2192 {new_version}\"\ncommit_args = \"\"\n
"},{"location":"#visualize-the-versioning-path","title":"Visualize the versioning path","text":"

You can see the potential versioning paths with the show-bump subcommand.

Showing the potential versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0\n               \u251c\u2500 minor \u2500 0.2.0\n               \u2570\u2500 patch \u2500 0.1.1\n$ bump-my-version show-bump 1.2.3\n1.2.3 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0\n               \u251c\u2500 minor \u2500 1.3.0\n               \u2570\u2500 patch \u2500 1.2.4\n

The default configuration only allows bumping the major, minor, or patch version. What if you wanted to support pre-release versions?

"},{"location":"#add-support-for-pre-release-versions","title":"Add support for pre-release versions","text":"

Alter the parse configuration to support pre-release versions. This parse option uses an extended (or verbose) regular expression to extract the version parts from the current version.

New parse configuration
parse = \"\"\"(?x)\n    (?P<major>0|[1-9]\\\\d*)\\\\.\n    (?P<minor>0|[1-9]\\\\d*)\\\\.\n    (?P<patch>0|[1-9]\\\\d*)\n    (?:\n        -                             # dash separator for pre-release section\n        (?P<pre_l>[a-zA-Z-]+)         # pre-release label\n        (?P<pre_n>0|[1-9]\\\\d*)        # pre-release version number\n    )?                                # pre-release section is optional\n\"\"\"\n

Alter the serialize configuration to support pre-release versions.

New serialize configuration
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{pre_n}\",\n    \"{major}.{minor}.{patch}\",\n]\n

Add a new configuration section for the pre_l part.

New pre_l configuration
[tool.bumpversion.parts.pre_l]\nvalues = [\"dev\", \"rc\", \"final\"]\noptional_value = \"final\"\n
"},{"location":"#visualize-the-new-versioning-path","title":"Visualize the new versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u251c\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n               \u2570\u2500 pre_n \u2500 0.1.0-final1\n

The pre_l is not bump-able because it is already at the maximum value. The pre_n is bump-able because it is not at the maximum value.

If we run bump-my-version show-bump 1.0.0-dev0, we can see the new versioning path for a dev starting version.

Showing the new versioning path for a dev version
$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u251c\u2500 pre_l \u2500 1.0.0-rc0\n                    \u2570\u2500 pre_n \u2500 1.0.0-dev1\n

Finally, we can see the new versioning path for a rc starting version.

Showing the new versioning path for an rc version
$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u251c\u2500 pre_l \u2500 1.0.0\n                   \u2570\u2500 pre_n \u2500 1.0.0-rc1\n

The full development and release path is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
  • bump pre_n \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
  • bump pre_n \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase using bump-my-version bump pre_n.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidates increase using bump-my-version bump pre_n.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"#automate-the-pre-release-numbering","title":"Automate the pre-release numbering","text":"

The pre_n or pre-release number is a number that increases with each pre-release. You can automate this my changing the serialization configuration.

Serialize configuration with pre_n automation
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{distance_to_latest_tag}\",\n    \"{major}.{minor}.{patch}\",\n]\n

The distance_to_latest_tag is a special value that is replaced with the number of commits since the last tag. This is a good value to use for the pre_n because it will always increase with each commit.

"},{"location":"#visualize-the-pre_n-versioning-path","title":"Visualize the pre_n versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path with pre_n automation
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u2570\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u2570\u2500 pre_l \u2500 1.0.0-rc0\n$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u2570\u2500 pre_l \u2500 1.0.0\n

The pre_n path is now missing because it is automated.

The full development and release path now is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
    • each commit will increase \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
    • each commit will increase \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase automatically with each commit.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidate versions increase automatically with each commit.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"#development-contributing","title":"Development & Contributing","text":"

Thank you, contributors! You can find a full list here: https://github.com/callowayproject/bump-my-version/graphs/contributors

See also our CONTRIBUTING.md

Development of this happens on GitHub, patches including tests, and documentation are very welcome, as well as bug reports! Please open an issue if this tool does not support every aspect of bumping versions in your development workflow, as it is intended to be very versatile.

"},{"location":"#license","title":"License","text":"

Bump My Version is licensed under the MIT License - see the LICENSE file for details

"},{"location":"CHANGELOG/","title":"Changelog","text":""},{"location":"CHANGELOG/#changelog","title":"Changelog","text":""},{"location":"CHANGELOG/#0241-2024-06-26","title":"0.24.1 (2024-06-26)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes","title":"Fixes","text":"
  • Refactor error handling in SCM and add error handling test. 7ca6356

    This commit includes a new test in test_scm.py to verify the correct formatting and raising of subprocess errors in the SCM module. Additionally, the subprocess error handling has been refactored in the SCM module to include a new method, format_and_raise_error, for improved code readability and reusability.

  • [pre-commit.ci] pre-commit autoupdate. 60acc2d

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.9 \u2192 v0.4.10

"},{"location":"CHANGELOG/#other","title":"Other","text":""},{"location":"CHANGELOG/#0240-2024-06-25","title":"0.24.0 (2024-06-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new","title":"New","text":"
  • Add VersionNotFoundError test in test_bump.py. cb050a8

    The code in test_bump.py file has been modified to include a test for VersionNotFoundError exception. This ensures that the implementation properly handles cases where a specified version could not be found. - Add test for no commit on modification error. 7527029

    A test has been added to the bumpversion library to ensure that no commit and tag is made if there is an error modification. Specifically, the test checks the \u201cdo_bump\u201d function and asserts that \u201cmock_commit_and_tag\u201d and \u201cmock_update_config_file\u201d are not called under these conditions.

  • [pre-commit.ci] pre-commit autoupdate. 0e3a154

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.8 \u2192 v0.4.9

"},{"location":"CHANGELOG/#other_1","title":"Other","text":""},{"location":"CHANGELOG/#updates","title":"Updates","text":"
  • Improve error message for SCM command failures. 8f72f86

    The error message for failures in the SCM command execution has been enhanced. Now it displays not only the command\u2019s return code but also the standard output and error, improving the debugging process.

"},{"location":"CHANGELOG/#0230-2024-06-14","title":"0.23.0 (2024-06-14)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_1","title":"Fixes","text":"
  • Refactor valid_bumps and invalid_bumps to include_bumps and exclude_bumps. 2df57cc

    The configuration parameters valid_bumps and invalid_bumps were renamed to include_bumps and exclude_bumps respectively. This new naming better denotes their function, and the changes were consistently applied across all related files and tests. Numerous fixture outputs were also updated to reflect these changes. - Fixed spelling in CODE_OF_CONDUCT.md. 254ea44

"},{"location":"CHANGELOG/#new_1","title":"New","text":"
  • Add file filtering based on valid and invalid bumps. f9f7f96

    This commit introduces the ability to filter files based on whether the specified bump type is valid or not. It adds valid_bumps and invalid_bumps lists in the file configurations and adjusts the bumping process to consider these configurations. Tests are updated to reflect these new handling of valid and invalid bumps. - Add new files to .gitignore. 34e4dc1

    Several new file types have been added to .gitignore for ignoring during commits. These include \u2018.python-version\u2019, \u2018requirements-dev.lock\u2019, and \u2018requirements.lock\u2019 files. - Add valid_bumps and invalid_bumps to file configuration. 9458851

    Updated the configuration file model to support valid_bumps and invalid_bumps. This feature provides control over which version section updates can trigger file changes. Adjusted various test fixtures and cleaned up tests to match these changes. Also, some updates were made to the documentation accordingly.

  • [pre-commit.ci] pre-commit autoupdate. e44f6af

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.4 \u2192 v0.4.8

"},{"location":"CHANGELOG/#other_2","title":"Other","text":""},{"location":"CHANGELOG/#updates_1","title":"Updates","text":"
  • Update documentation for clarification. 2224808

    The changes made update the wording in the documentation to clarify the roles of include_bumps and exclude_bumps in the bump-my-version configuration. Additionally, unnecessary repetition was removed and overlapping examples were also corrected. - Update docs/reference/configuration.md. 7c801c0

    co-authored-by: wkoot 3715211+wkoot@users.noreply.github.com

"},{"location":"CHANGELOG/#0220-2024-06-11","title":"0.22.0 (2024-06-11)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_2","title":"New","text":"
  • Add extensive documentation for the \u2018show\u2019 subcommand. 91409d8

    This commit adds extensive documentation for the show subcommand in the program\u2019s reference. It also includes smaller updates and corrections to other parts of the documentation. An in-depth example usage of show is added both to the dedicated show.md file and in the function\u2019s docstring.

  • Renamed version workflow to release. 68f9eee
"},{"location":"CHANGELOG/#updates_2","title":"Updates","text":""},{"location":"CHANGELOG/#0211-2024-05-16","title":"0.21.1 (2024-05-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#other_3","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 1b57c2b

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. e813eda

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.3 \u2192 v0.4.4

  • [pre-commit.ci] pre-commit autoupdate. 05a0dd6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.2 \u2192 v0.4.3

"},{"location":"CHANGELOG/#updates_3","title":"Updates","text":"
  • Update README.md. cad7096
"},{"location":"CHANGELOG/#0210-2024-05-01","title":"0.21.0 (2024-05-01)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_2","title":"Fixes","text":"
  • Fixed a bug in the glob tests. 1041fe9

    Was not properly looking in the correct relative directories. - Fixed test for Windows glob paths. ea45c4c

  • Fixed exclusion logic with wcmatch. 1c391be
  • Refactored glob matching to use the wcmatch library. bbf4ae0
"},{"location":"CHANGELOG/#new_3","title":"New","text":"
  • Adds glob_exclude file specification parameter. 420e3bd

    User can prune the files resolved via the glob parameter.

    Fixes #184

  • [pre-commit.ci] pre-commit autoupdate. ce02aa7

    updates: - github.com/astral-sh/ruff-pre-commit: v0.4.1 \u2192 v0.4.2

"},{"location":"CHANGELOG/#other_4","title":"Other","text":""},{"location":"CHANGELOG/#0203-2024-04-26","title":"0.20.3 (2024-04-26)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_3","title":"Fixes","text":"
  • Fixed test logging setup. 3777f27
  • Fixed the indentation problem. ec3cd99

    • Added a dedent when a file does not match the change pattern.
    • Fixes #181
  • [pre-commit.ci] pre-commit autoupdate. e916f87

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.7 \u2192 v0.4.1

"},{"location":"CHANGELOG/#other_5","title":"Other","text":""},{"location":"CHANGELOG/#0202-2024-04-23","title":"0.20.2 (2024-04-23)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_4","title":"Fixes","text":"
  • Fixed the rendering of numeric version components. c522c75

    • Numeric version components now will attempt to render its value as an integer and fall back to the parsed value.
    • Fixed code block in the README. b4ff9f3
"},{"location":"CHANGELOG/#other_6","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 9b09da8

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.5 \u2192 v0.3.7

"},{"location":"CHANGELOG/#0201-2024-04-13","title":"0.20.1 (2024-04-13)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_5","title":"Fixes","text":"
  • Fix typos discovered by codespell. d5c33a3
  • Fixed relative references. 2aa1011
  • Refactored the docs. b63a9e7
"},{"location":"CHANGELOG/#other_7","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. f438bc6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.4 \u2192 v0.3.5

  • Pre-commit: Discover typos with codespell. 2509fc7

    Related to: * #168 - [pre-commit.ci] pre-commit autoupdate. be5cb79

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.3 \u2192 v0.3.4

"},{"location":"CHANGELOG/#0200-2024-03-27","title":"0.20.0 (2024-03-27)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_6","title":"Fixes","text":"
  • Refactored context into its own module. 5a3e05d
"},{"location":"CHANGELOG/#new_4","title":"New","text":"
  • Added always_increment attribute for parts. 53ee848

    This is a requirement for CalVer to ensure they always increment with each bump, but it will work for any type. - Added CalVer function and formatting. 7a0e639

    • Version parts now have a calver_format attribute for CalVer parts.
  • Updated the documentation. 607609d
"},{"location":"CHANGELOG/#updates_4","title":"Updates","text":""},{"location":"CHANGELOG/#0193-2024-03-23","title":"0.19.3 (2024-03-23)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_7","title":"Fixes","text":"
  • Fixed packaging of dev releases. 84254e0
  • Fixed platform-dependent encoding. f8b4d65

    • Added encoding=\"utf-8\" to all writes.
    • Fixed version.yaml workflow. 10b007c
"},{"location":"CHANGELOG/#other_8","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. e92000a

    updates: - github.com/astral-sh/ruff-pre-commit: v0.3.2 \u2192 v0.3.3

  • Bump the github-actions group with 3 updates. a422c58

    Bumps the github-actions group with 3 updates: actions/checkout, actions/setup-python and codecov/codecov-action.

    Updates actions/checkout from 3 to 4 - Release notes - Changelog - Commits

    Updates actions/setup-python from 4 to 5 - Release notes - Commits

    Updates codecov/codecov-action from 3 to 4 - Release notes - Changelog - Commits

    updated-dependencies: - dependency-name: actions/checkout dependency-type: direct:production update-type: version-update:semver-major dependency-group: github-actions

    signed-off-by: dependabot[bot] support@github.com

  • Keep GitHub Actions up to date with GitHub\u2019s Dependabot. 2e55fa1

    • https://docs.github.com/en/code-security/dependabot/working-with-dependabot/keeping-your-actions-up-to-date-with-dependabot
    • https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#package-ecosystem
"},{"location":"CHANGELOG/#0192-2024-03-16","title":"0.19.2 (2024-03-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_8","title":"Fixes","text":"
  • Fixed bad options not returning an error code. e88f0a9

    Fixes #153 - Fix issue on version.yaml. 7d14065

"},{"location":"CHANGELOG/#0191-2024-03-16","title":"0.19.1 (2024-03-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_9","title":"Fixes","text":"
  • Fix commas in legacy multiline options. 62dfe8e
"},{"location":"CHANGELOG/#new_5","title":"New","text":"
  • Added manual version bumping in the GitHub action. c9d67b5
"},{"location":"CHANGELOG/#other_9","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. be1a568

    updates: - github.com/astral-sh/ruff-pre-commit: v0.2.2 \u2192 v0.3.2

"},{"location":"CHANGELOG/#0190-2024-03-12","title":"0.19.0 (2024-03-12)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_10","title":"Fixes","text":"
  • Fixing version hint generation. ae1732b
"},{"location":"CHANGELOG/#updates_5","title":"Updates","text":"
  • Removes ability to call the CLI without subcommand. e56c944

    BREAKING CHANGE: You must use bump-my-version bump

"},{"location":"CHANGELOG/#0183-2024-02-25","title":"0.18.3 (2024-02-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_11","title":"Fixes","text":"
  • Fixed \u2013ignore-missing-version and \u2013ignore-missing-files options. 7635873

    The CLI options were defaulting to False when missing. This overrode the configuration.

    Fixes #140

"},{"location":"CHANGELOG/#0182-2024-02-25","title":"0.18.2 (2024-02-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_12","title":"Fixes","text":"
  • Fixed docs and cli help. 8ac1087
"},{"location":"CHANGELOG/#0181-2024-02-24","title":"0.18.1 (2024-02-24)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_13","title":"Fixes","text":"
  • Fixed type annotation in config. 2988ede
  • Fixed naming issue for docs. 2850aa7

    • renamed changelog.md and contributing.md
  • Added how-to doc. 68643a9

    • \u201cHow to update a date in a file\u201d
  • [pre-commit.ci] pre-commit autoupdate. c495d3d

    updates: - github.com/astral-sh/ruff-pre-commit: v0.2.1 \u2192 v0.2.2

"},{"location":"CHANGELOG/#new_6","title":"New","text":""},{"location":"CHANGELOG/#other_10","title":"Other","text":""},{"location":"CHANGELOG/#updates_6","title":"Updates","text":"
  • Updated docs and styles. f4f75fa
"},{"location":"CHANGELOG/#0180-2024-02-18","title":"0.18.0 (2024-02-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_7","title":"New","text":"
  • Added --ignore-missing-files option to bump. fcfaac7
  • Added configuration option ignore_missing_files. b473a19
"},{"location":"CHANGELOG/#other_11","title":"Other","text":"
  • Convert docs to MkDocs. f805c33
  • Converted documentation to use MkDocs. 1b8c6b3
"},{"location":"CHANGELOG/#0174-2024-02-10","title":"0.17.4 (2024-02-10)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_14","title":"Fixes","text":"
  • Fixed linting errors. 9515afc
  • Fix encoding when reading text. c03476a

    Fixes #68

"},{"location":"CHANGELOG/#other_12","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 491b4aa

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.14 \u2192 v0.2.0

"},{"location":"CHANGELOG/#0173-2024-01-29","title":"0.17.3 (2024-01-29)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_15","title":"Fixes","text":"
  • Refactored VersionComponentConfig to VersionComponentSpec. b538308

    More consistent with VersionSpec

"},{"location":"CHANGELOG/#new_8","title":"New","text":"
  • Added mental model documentation. 5cbd250
"},{"location":"CHANGELOG/#other_13","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. a2a3fe6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.11 \u2192 v0.1.14

"},{"location":"CHANGELOG/#updates_7","title":"Updates","text":"
  • Updated more documentation. 779c84c
"},{"location":"CHANGELOG/#0172-2024-01-27","title":"0.17.2 (2024-01-27)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_16","title":"Fixes","text":"
  • Fixed some tests. 593a4ee
  • Refactored serialization. 0ac2cd8

    • Moved serialization from VersionConfig to version.serialization
    • Fixed extra capture group in PEP440 parser. 384fd99
  • Refactored verioning models. 88e7f71

    • created a \u201cconventions\u201d module for future release
    • added an optional depends_on version component configuration
    • The depends_on is required for PEP440 versioning
    • Fixed None as value for a function. f8c4d05
    • Turns None into an empty string
    • Fixed bad imports. 5c86d51
  • Refactored versioning models and tests. 7d05414
  • Refactored version parsing. 5ed546b
  • Refactored versioning functions and version parts. be87721
  • Fixed timezone of a test. 0e01253
"},{"location":"CHANGELOG/#0171-2024-01-25","title":"0.17.1 (2024-01-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_17","title":"Fixes","text":"
  • Fixed bad error checking with SCM. 10e5d7d
  • Fix missing current version within the context. a5dca4c
"},{"location":"CHANGELOG/#0170-2024-01-22","title":"0.17.0 (2024-01-22)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_18","title":"Fixes","text":"
  • Fixed Py3.8 type annotation. c15b23b
  • Fixed some output in visualizing. 406f97a
  • Fixed bad type annotation. 8f4bedf
  • Fixed bad test imports. a74342b
  • Refactored the create subcommand. f529d28

    • Also organized the CLI tests
"},{"location":"CHANGELOG/#new_9","title":"New","text":"
  • Added show-bump subcommand. 0bbd814

    • Shows possible resulting versions of the bump command
    • Added sample-config feature. 3d0f67d
    • Initial implementation
"},{"location":"CHANGELOG/#updates_8","title":"Updates","text":"
  • Updated documentation. 4f90348
"},{"location":"CHANGELOG/#0162-2024-01-13","title":"0.16.2 (2024-01-13)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_19","title":"Fixes","text":"
  • Fixed a bad import. 46c9c48
  • Fixed extra whitespace added when updating pyproject.toml. 839f17f

    • Removed dotted-notation from requirements. There is an issue on how dotted-notation sets values in the TOMLkit data structure.
    • Added get_nested_value and set_nested_value as replacements for dotted-notation.
"},{"location":"CHANGELOG/#other_14","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. ee4d2f3

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.9 \u2192 v0.1.11

"},{"location":"CHANGELOG/#0161-2024-01-06","title":"0.16.1 (2024-01-06)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_20","title":"Fixes","text":"
  • Fixed empty string replacement bug. d9965ab

    Only a missing replacement value will trigger one of the fallback options.

    Fixes #117

"},{"location":"CHANGELOG/#0160-2024-01-05","title":"0.16.0 (2024-01-05)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_10","title":"New","text":"
  • Add support for legacy multiline search options (refs #98). 278eae5
"},{"location":"CHANGELOG/#other_15","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 2e9a400

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.7 \u2192 v0.1.9

"},{"location":"CHANGELOG/#0154-2023-12-29","title":"0.15.4 (2023-12-29)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_21","title":"Fixes","text":"
  • Fix not being able to tag without also committing. 753c990
  • Fixed testing automation. 19215f1

    • The new commit/tag decoupling requires the --no-tag flag
"},{"location":"CHANGELOG/#0153-2023-12-18","title":"0.15.3 (2023-12-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_22","title":"Fixes","text":"
  • Fix miscast of current_version. b8ea252

    • When using the legacy configuration format, a single-digit version is parsed as an int

    Fixes #99

"},{"location":"CHANGELOG/#0152-2023-12-18","title":"0.15.2 (2023-12-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_23","title":"Fixes","text":"
  • Fixed regression in config update. 2bbbd74

    Fixes #108

"},{"location":"CHANGELOG/#new_11","title":"New","text":"
  • Added a test case for line-start regexes. ef4823c
"},{"location":"CHANGELOG/#0151-2023-12-18","title":"0.15.1 (2023-12-18)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_24","title":"Fixes","text":"
  • Fixes workflow triggers. 690452e
  • Fixes mismatched artifact up/downloading versions. 3f61742
  • Fixed PR_NUMBER retrieval. 85a8b48
  • Fixes committing and download-artifact. 12ba54f
  • Refactored workflows. d2f30a8
"},{"location":"CHANGELOG/#other_16","title":"Other","text":"
  • Testing PR acquisition. 67ab83d
  • Put in temporary debugging steps. 6ac064e
"},{"location":"CHANGELOG/#updates_9","title":"Updates","text":"
  • Changed the triggers to cause runs. 23e6c18
"},{"location":"CHANGELOG/#0150-2023-12-16","title":"0.15.0 (2023-12-16)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_25","title":"Fixes","text":"
  • Fixed requirements for github action. d96e07a
"},{"location":"CHANGELOG/#updates_10","title":"Updates","text":"
  • Changed default regex CLI value to None. 93191f3

    Fixes #64

    The default value of False was overriding other values.

"},{"location":"CHANGELOG/#0140-2023-12-15","title":"0.14.0 (2023-12-15)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_26","title":"Fixes","text":"
  • Fixed issue when adding files. 84556f8
  • Fixed missing requirement in GH action. 42bab83
  • Fixed regression regarding multiple changes in one file. e7a7629

    Changed the method of marking changes from a dict keyed by the file name to a list of FileChanges.

    FileChanges encapsulate a single change to a file. - Refactored logging to provide indented output. 4e68214

  • Refactored FileConfig to FileChange. 249a999

    This better describes what the class does: describe a file change.

    Also moved get_search_pattern to the class, since it is specific to each instance - Refactored config file management. a4c90b2

    Moved the INI format stuff into files_legacy.py - Fixes generate-requirements.sh to upgrade. 121ef69

"},{"location":"CHANGELOG/#new_12","title":"New","text":"
  • Added caching to the resolved filemap. c96e0bd
  • Added custom GitHub action. 4ce17a9
  • Added indented logger to improve console output. d1d19e3
"},{"location":"CHANGELOG/#updates_11","title":"Updates","text":"
  • Changed the management of file changes. 909396d

    File changes are hashable to weed out duplication. - Removed some commented lines. 89686b8

"},{"location":"CHANGELOG/#0130-2023-12-06","title":"0.13.0 (2023-12-06)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_27","title":"Fixes","text":"
  • Fixed import of extract_regex_flags. a980670
  • Fixed logging and regex regression in 3.11. cae12dc
  • Fixed issue with tag name. e218264

    Fixes #74

    current_version and tag_name now do not need to match exactly - Fixed logic in auto bump workflow. 909a53f

  • Fixes https://github.com/callowayproject/bump-my-version/issues/85. 97049e0

    HG returns the tags in the order they were created so we want the last one in the list - Fixed autoversioning. a308a35

"},{"location":"CHANGELOG/#new_13","title":"New","text":"
  • Added key_path to FileConfig. e160b40

    • Also made all attributes required except filename, glob, and key_path
"},{"location":"CHANGELOG/#other_17","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 8188a42

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. 4c81ad4

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.3 \u2192 v0.1.5

  • [pre-commit.ci] pre-commit autoupdate. 7109d70

    updates: - github.com/astral-sh/ruff-pre-commit: v0.1.3 \u2192 v0.1.6

"},{"location":"CHANGELOG/#updates_12","title":"Updates","text":"
  • Refactored configuration file updating. e407974

    TOML files are parsed, specific values are updated, and re-written to avoid updating the wrong data.

    It uses a two-way parser, so all formatting and comments are maintained.

    INI-type configuration files use the old way, since that format is deprecated.

"},{"location":"CHANGELOG/#0120-2023-11-04","title":"0.12.0 (2023-11-04)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_28","title":"Fixes","text":"
  • Fixed versioning. 8769671
  • Fix dev versioning with PR number. 463082b
  • Fix dev versioning. 1eed99b

    • added an echo of the PR_NUMBER
    • Fix versioning of development versions. e89599f
  • Fixes workflows. 5ebb0d7
  • Fixed bug #65 where glob\u2019d files weren\u2019t used. 357b9dc
"},{"location":"CHANGELOG/#new_14","title":"New","text":"
  • Add -h for help option. fda71b0

    Fixes #67

"},{"location":"CHANGELOG/#other_18","title":"Other","text":"
  • Drop Python3.7 as compatible version. 890edc8

    Since this is no longer tested, it\u2019s safer to start at 3.8. - [pre-commit.ci] auto fixes from pre-commit.com hooks. fbcef03

    for more information, see https://pre-commit.ci - Recommend calling \u2018bump-my-version\u2019 instead of \u2018bumpversion\u2019. 9fb1a1d

  • [pre-commit.ci] pre-commit autoupdate. e2579d6

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.290 \u2192 v0.0.292

  • [pre-commit.ci] pre-commit autoupdate. e21fdd9

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.290 \u2192 v0.1.1

  • [pre-commit.ci] pre-commit autoupdate. 7e5d1bc

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.290 \u2192 v0.1.3

"},{"location":"CHANGELOG/#updates_13","title":"Updates","text":"
  • Changed the default regex search to non-regex. 0034716

    Fixes #59

    • Changed the flags to \u2013regex/\u2013no-regex
    • updated tests and docs
"},{"location":"CHANGELOG/#0110-2023-09-26","title":"0.11.0 (2023-09-26)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#other_19","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 4a3d046

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.285 \u2192 v0.0.290

"},{"location":"CHANGELOG/#updates_14","title":"Updates","text":"
  • Removed bumpversion as a duplicate of the bump-my-version script. a59ced8
  • Updated dependency from Pydantic 1 to 2. 577aa4c
"},{"location":"CHANGELOG/#0100-2023-09-05","title":"0.10.0 (2023-09-05)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#updates_15","title":"Updates","text":"
  • Refactored file resolution, inclusion, and exclusion. 646af54

    • Fixes #61
    • Config now includes resolved_filemap property
    • resolved filemap expands all globs
    • Config now includes files_to_modify property
    • files to modify resolves inclusions and exclutions
    • Improved Config.add_files property
"},{"location":"CHANGELOG/#093-2023-08-25","title":"0.9.3 (2023-08-25)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_29","title":"Fixes","text":"
  • Fixed file configuration overrides. c1ef3b2

    Fixes #55

    The file config was ignoring falsey values when constructing the dict.

    It now ignores None values. - Fixed documentation regarding regex config. cd71a1a

    • TOML requires the double backslash while INI doesn\u2019t
    • Fixed requirements for docs. 7856ee0
"},{"location":"CHANGELOG/#new_15","title":"New","text":"
  • Added documentation building workflow. 48980d7
"},{"location":"CHANGELOG/#other_20","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 7c38c40

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.284 \u2192 v0.0.285

  • [pre-commit.ci] pre-commit autoupdate. c30bd12

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.282 \u2192 v0.0.284

  • [pre-commit.ci] pre-commit autoupdate. 95c89fb

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.281 \u2192 v0.0.282

"},{"location":"CHANGELOG/#updates_16","title":"Updates","text":"
  • Removed mentions of Python 3.7. a91f690
"},{"location":"CHANGELOG/#092-2023-08-07","title":"0.9.2 (2023-08-07)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_30","title":"Fixes","text":"
  • Fixed modified context when committing. 130bbe0

    • Resets the context before committing and tagging
    • Fixes #14
"},{"location":"CHANGELOG/#091-2023-08-03","title":"0.9.1 (2023-08-03)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#other_21","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 4b457d0

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. adb7e4c

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.277 \u2192 v0.0.281

"},{"location":"CHANGELOG/#updates_17","title":"Updates","text":"
  • Remove pygments_style from docsrc/conf.py. 32798a9

    The theme defaults, subjectively, look better.

"},{"location":"CHANGELOG/#090-2023-08-03","title":"0.9.0 (2023-08-03)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_16","title":"New","text":"
  • Added documentation about regular expressions. 449b70a
  • Added configuration and command-line no_regex option. a295a32

    • Global and individual file configurations available for no_regex
    • Command-line flag --no-regex flag added for bump and replace sub-commands
    • Adds regular expression searching ability. 0210d74
    • Search strings are treated as regular expressions after the initial substitution
    • Added deprecation warning on .cfg files. a0481b7
"},{"location":"CHANGELOG/#080-2023-07-13","title":"0.8.0 (2023-07-13)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#new_17","title":"New","text":"
  • Added documentation for ignore missing version. e0731c3
  • Added --ignore-missing-version flag to bump and replace. a5bd008
  • Added ignore-missing-version configuration. 45c85be

    • Defaults to False
    • File configurations can also override this value
    • Added deprecation warnings. 733438b
    • --list option will go bye-bye in 1.0
    • calling bumpversion without a subcomand will leave in 1.0
"},{"location":"CHANGELOG/#071-2023-07-12","title":"0.7.1 (2023-07-12)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_31","title":"Fixes","text":"
  • Fix search and replace options for replace. 781e8d8

    • The --search and --replace options now completely override any other search and replace logic.

    Fixes #34

"},{"location":"CHANGELOG/#other_22","title":"Other","text":"
  • [pre-commit.ci] pre-commit autoupdate. 531738d

    updates: - github.com/astral-sh/ruff-pre-commit: v0.0.276 \u2192 v0.0.277

  • [pre-commit.ci] pre-commit autoupdate. 61e6747

    updates: - https://github.com/charliermarsh/ruff-pre-commit \u2192 https://github.com/astral-sh/ruff-pre-commit

"},{"location":"CHANGELOG/#070-2023-07-10","title":"0.7.0 (2023-07-10)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_32","title":"Fixes","text":"
  • Fixed test coverage. 3fe96f0
  • Fixed wrong pydantic version pinning. d4b125e
  • Fixed typing issue. bfe5306

    • Declared SourceCodeManager attributes as ClassVar[List[str]]
    • _TEST_USABLE_COMMAND, _COMMIT_COMMAND, and _ALL_TAGS_COMMAND affected
"},{"location":"CHANGELOG/#new_18","title":"New","text":"
  • Added tests for CLI replace command. a53cddc
  • Added and re-organized documentation. c62d65e
  • Added replace subcommand. 8722a0f

    • Works just like bump but
      • doesn\u2019t do any version incrementing
      • Will not change the configuration file
      • Will not commit or tag
    • Can use bumpversion show new_version --increment <versionpart> to see what the new version would be
    • Adds short_branch_name to version rendering context. 7f7e50c
    • short_branch_name is the branch name, lower case, containing only a-z and 0-9, and truncated to 20 characters.

    Fixes #28

"},{"location":"CHANGELOG/#other_23","title":"Other","text":"
  • Check config before tagging. 3a6e3ee
  • Format version parts. ee43bdb
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 5e6f566

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. f1acd35

    updates: - github.com/charliermarsh/ruff-pre-commit: v0.0.272 \u2192 v0.0.275

"},{"location":"CHANGELOG/#060-2023-06-23","title":"0.6.0 (2023-06-23)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_33","title":"Fixes","text":"
  • Fixed --help and bump invocations. 9d965e5

    • --help works for individual sub-commands, but not for the command
    • bump now works and fixed tests
    • Fixed issue regarding TOML types. 8960d24
    • tomlkit.parse() returns a TOMLDocument.
    • unwrap() converts it into a dict
"},{"location":"CHANGELOG/#new_19","title":"New","text":"
  • Adds branch_name to SCM information. 173be1a
  • Added documentation for the show command. d537274
  • Adds --increment option to show subcommand. b01fffc

    • when specified it increments the current version and adds new_version to the available output.
    • Added show subcommand. 9bce887
    • supersedes the --list option
    • provides much more capability
    • Can output in YAML, JSON, and default
    • Can specify one or more items to display
    • Can use dotted-notation to pull items from nested data structures.
"},{"location":"CHANGELOG/#updates_18","title":"Updates","text":"
  • Changes bump-my-version into subcommands. 31ffbcf

    • Is backwards-compatible with previous versions
    • bump-my-version forwards command to bump-my-version bump subcommand
    • Only problem is that Click will not show help automatically, must provide --help
"},{"location":"CHANGELOG/#051-2023-06-14","title":"0.5.1 (2023-06-14)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_34","title":"Fixes","text":"
  • Fixes reporting the wrong version missing in a file. efb04e9

    • Fixes issue #20
    • Renders the correct current_version for each file being modified.
"},{"location":"CHANGELOG/#other_24","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 5476cdf

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. 6e500c2

    updates: - github.com/charliermarsh/ruff-pre-commit: v0.0.270 \u2192 v0.0.272

"},{"location":"CHANGELOG/#050-2023-06-12","title":"0.5.0 (2023-06-12)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_35","title":"Fixes","text":"
  • Fixed ruff complaints about subprocess. c429c68
  • Fixed issue with formatting. da7544f

    There is an underlying edge case where the deriving previous environment variables with multiple ways of formatting version numbers will fail.

  • Add test to reproduce issue #14. d78ff46
  • Added documentation for replacing strings in different files. 893ec03

    Fixes #6

"},{"location":"CHANGELOG/#new_20","title":"New","text":""},{"location":"CHANGELOG/#other_25","title":"Other","text":"
  • Made VERSION_PART optional. f236b7d

    • Fixes #16
    • VERSION_PART is detected from the arguments based on the configuration
"},{"location":"CHANGELOG/#updates_19","title":"Updates","text":"
  • Updated docs indicated VERSION_PART is optional. 22edeac
  • Updated tests for bad version parts. 23be62d
  • Changed exception type raised when bad version part is detected. 1e3ebc5

    • ValueError -> click.BadArgumentUsage
    • Updated readme. 7780265

    Fixes #7

"},{"location":"CHANGELOG/#041-2023-06-09","title":"0.4.1 (2023-06-09)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_36","title":"Fixes","text":"
  • Fixes release.yaml. 01870d5

    Outputs the notes to a file instead of an environment variable.

"},{"location":"CHANGELOG/#other_26","title":"Other","text":"
  • [pre-commit.ci] auto fixes from pre-commit.com hooks. 266002f

    for more information, see https://pre-commit.ci - [pre-commit.ci] pre-commit autoupdate. edc444f

    updates: - github.com/charliermarsh/ruff-pre-commit: v0.0.261 \u2192 v0.0.270

"},{"location":"CHANGELOG/#040-2023-04-20","title":"0.4.0 (2023-04-20)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_37","title":"Fixes","text":"
  • Fixed pre-commit hook for dependency checking. 3d5c253
  • Fixed installing test dependencies. c1034eb
  • Fixed dependency spec. 4782745
  • Fixed missing python in pypi test. e5ed27d
  • Fixed some CI issues. d4b03d7
  • Fixed vague commit and tagging info. 4fb5158

    • If commit is configured false, it will report that it will not commit
    • If commit is configured false, tagging is disabled and it reports that
    • If tagging is configured false, it will report it is not tagging
    • Fixes test package. 7c12072
    • The build-and-inspect action didn\u2019t save the dist packages
"},{"location":"CHANGELOG/#new_21","title":"New","text":"
  • Added tests for logging branches. f8f0278
  • Added path restrictions on release-hints. e1af658
  • Added test build to CI. 8738f3f
  • Added doc files to table of contents. 49858c0
"},{"location":"CHANGELOG/#other_27","title":"Other","text":"
  • Completely migrated setuptools to use pyproject.toml. f10f8b2
  • [pre-commit.ci] pre-commit autoupdate. d626f7d

    updates: - https://github.com/python/black \u2192 https://github.com/psf/black

"},{"location":"CHANGELOG/#updates_20","title":"Updates","text":"
  • Removed pre-commit dependency hook. ac6cdd0
  • Changed the version serialization. c529452

    • can bump \u201cdev\u201d to get a development release
    • Updated formatting documentation. 8006f3e
"},{"location":"CHANGELOG/#030-2023-04-17","title":"0.3.0 (2023-04-17)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_38","title":"Fixes","text":"
  • Fixed bug in SCMInfo setup. e8fddc9
  • Fixed missing xml coverage report. 696503f
  • Fixed assertion in failing test. 7afe58c
  • Fixes issue when new version equals current version. 64b0de3

    • Now it reports they are the same and exits.
    • Fixes issue of duplicate tags. c025650
    • Now it checks if the tag exists and reports a warning
    • Fixed automation tooling. 19f13b7
    • changed name to bump-my-version in setup.cfg
    • added PAT in release pipeline to (hopefully) allow committing and tagging to master without issue.
"},{"location":"CHANGELOG/#new_22","title":"New","text":"
  • Added codecov to workflow. a5009e0
"},{"location":"CHANGELOG/#other_28","title":"Other","text":"
  • Migrated setuptools metadata to pyproject.toml. 0bd54dc
"},{"location":"CHANGELOG/#updates_21","title":"Updates","text":"
  • Updated the readme. 1b1d910
  • Updated documentation. 6c3b4fe
"},{"location":"CHANGELOG/#020-2023-04-14","title":"0.2.0 (2023-04-14)","text":"

Compare the full difference.

"},{"location":"CHANGELOG/#fixes_39","title":"Fixes","text":"
  • Fixed configuration to allow_dirty in bumpversion. b042e31
  • Fixes issue with generate-changelog and git. 2a977af
  • Fixes the quoting in the bumpversion expressions. 9a55d6d
  • Fixed issue with windows testing. b8abc44

    • different methods for reporting paths was resolved by casting them the pathlib.Paths
    • Fixes windows testing error. 556853b
    • the differences in path specifications seems to be causing problems.
    • Fixed type issue in Python 3.7, 3.8. ddfd3bf
  • Fixed configuration file detection. fbf85c2

    Doesn\u2019t just stop when it finds one, it checks for the existence of the header. - Fixed logging output and output in general. 0aea9dc

"},{"location":"CHANGELOG/#new_23","title":"New","text":"
  • Added additional option to manual runs: verbose. 81eb097
  • Added new workflows. a9cac5b

    • Added bumpversion.yaml to increase the version when a PR is closed
    • Added release.yaml to create a github release and upload things to PyPI
  • Added PYTHONUTF8 mode. 91a73e2

    • see https://docs.python.org/3/using/windows.html#utf-8-mode
  • Added explicit environment variable declarations. 80fe7ef
  • Added a github CI workflow. 2b3b358
  • Added files for coverage to ignore. cfbba08

    • main.py
    • aliases.py
  • Added LICENSE. 34a9be5
  • Added tests for version parsing errors. 71a204b
  • Added utf8 test in files. 9cb8f60
  • Added more tests for scm. fe794dd
  • Added \u2013list function. 88709fd
"},{"location":"CHANGELOG/#other_29","title":"Other","text":"
  • Removing testing for Python 3.7. 19eaeef
  • Moved configuration to pyproject.toml. d339007
  • Initial conversion. f5d1cab
  • Initial commit. d7dec79
"},{"location":"CHANGELOG/#updates_22","title":"Updates","text":"
  • Updated workflows. 857835d

    • Added better changelog parsing
    • Added workflow dispatch inputs for manual runs
    • Improved documentation. f3b7a0f
  • Renamed tox job to test. a9b6db3
  • Updated README and other documentation. e0cebb3
  • Improved Mercurial support. 560999d
  • Improved logging output. 6ccfa7d
  • Changed errors to subclass UsageError. a447651
  • Changed BaseVCS to SourceCodeManager. 11c5609

    Just for consistency. - Modified the group command back to a single command. 6d4179b

    Will eventually change to a group command, but later.

"},{"location":"CHANGELOG/#010-2023-03-24","title":"0.1.0 (2023-03-24)","text":"
  • Initial creation
"},{"location":"CONTRIBUTING/","title":"Contributing","text":""},{"location":"CONTRIBUTING/#contributing-to-bump-my-version","title":"Contributing to Bump My Version","text":"

First off, thanks for taking the time to contribute! \u2764\ufe0f

All types of contributions are encouraged and valued. See the Table of Contents for different ways to help and details about how this project handles them. Please make sure to read the relevant section before making your contribution. It will make it much easier for us maintainers and smooth out the experience for all involved. The community looks forward to your contributions. \ud83c\udf89

If you like the project but don\u2019t have time to contribute, that\u2019s fine. There are other easy ways to support the project and show your appreciation, which we would also be very happy about: - Star the project - Tweet about it - Refer to this project in your project\u2019s readme - Mention the project at local meetups and tell your friends/colleagues

"},{"location":"CONTRIBUTING/#table-of-contents","title":"Table of Contents","text":"
  • Code of Conduct
  • I Have a Question
  • Reporting Bugs
  • Suggesting Enhancements
  • Your First Code Contribution
  • Improving The Documentation
  • Styleguides
  • Join The Project Team
"},{"location":"CONTRIBUTING/#code-of-conduct","title":"Code of Conduct","text":"

This project and everyone participating in it are governed by the Bump My Version Code of Conduct. By participating, you are expected to uphold this code. Please report unacceptable behavior to coreyoordt@gmail.com.

"},{"location":"CONTRIBUTING/#i-have-a-question","title":"I Have a Question","text":"

If you want to ask a question, we assume that you have read the available Documentation.

Before you ask a question, it is best to search for existing Issues that might help you. In case you have found a suitable issue and still need clarification, you can write your question in this issue. It is also advisable to search the internet for answers first.

If you then still feel the need to ask a question and need clarification, we recommend the following:

  • Open an Issue.
  • Provide as much context as you can about what you\u2019re running into.
  • Provide project and platform versions (nodejs, npm, etc), depending on what seems relevant.

We will then take care of the issue as soon as possible.

"},{"location":"CONTRIBUTING/#reporting-bugs","title":"Reporting Bugs","text":""},{"location":"CONTRIBUTING/#before-submitting-a-bug-report","title":"Before Submitting a Bug Report","text":"

A good bug report shouldn\u2019t leave others needing to chase you up for more information. Therefore, we ask you to investigate carefully, collect information, and describe the issue in detail in your report. Please complete the following steps in advance to help us fix any potential bug as fast as possible.

  • Make sure that you are using the latest version.
  • Determine if your bug is really a bug and not an error on your side e.g. using incompatible environment components/versions (Make sure that you have read the documentation. If you are looking for support, you might want to check this section).
  • To see if other users have experienced (and potentially already solved) the same issue you are having, check if there is not already a bug report existing for your bug or error in the bug tracker.
  • Also, make sure to search the internet (including Stack Overflow) to see if users outside of the GitHub community have discussed the issue.
  • Collect information about the bug:
    • Stack trace (Traceback)
    • OS, Platform, and Version (Windows, Linux, macOS, x86, ARM)
    • The version of Python
    • Possibly your input and the output
    • Can you reliably reproduce the issue? And can you also reproduce it with older versions?
"},{"location":"CONTRIBUTING/#how-do-i-submit-a-good-bug-report","title":"How Do I Submit a Good Bug Report?","text":"

You must never report security-related issues, vulnerabilities, or bugs that include sensitive information to the issue tracker or elsewhere in public. Instead, sensitive bugs must be sent by email to coreyoordt@gmail.com.

We use GitHub issues to track bugs and errors. If you run into an issue with the project:

  • Open an Issue. (Since we can\u2019t be sure at this point whether it is a bug or not, we ask you not to talk about a bug yet and not to label the issue.)
  • Explain the behavior you would expect and the actual behavior.
  • Please provide as much context as possible and describe the reproduction steps that someone else can follow to recreate the issue on their own. This usually includes your code. For good bug reports, you should isolate the problem and create a reduced test case.
  • Provide the information you collected in the previous section.

Once it\u2019s filed:

  • The project team will label the issue accordingly.
  • A team member will try to reproduce the issue with your provided steps. If there are no reproduction steps or no obvious way to reproduce the issue, the team will ask you for those steps and will not address them until they are included.
  • If the team is able to reproduce the issue, the issue will be left to be implemented by someone.
"},{"location":"CONTRIBUTING/#suggesting-enhancements","title":"Suggesting Enhancements","text":"

This section guides you through submitting an enhancement suggestion for Bump My Version, including completely new features and minor improvements to existing functionality. Following these guidelines will help maintainers and the community to understand your suggestion and find related suggestions.

"},{"location":"CONTRIBUTING/#before-submitting-an-enhancement","title":"Before Submitting an Enhancement","text":"
  • Make sure that you are using the latest version.
  • Read the documentation carefully and find out if the functionality is already covered, maybe by an individual configuration.
  • Perform a search to see if the enhancement has already been suggested. If it has, add a comment to the existing issue instead of opening a new one.
  • Find out whether your idea fits with the scope and aims of the project. It\u2019s up to you to make a strong case to convince the project\u2019s developers of the merits of this feature. Keep in mind that we want features that will be useful to the majority of our users and not just a small subset. If you\u2019re just targeting a minority of users, consider writing an add-on/plugin library.
"},{"location":"CONTRIBUTING/#how-do-i-submit-a-good-enhancement-suggestion","title":"How Do I Submit a Good Enhancement Suggestion?","text":"

Enhancement suggestions are tracked as GitHub issues.

  • Use a clear and descriptive title for the issue to identify the suggestion.
  • Describe the problem or use case this enhancement solves or the new benefit it provides.
  • Explain why this enhancement would be useful to most Bump My Version users. You may also want to point out the other projects that solved it better and which could serve as inspiration.
  • Provide a step-by-step description of the suggested enhancement in as many details as possible.
  • You may also tell how current alternatives do not work for you, if appropriate
"},{"location":"CONTRIBUTING/#your-first-code-contribution","title":"Your First Code Contribution","text":""},{"location":"CONTRIBUTING/#legal-notice","title":"Legal Notice","text":"

When contributing to this project, you must agree that you have authored 100% of the content, that you have the necessary rights to the content and that the content you contribute may be provided under the project license.

"},{"location":"CONTRIBUTING/#setup","title":"Setup","text":"

There are several ways to create an isolated Python development environment. This is the default method.

Run the following in a terminal:

# Clone the repository\ngit clone https://github.com/callowayproject/bump-my-version.git\n\n# Enter the repository\ncd bump-my-version\n\n# Create, then activate a virtual environment\npython -m venv env\nsource env/bin/activate\n\n# Install the development requirements\npython -m pip install -r requirements/dev.txt\n
"},{"location":"CONTRIBUTING/#run-tests","title":"Run tests","text":"

Once setup, you should be able to run tests:

pytest\n
"},{"location":"CONTRIBUTING/#install-pre-commit-hooks","title":"Install Pre-commit Hooks","text":"

Pre-commit hooks are scripts that run every time you make a commit. If any of the scripts fail, it stops the commit. You can see a listing of the checks in the .pre-commit-config.yaml file.

pre-commit install\n
"},{"location":"CONTRIBUTING/#improving-the-documentation","title":"Improving The Documentation","text":"

Please, please help us here.

"},{"location":"CONTRIBUTING/#styleguides","title":"Styleguides","text":""},{"location":"CONTRIBUTING/#coding-style","title":"Coding Style","text":"

All of the basic coding styles are configured into tools for fixing and checking them. Pre-commit is used to automate the process.

"},{"location":"CONTRIBUTING/#commit-messages","title":"Commit Messages","text":"

Commit messages are used to generate the change log.

New changes

Commit messages are categorized as \u201cnew\u201d if the commit message starts with:

  • new
  • add

For example: Added this cool new feature or New document type added.

Updates

Commit messages are categorized as \u201cupdates\u201d if the commit message starts with:

  • update
  • change
  • rename
  • remove
  • delete
  • improve
  • refacto
  • chg
  • modif

For example: Modified the taxonomy schema or Improves performance by 419%

Fixes

Commit messages are categorizes as \u201cfixes\u201d if the commit message starts with:

  • fix

For example: Fixes bug #123

Other

All other commit messages are categorized as \u201cother.\u201d

Ignoring commit messages

To have the change log generator ignore this commit, add to the summary line:

  • @minor
  • !minor
  • @cosmetic
  • !cosmetic
  • @refactor
  • !refactor
  • @wip
  • !wip
"},{"location":"CONTRIBUTING/#join-the-project-team","title":"Join The Project Team","text":"

If you would like to be a maintainer, reach out to coreyoordt@gmail.com.

"},{"location":"CONTRIBUTING/#attribution","title":"Attribution","text":"

This guide is based on the contributing-gen. Make your own!

"},{"location":"explanation/","title":"Explanation","text":""},{"location":"explanation/mental-model/","title":"The mental model used by Bump My Version","text":""},{"location":"explanation/mental-model/#overview","title":"Overview","text":"

There are four main concepts in Bump My Version:

  1. Configuration
  2. Version handling
  3. File changing
  4. Source control management interface
"},{"location":"explanation/mental-model/#configuration","title":"Configuration","text":"

The predecessor to Bump My Version, bumpversion, was designed to have the configuration file optional. All configuration values could be specified on the command line. This only worked in the simplest of version schemes.

While Bump My Version can do many things without a configuration file, it is designed to have a configuration file. The configuration file is required to specify the version scheme. The configuration file also specifies the files to change and how to change them.

"},{"location":"explanation/mental-model/#version-handling","title":"Version handling","text":"

Bump My Version abstracts the version handling into a few concepts:

A version spec defines the rules for incrementing a version.

A version component spec defines how a single part of a version spec, such as major, minor, or patch, works. It defines the types of values, how to increment the component, and how to reset it.

A version parser is a regular expression used in several ways. Its named capture groups define the possible components in a version spec and the order in which they appear. It also parses a version string into version component names and their values.

A version is the concrete representation of a version spec. It is a mapping of version component names to version components.

A version component is the concrete representation of a version component spec. It is a version component spec with a specific value.

A version serialization format is a list of format strings used to serialize a version into a string.

"},{"location":"explanation/mental-model/#how-a-version-spec-is-generated","title":"How a version spec is generated","text":"How a configuration file is used to generate a version spec.

The most important part of the configuration file is the version parser. It defines the structure of the version spec.

If the configuration file contains a version component spec that matches a named capture group in the version parser, then that version component spec is used in the version spec. The yellow and green named capture groups in the diagram demonstrate this.

If the configuration file does not contain a version component spec that matches a named capture group in the version parser, then a default version component spec is used. The blue named capture group in the diagram demonstrates this.

The component dependency graph determines the order in which the version components are incremented and reset. For example, in the diagram, the patch component depends on the minor component, which depends on the major component. Therefore, when the major component is incremented, the minor component is reset, which cascades to the patch component.

"},{"location":"explanation/mental-model/#how-a-version-is-generated","title":"How a version is generated","text":"How a version spec is used to generate a version.

The version spec has a create_version method that takes a mapping of version component names to values.

Each version component spec has a create_component method that takes a value. The create_version method calls the create_component method for each version component spec in the version spec with the value from the mapping.

The create_component assembles its version spec_ with the version components to create a version.

"},{"location":"explanation/mental-model/#how-a-version-is-serialized","title":"How a version is serialized","text":"

Optional value rule. Version component specs can define an optional value. For example, numeric components have 0 as an optional value. Optional values may be omitted from the serialization as long as all dependent components also have optional values.

Required value rule. Version component specs is required if its value or the value of any of its dependent components is not optional.

A valid serialization contains all the required components in the version spec based on the required value rule.

An invalid serialization does not contain all the required components in the version spec based on the required value rule.

The optimal serialization is the valid serialization that uses the fewest components.

The serialize method of the version spec returns either the optimal serialization or the first invalid serialization.

"},{"location":"explanation/mental-model/#version-serialization-examples","title":"Version serialization examples","text":"

No optional values

In this example, the major component is 1, the minor component is 2, and patch component is 3. Since none of the values are optional (0), only one serialization format is valid. This one valid format is the optimal format.

One optional value

A version with values major=1, minor=2, and patch=0 has two valid serializations. The optimal serialization is the one that uses the fewest components. 1.2 in this example.

Two optional values

A version with values major=1, minor=0, and patch=0 has three valid serializations. The optimal serialization is the one that uses the fewest components. 1 in this example.

No valid serialization options

A version with values major=1, minor=2, and patch=3 has no valid serializations in this example. The serialize method returns the first invalid serialization.

"},{"location":"howtos/","title":"How-To Guides","text":"
  • Avoid incorrect replacements
  • Custom version formats by file
  • Multiple replacements
"},{"location":"howtos/avoid-incorrect-replacements/","title":"Avoiding incorrect replacements","text":"

In files that have multiple version strings, Bump My Version may find the wrong string and replace it. Given this requirements.txt for MyProject:

Django>=1.5.6,<1.6\nMyProject==1.5.6\n

The default search and replace templates will replace the wrong text. Instead of changing MyProject\u2019s version from 1.5.6 to 1.6.0, it changes Django\u2019s version:

Django>=1.6.0,<1.6\nMyProject==1.5.6\n

Providing search and replace templates for the requirements.txt file will avoid this.

This .bumpversion.toml will ensure only the line containing MyProject will be changed:

[tool.bumpversion]\ncurrent_version = \"1.5.6\"\n\n[[tool.bumpversion.files]]\nfilename = \"requirements.txt\"\nsearch = \"MyProject=={current_version}\"\nreplace = \"MyProject=={new_version}\"\n

If the string to be replaced includes literal quotes, the search and replace patterns must include them to match. Given the file version.sh:

MY_VERSION=\"1.2.3\"\n

Then the following search and replace patterns (including quotes) would be required:

[[tool.bumpversion.files]]\nfilename = \"version.sh\"\nsearch = \"MY_VERSION=\\\"{current_version}\\\"\"\nreplace = \"MY_VERSION=\\\"{new_version}\\\"\"\n
"},{"location":"howtos/calver/","title":"Using Calendar Versioning (CalVer)","text":"

Calendar Versioning (CalVer) is a versioning scheme that uses a date-based version number.

For this example, we will use the following format: YYYY.MM.DD.patch. It will yield numbers like:

  • 2022.2.1 for the first patch of February 1, 2022
  • 2022.2.1.1 for the second patch of February 1, 2022
"},{"location":"howtos/calver/#initial-configuration","title":"Initial configuration","text":".bumpversion.toml
[tool.bumpversion]\ncurrent_version = \"2024.3.1.4\"\nparse = \"\"\"(?x)                     # Verbose mode\n    (?P<release>                    # The release part\n        (?:[1-9][0-9]{3})\\\\.        # YYYY.\n        (?:1[0-2]|[1-9])\\\\.         # MM.\n        (?:3[0-1]|[1-2][0-9]|[1-9]) # DD\n    )\n    (?:\\\\.(?P<patch>\\\\d+))?         # .patch, optional\n\"\"\"\nserialize = [\"{release}.{patch}\", \"{release}\"]\n\n[tool.bumpversion.parts.release]\ncalver_format = \"{YYYY}.{MM}.{DD}\"\n

You can look up the regular expressions for the CalVer format in the CalVer reference.

"},{"location":"howtos/calver/#expected-behavior","title":"Expected behavior","text":"

You can find out more about the logic behind the CalVer incrementing in the CalVer reference.

"},{"location":"howtos/calver/#bumping-the-release-resets-the-patch-part","title":"Bumping the release resets the patch part","text":"

When you bump the calendar version, the patch is reset to 0 even if the release did not change.

Bumping the release resets patch
$ date -I      \n2024-03-1\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.1\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.1.5\n

The next day:

Bumping the release resets patch, the next day
$ date -I      \n2024-03-2\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.2\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.2\n
"},{"location":"howtos/calver/#the-result-of-a-bump-to-patch-depends-on-the-date","title":"The result of a bump to patch depends on the date","text":"

Calendar Versioned parts are updated with every bump, regardless of the part being bumped. If you are bumping the version within the same time period (in this example, the same day), the release part will not change. So bumping the patch part will increment the patch part only.

Bumping patch on the same day
$ date -I      \n2024-03-1\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.1\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.1.5\n

However, if you bump the version on the next day, the release part will also be updated.

Bumping patch on the next day
$ date -I      \n2024-03-2\n$ bump-my-version show-bump\n2024.3.1.4 \u2500\u2500 bump \u2500\u252c\u2500 release \u2500 2024.3.2\n                    \u2570\u2500 patch \u2500\u2500\u2500 2024.3.2\n
"},{"location":"howtos/custom-version-formats-by-file/","title":"Custom version formats in different files","text":"

You can use file configurations to replace the version in multiple files, even if each file has the version formatted differently.

In a module-aware Go project, when you create a major version of your module beyond v1, your module name must include the major version number (e.g., github.com/myorg/myproject/v2). However, you also have the full version in a YAML file named release-channels.yaml.

go.mod file:

module github.com/myorg/myproject/v2\n\ngo 1.12\n\nrequire (\n    ...\n)\n

release-channels.yaml file:

stable: \"v2.21.4\"\n

You can use Bump My Version to maintain the major version number within the go.mod file by using the parse and serialize options, as in this example:

.bumpversion.toml file:

[tool.bumpversion]\ncurrent_version = \"2.21.4\"\n\n[[tool.bumpversion.files]]\nfilename = \"go.mod\"\nparse = \"(?P<major>\\\\d+)\"\nserialize = \"{major}\"\nsearch = \"module github.com/myorg/myproject/v{current_version}\"\nreplace = \"module github.com/myorg/myproject/v{new_version}\"\n\n[[tool.bumpversion.files]]\nfilename = \"release-channels.yaml\"\n

While all the version bumps are minor or patch, the go.mod file doesn\u2019t change, while the release-channels.yaml file will. As soon as you do a major version bump, the go.mod file now contains this module directive:

module github.com/myorg/myproject/v3\n
"},{"location":"howtos/multiple-replacements/","title":"Multiple replacements within the same file","text":"

To make several replacements in the same file, you must configure multiple [[tool.bumpversion.files]] sections for the same file with different configuration options.

In this example, the changelog is generated before the version bump. It uses Unreleased as the heading and includes a link to GitHub to compare this version (HEAD) with the previous version.

To change Unreleased to the current version, we have an entry with search set to Unreleased. The default replace value is {new_version}, so changing it is unnecessary.

To change the link, another entry has its search set to {current_version}...HEAD and the replace set to {current_version}...{new_version}.

[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"Unreleased\"\n\n[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"{current_version}...HEAD\"\nreplace = \"{current_version}...{new_version}\"\n
"},{"location":"howtos/update-a-date/","title":"How to update a date in a file","text":"

Many times when bumping a version, you will also want to update a date in a file. This is a common use case for changelogs, but it could be any file that contains a date. In this example, we have an __init__.py that looks like this:

my_package/__init__.py
__date__ = '2022-12-19'\n__version__ = '0.4.0'\n

The desired outcome is to update the date to the current date. For example, if today is February 23, 2024, the init.py file should look like this after a minor bump:

my_package/__init__.py
__date__ = '2024-02-23'\n__version__ = '0.5.0'\n
"},{"location":"howtos/update-a-date/#setting-up-the-file-configurations","title":"Setting up the file configurations","text":"

We need Bump My Version to update the __init__.py file twice: once for the version and once for the date. Here is the necessary configuration:

.bumpversion.toml or other config file
[[tool.bumpversion.files]]\nfilename = '__init__.py'\nsearch = \"__date__ = '\\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}'\"\nreplace = \"__date__ = '{now:%Y-%m-%d}'\"\nregex = true\n\n[[tool.bumpversion.files]]\nfilename = '__init__.py'\n
"},{"location":"reference/","title":"Reference","text":"
  • Subcommands
  • Command-line interface
  • Configuration
  • Calendar versioning reference
  • Formatting context
  • Version parts
  • Search and replace configuration
  • API
"},{"location":"reference/calver_reference/","title":"Calendar versioning reference","text":""},{"location":"reference/calver_reference/#calendar-versioning-codes","title":"Calendar versioning codes","text":"

The following table lists the available format codes for calendar versioning (CalVer) schemes. The codes can be used to define the version format in the calver_format configuration options. Formatting codes, surrounded by { } can be combined to create a custom version format. For example, the format YYYY.MM.DD can be defined as \"{YYYY}.{MM}.{DD}\".

Code Example(s) Comment YYYY 2000, 2001, \u2026, 2099 Full year YY 0, 1, 2, \u2026, 99 Short year as integer 0Y 00, 01, 02, \u2026, 99 Short Year, zero-padded MMM Jan, Feb, jan, f\u00e9v Month abbreviation, locale-based MM 1, 2, \u2026, 12 Month as integer 0M 01, 02, \u2026, 12 Month, zero-padded DD 1, 2, \u2026, 31 Day of month as integer 0D 01, 02, \u2026, 31 Day of month, zero-padded JJJ 1, 2, 3, \u2026, 366 Day of year as integer 00J 001, 002, \u2026, 366 Day of year, zero-padded Q 1, 2, 3, 4 Quarter WW 0, 1, 2, \u2026, 53 Week number, Monday is first day 0W 00, 01, 02, \u2026, 53 Week number, Monday is first day, zero-padded UU 0, 1, 2, \u2026, 53 Week number, Sunday is first day 0U 00, 01, 02, \u2026, 53 Week number, Sunday is first day, zero-padded VV 1, 2, \u2026, 53 ISO 8601 week number as integer 0V 01, 02, \u2026, 53 ISO 8601 week number, zero-padded GGGG 2000, 2001, \u2026, 2099 ISO 8601 week-based year GG 0, 1, 2, \u2026, 99 ISO 8601 short week-based year as integer 0G 01, 02, \u2026, 99 ISO 8601 short week-based year, zero-padded Example configuration
[tool.bumpversion.parts.release]\ncalver_format = \"{YYYY}.{MM}.{DD}\"\n
"},{"location":"reference/calver_reference/#parsing-calver-versions","title":"Parsing CalVer versions","text":"

Using the following chart, we can set up the version parsing:

Code Regex YYYY (?:[1-9][0-9]{3}) YY (?:[1-9][0-9]?) 0Y (?:[0-9]{2}) MMM See below MM (?:1[0-2]\\|[1-9]) 0M (?:1[0-2]\\|0[1-9]) DD (?:3[0-1]\\|[1-2][0-9]\\|[1-9]) 0D (?:3[0-1]\\|[1-2][0-9]\\|0[1-9]) JJJ (?:36[0-6]\\|3[0-5][0-9]\\|[1-2][0-9][0-9]\\|[1-9][0-9]\\|[1-9]) 00J (?:36[0-6]\\|3[0-5][0-9]\\|[1-2][0-9][0-9]\\|0[1-9][0-9]\\|00[1-9]) Q (?:[1-4]) WW (?:5[0-3]\\|[1-4][0-9]\\|[0-9]) 0W (?:5[0-3]\\|[0-4][0-9]) UU (?:5[0-3]\\|[1-4][0-9]\\|[0-9]) 0U (?:5[0-3]\\|[0-4][0-9]) VV (?:5[0-3]\\|[1-4][0-9]\\|[1-9]) 0V (?:5[0-3]\\|[1-4][0-9]\\|0[1-9]) GGGG (?:[1-9][0-9]{3}) GG (?:[0-9][0-9]?) 0G (?:[0-9]{2})

Month abbreviations

The month abbreviation is locale-based. Here are some examples:

(?:Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec) for English

(?:jan|f\u00e9v|mar|avr|mai|jui|jui|ao\u00fb|sep|oct|nov|d\u00e9c) for French

You can use these regular expressions to parse CalVer versions in your project. For example, the following parse configuration can be used to parse a version string in the format YYYY.MM.DD as the release part of the version string:

[tool.bumpversion]\nparse = \"\"\"(?x)                      # Verbose mode\n    (?P<release>\n        (?:[1-9][0-9]{3})\\\\.         # YYYY.\n        (?:1[0-2]|[1-9])\\\\.          # MM.\n        (?:3[0-1]|[1-2][0-9]|[1-9])  # DD\n    )\n\"\"\"\n
"},{"location":"reference/calver_reference/#calver-incrementing-logic","title":"CalVer incrementing logic","text":"
  • CalVer version components are marked as always_increment by default.
  • When bumping a version, you specify which component to increment. It is called the target component.
  • When bumping a version, the components marked as always_increment are incremented first.
  • If an always_increment component\u2019s value changed, its dependent components are marked for reset to their default values.
  • If the target component is in the set of components marked for reset, the target component is reset to its default value.
  • If the target component is not in the set of components marked for reset, the target component is incremented and its dependent components are reset to their default values.
"},{"location":"reference/cli/","title":"CLI Reference","text":""},{"location":"reference/cli/#bump-my-version","title":"bump-my-version","text":"

Version bump your Python project.

Usage:

bump-my-version [OPTIONS] COMMAND [ARGS]...\n

Options:

Name Type Description Default --version boolean Show the version and exit. False --help boolean Show this message and exit. False

Subcommands

  • bump:
  • replace:
  • sample-config: Print a sample configuration file.
  • show:
  • show-bump: Show the possible versions resulting from the bump subcommand.
"},{"location":"reference/cli/#bump-my-version-bump","title":"bump-my-version bump","text":"

Change the version.

ARGS may contain any of the following:

VERSION_PART is the part of the version to increase, e.g. minor. Valid values include those given in the --serialize / --parse option.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

Usage:

bump-my-version bump [OPTIONS] [ARGS]...\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None -v, --verbose integer range (0 and above) Print verbose logging to stderr. Can specify several times for more verbosity. 0 --allow-dirty / --no-allow-dirty boolean Don\u2019t abort if working directory is dirty, or explicitly abort if dirty. None --current-version text Version that needs to be updated None --new-version text New version that should be in the files None --parse text Regex parsing the version string None --serialize text How to format what is parsed back to a version None --search text Template for complete string to search None --replace text Template for complete string to replace None --regex / --no-regex boolean Treat the search parameter as a regular expression or explicitly do not treat it as a regular expression. None --no-configured-files boolean Only replace the version in files specified on the command line, ignoring the files from the configuration file. False --ignore-missing-files / --no-ignore-missing-files boolean Ignore any missing files when searching and replacing in files. None --ignore-missing-version / --no-ignore-missing-version boolean Ignore any Version Not Found errors when searching and replacing in files. None --dry-run, -n boolean Don\u2019t write any files, just pretend. False --commit / --no-commit boolean Commit to version control None --tag / --no-tag boolean Create a tag in version control None --sign-tags / --no-sign-tags boolean Sign tags if created None --tag-name text Tag name (only works with \u2013tag) None --tag-message text Tag message None -m, --message text Commit message None --commit-args text Extra arguments to commit command None --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-replace","title":"bump-my-version replace","text":"

Replace the version in files.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

Usage:

bump-my-version replace [OPTIONS] [FILES]...\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None -v, --verbose integer range (0 and above) Print verbose logging to stderr. Can specify several times for more verbosity. 0 --allow-dirty / --no-allow-dirty boolean Don\u2019t abort if working directory is dirty, or explicitly abort if dirty. None --current-version text Version that needs to be updated None --new-version text New version that should be in the files. If not specified, it will be None. None --parse text Regex parsing the version string None --serialize text How to format what is parsed back to a version None --search text Template for complete string to search None --replace text Template for complete string to replace None --regex / --no-regex boolean Treat the search parameter as a regular expression or explicitly do not treat it as a regular expression. False --no-configured-files boolean Only replace the version in files specified on the command line, ignoring the files from the configuration file. False --ignore-missing-version boolean Ignore any Version Not Found errors when searching and replacing in files. False --ignore-missing-files boolean Ignore any missing files when searching and replacing in files. False --dry-run, -n boolean Don\u2019t write any files, just pretend. False --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-sample-config","title":"bump-my-version sample-config","text":"

Print a sample configuration file.

Usage:

bump-my-version sample-config [OPTIONS]\n

Options:

Name Type Description Default --prompt / --no-prompt boolean Ask the user questions about the configuration. True --destination choice (stdout | .bumpversion.toml | pyproject.toml) Where to write the sample configuration. stdout --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-show","title":"bump-my-version show","text":"

Show current configuration information.

ARGS may contain one or more configuration attributes. For example:

  • bump-my-version show current_version
  • bump-my-version show files.0.filename
  • bump-my-version show scm_info.branch_name
  • bump-my-version show current_version scm_info.distance_to_latest_tag

Usage:

bump-my-version show [OPTIONS] [ARGS]...\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None -f, --format choice (default | yaml | json) Config file to read most of the variables from. default -i, --increment text Increment the version part and add new_version to the configuration. None --help boolean Show this message and exit. False"},{"location":"reference/cli/#bump-my-version-show-bump","title":"bump-my-version show-bump","text":"

Show the possible versions resulting from the bump subcommand.

Usage:

bump-my-version show-bump [OPTIONS] [VERSION]\n

Options:

Name Type Description Default --config-file path Config file to read most of the variables from. None --ascii boolean Use ASCII characters only. False --help boolean Show this message and exit. False"},{"location":"reference/configuration/","title":"Configuration","text":"

Bump My Version looks in three places for configuration information (in order of precedence):

  1. command line
  2. configuration file
  3. environment variables
"},{"location":"reference/configuration/#configuration-files","title":"Configuration files","text":"

Bump My Version looks in four places for the configuration file to parse (in order of precedence):

  1. --config-file <FILE> (command line argument)
  2. BUMPVERSION_CONFIG_FILE=file (environment variable)
  3. .bumpversion.cfg (legacy)
  4. .bumpversion.toml
  5. setup.cfg (legacy)
  6. pyproject.toml

.toml files are recommended. We will likely drop support for ini-style formats in the future. You should add your configuration file to your source code management system.

By using a configuration file, you no longer need to specify those options on the command line. The configuration file also allows greater flexibility in specifying how files are modified.

"},{"location":"reference/configuration/#global-configuration","title":"Global Configuration","text":"

The general configuration is grouped in a [tool.bumpversion] or [bumpversion] section, depending on if it is a TOML or INI file, respectfully.

"},{"location":"reference/configuration/#allow_dirty","title":"allow_dirty","text":"required No default False type boolean command line option --allow-dirty | --no-allow-dirty environment var BUMPVERSION_ALLOW_DIRTY

Bump-my-version\u2019s default behavior is to abort if the working directory has uncommitted changes. This protects you from releasing unversioned files and overwriting unsaved changes.

"},{"location":"reference/configuration/#commit","title":"commit","text":"required No default False (Don\u2019t create a commit) type boolean command line option --commit | --no-commit environment var BUMPVERSION_COMMIT

Whether to create a commit using git or Mercurial.

If you have pre-commit hooks, add an option to commit_args to turn off your pre-commit hooks. For Git, use --no-verify and use --config hooks.pre-commit= for Mercurial.

"},{"location":"reference/configuration/#commit_args","title":"commit_args","text":"required No default \"\" type string command line option --commit-args environment var BUMPVERSION_COMMIT_ARGS

Extra arguments to pass to commit command. This is only used when the commit option is set to True.

If you have pre-commit hooks, add an option to turn off your pre-commit hooks. For Git, use --no-verify and use --config hooks.pre-commit= for Mercurial.

"},{"location":"reference/configuration/#current_version","title":"current_version","text":"required Yes default \"\" type string command line option --current-version environment var BUMPVERSION_CURRENT_VERSION

The current version of the software package before bumping. A value for this is required.

"},{"location":"reference/configuration/#ignore_missing_files","title":"ignore_missing_files","text":"required No default False type boolean command line option --ignore-missing-files environment var BUMPVERSION_IGNORE_MISSING_FILES

If True, don\u2019t fail if the configured file is missing.

"},{"location":"reference/configuration/#ignore_missing_version","title":"ignore_missing_version","text":"required No default False type boolean command line option --ignore-missing-version environment var BUMPVERSION_IGNORE_MISSING_VERSION

If True, don\u2019t fail if the version string to be replaced is not found in the file.

"},{"location":"reference/configuration/#message","title":"message","text":"required No default Bump version: {current_version} \u2192 {new_version} type string command line option --message environment var BUMPVERSION_MESSAGE

The commit message template to use when creating a commit. This is only used when the commit option is set to True.

This string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

"},{"location":"reference/configuration/#parse","title":"parse","text":"required No default (?P<major>\\d+)\\.(?P<minor>\\d+)\\.(?P<patch>\\d+) type string command line option --parse environment var BUMPVERSION_PARSE

This is the default regular expression (Python regular expression syntax) for finding and parsing the version string into its components. Individual part or file configurations may override this.

The regular expression must be able to parse all strings produced by the configured serialize value. Named matching groups (\u201c(?P<name>...)\u201d) indicate the version part the matched value belongs to.

"},{"location":"reference/configuration/#regex","title":"regex","text":"required No default False type boolean command line option --regex | --no-regex environment var BUMPVERSION_REGEX

Treat the search string as a regular expression.

"},{"location":"reference/configuration/#replace","title":"replace","text":"required No default {new_version} type string command line option --replace environment var BUMPVERSION_REPLACE

This is the template to create the string that will replace the current version number in the file.

"},{"location":"reference/configuration/#search","title":"search","text":"required No default {current_version} type string command line option --search environment var BUMPVERSION_SEARCH

This is the template string for searching. It is rendered using the formatting context for searching in the file. Individual file configurations may override this. This can span multiple lines and is templated using Python Format String Syntax. The formatting context reference describes the available variables.

This is useful if there is the remotest possibility that the current version number might be present multiple times in the file and you mean to bump only one of the occurrences.

"},{"location":"reference/configuration/#serialize","title":"serialize","text":"required No default [\"{major}.{minor}.{patch}\"] type an array of strings command line option --serialize environment var BUMPVERSION_SERIALIZE

This is the default list of templates specifying how to serialize the version parts back to a version string. Individual part or file configurations may override this.

Since version parts can be optional, bumpversion will try the serialization formats beginning with the first and choose the last one where all values can all non-optional values are represented.

In this example (in TOML):

serialize = [\n    \"{major}.{minor}.{patch}\",\n    \"{major}.{minor}\",\n    \"{major}\"\n]\n

Since 0 is optional by default, Version 1.8.9 will serialize to 1.8.9, 1.9.0 will serialize to 1.9, and version 2.0.0 will serialize as 2.

Each string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

"},{"location":"reference/configuration/#sign_tags","title":"sign_tags","text":"required No default False (Don\u2019t sign tags) type boolean command line option --sign-tags | --no-sign-tags environment var BUMPVERSION_SIGN_TAGS

If True, sign the created tag, when tag is True.

"},{"location":"reference/configuration/#tag","title":"tag","text":"required No default False (Don\u2019t create a tag) type boolean command line option --tag | --no-tag environment var BUMPVERSION_TAG

If True, create a tag after committing the changes. The tag is named using the tag_name option.

If you are using git, don\u2019t forget to git-push with the --tags flag when you are done.

"},{"location":"reference/configuration/#tag_message","title":"tag_message","text":"required No default Bump version: {current_version} \u2192 {new_version} type string command line option --tag-message environment var BUMPVERSION_TAG_MESSAGE

The tag message template to use when creating a tag when tag is True

This string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

Bump My Version creates an annotated tag in Git by default. To turn this off and create a lightweight tag, you must explicitly set an empty tag_message value.

"},{"location":"reference/configuration/#tag_name","title":"tag_name","text":"required No default v{new_version} type string command line option --tag-name environment var BUMPVERSION_TAG_NAME

The template used to render the tag when tag is True.

This string is templated using the Python Format String Syntax. The formatting context reference describes the available variables.

"},{"location":"reference/configuration/#examples","title":"Examples","text":"TOMLCFG
[tool.bumpversion]\nallow_dirty = false\ncommit = false\nmessage = \"Bump version: {current_version} \u2192 {new_version}\"\ncommit_args = \"\"\ntag = false\nsign_tags = false\ntag_name = \"v{new_version}\"\ntag_message = \"Bump version: {current_version} \u2192 {new_version}\"\ncurrent_version = \"1.0.0\"\nparse = \"(?P<major>\\\\d+)\\\\.(?P<minor>\\\\d+)\\\\.(?P<patch>\\\\d+)\"\nserialize = [\n    \"{major}.{minor}.{patch}\"\n]\nsearch = \"{current_version}\"\nreplace = \"{new_version}\"\n
[bumpversion]\nallow_dirty = False\ncommit = False\nmessage = Bump version: {current_version} \u2192 {new_version}\ncommit_args = \ntag = False\nsign_tags = False\ntag_name = v{new_version}\ntag_message = Bump version: {current_version} \u2192 {new_version}\ncurrent_version = 1.0.0\nparse = (?P<major>\\d+)\\.(?P<minor>\\d+)\\.(?P<patch>\\d+)\nserialize =\n    {major}.{minor}.{patch}\nsearch = {current_version}\nreplace = {new_version}\n
"},{"location":"reference/configuration/#version-part-specific-configuration","title":"Version part-specific configuration","text":"

Version part configuration is grouped in a [tool.bumpversion.parts.<partname>] or [bumpversion:part:<partname>] section, depending on if it is a TOML or INI file, respectfully.

You only need to configure version parts if they deviate from the default, and then you only need to specify the overridden options.

"},{"location":"reference/configuration/#values","title":"values","text":"required No default numeric (i.e. 0, 1, 2, \u2026) type array of strings

An explicit list of all values to iterate through when bumping this part. An empty array is treated as indicating numeric values.

"},{"location":"reference/configuration/#optional_value","title":"optional_value","text":"required No default The first entry in values, 0 when using numeric values type string

When the version part matches this value, it is considered optional when serializing the final version string.

Note

Numeric values are still treated as strings internally, so when specifying an optional value, you must use a string.

"},{"location":"reference/configuration/#first_value","title":"first_value","text":"required No default The first entry in values, 0 when using numeric values type string

When the part is reset, the value will be set to the value specified here.

Note

Numeric values are still treated as strings internally, so when specifying a first value, you must use a string.

"},{"location":"reference/configuration/#independent","title":"independent","text":"required No default False type boolean

When this value is set to True, the part is not reset when other parts are incremented. Its incrementation is independent of the other parts. It is useful when you have a build number in your version that is incremented independently of the actual version.

"},{"location":"reference/configuration/#always_increment","title":"always_increment","text":"required No default False (True if calver_format is set) type boolean

When this value is set to True, the part is always incremented when the version is bumped, regardless of the target part.

"},{"location":"reference/configuration/#calver_format","title":"calver_format","text":"required No default empty type string

The calver_format is a string that specifies the format of the version part. It is used to determine the next value when bumping the version. The format is a string that uses the placeholders defined in the CalVer reference.

"},{"location":"reference/configuration/#examples_1","title":"Examples","text":"TOMLCFG
[tool.bumpversion.parts.release]\nvalues = [\n    \"alpha\",\n    \"beta\",\n    \"gamma\"\n]\noptional_value = \"gamma\"\n
[bumpversion:part:release]\noptional_value = gamma\nvalues =\n    alpha\n    beta\n    gamma\n
"},{"location":"reference/configuration/#file-specific-configuration","title":"File-specific configuration","text":"

This section configures which files Bump My Version should update by replacing their current version with the newly bumped version.

"},{"location":"reference/configuration/#filename","title":"filename","text":"required Yes\u2021 default empty type string

The name of the file to modify.

Note

\u2021 This is only used with TOML configuration and is only required if glob is not specified. INI-style configuration files specify the file name as part of the grouping.

"},{"location":"reference/configuration/#glob","title":"glob","text":"required Yes\u2021 default empty type string

The glob pattern specifying the files to modify.

Note

\u2021 This is only used with TOML configuration, and is only required if filename is not specified. INI-style configuration files specify the glob pattern as part of the grouping.

"},{"location":"reference/configuration/#glob_exclude","title":"glob_exclude","text":"required No default empty type list of string

A list of glob patterns to exclude from the files found via the glob parameter. Does nothing if filename is specified.

"},{"location":"reference/configuration/#parse_1","title":"parse","text":"required No default the value configured in the global parse field type string

This is an override to the default pattern to parse the version number from this file.

"},{"location":"reference/configuration/#serialize_1","title":"serialize","text":"required No default the value configured in the global serialize field type an array of strings

This is an override to the default templates to serialize the new version number in this file.

"},{"location":"reference/configuration/#search_1","title":"search","text":"required No default the value configured in the global search field type string

This is an override to the default template string how to search for the string to be replaced in the file.

"},{"location":"reference/configuration/#regex_1","title":"regex","text":"required No default the value configured in the global regex field type boolean

If True, treat the search parameter as a regular expression.

"},{"location":"reference/configuration/#replace_1","title":"replace","text":"required No default the value configured in the global replace field type string

This is an override to the template to create the string that will replace the current version number in the file.

"},{"location":"reference/configuration/#ignore_missing_version_1","title":"ignore_missing_version","text":"required No default The value configured in the global ignore_missing_version field type boolean

If True, don\u2019t fail if the version string to be replaced is not found in the file.

"},{"location":"reference/configuration/#ignore_missing_file","title":"ignore_missing_file","text":"required No default The value configured in the global ignore_missing_file field type boolean

if True, don\u2019t fail if the configured file is missing.

"},{"location":"reference/configuration/#include_bumps","title":"include_bumps","text":"required No default all version components type list of strings

The include_bumps file configuration allows you to control when bump-my-version includes this file for changes. Its alternative is the exclude_bumps configuration. When a bump <version component> command is issued, this file is changed only if the version component is in this list and not in exclude_bumps. The parse configuration defines version components.

The default value, or an empty list, includes all version components.

"},{"location":"reference/configuration/#exclude_bumps","title":"exclude_bumps","text":"required No default [] type list of strings

The exclude_bumps file configuration allows you to control when bump-my-version excludes this file for changes. Its alternative is the include_bumps configuration. When a bump <version component> command is issued, this file is only changed if the version component is not in this list. The parse configuration defines version components.

The default value does not exclude anything.

"},{"location":"reference/configuration/#examples_2","title":"Examples","text":"TOMLCFG

TOML allows us to specify the files using an array of tables. TOML configuration adds two fields to each file configuration: filename and glob. These fields are mutually exclusive: if you specify a value for both, only the glob value is used.

For example, to change coolapp/__init__.py with the defaults and alter CHANGELOG.md twice:

[[tool.bumpversion.files]]\nfilename = \"coolapp/__init__.py\"\n\n[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"Unreleased\"\n\n[[tool.bumpversion.files]]\nfilename = \"CHANGELOG.md\"\nsearch = \"{current_version}...HEAD\"\nreplace = \"{current_version}...{new_version}\"\n

INI-style configuration is in the section: [bumpversion:file:<filename>] or [bumpversion:glob:<glob pattern>].

Both, file: and glob: are configured the same. Their difference is that file will match file names directly like requirements.txt. While glob also matches multiple files via wildcards like **/pom.xml.

Note

The configuration file format requires each section header to be unique. If you want to process a certain file multiple times, you may append a description between parens to the file keyword: [bumpversion:file (special one):\u2026].

For example, to change coolapp/__init__.py with the defaults and alter CHANGELOG.md twice:

[bumpversion:file:coolapp/__init__.py]\n\n[bumpversion:file(version heading):CHANGELOG.md]\nsearch = Unreleased\n\n[bumpversion:file(previous version):CHANGELOG.md]\nsearch = {current_version}...HEAD\nreplace = {current_version}...{new_version}\n
"},{"location":"reference/formatting-context/","title":"Formatting context","text":"

These fields are available for

  • version serializing
  • searching and replacing in files
  • commit messages
  • tag names
  • tag annotations
"},{"location":"reference/formatting-context/#escaped-characters","title":"Escaped characters","text":"# The literal hash or octothorpe character. ; The literal semicolon character."},{"location":"reference/formatting-context/#date-and-time-fields","title":"Date and time fields","text":"now A Python datetime object representing the current local time, without a time zone reference. utcnow A Python datetime object representing the current local time in the UTC time zone.

You can provide additional formatting guidance for datetime objects using formatting codes. Put the formatting codes after the field and a colon. For example, {now:%Y-%m-%d} would output the current local time as 2023-04-20.

"},{"location":"reference/formatting-context/#source-code-management-fields","title":"Source code management fields","text":"

These fields will only have values if the code is in a Git or Mercurial repository.

commit_sha The latest commit reference. distance_to_latest_tag The number of commits since the latest tag. dirty A boolean indicating if the current repository has pending changes. branch_name The current branch name. short_branch_name The current branch name, converted to lowercase, with non-alphanumeric characters removed and truncated to 20 characters. For example, feature/MY-long_branch-name would become featuremylongbranchn."},{"location":"reference/formatting-context/#version-fields","title":"Version fields","text":"current_version The current version serialized as a string current_<version part> Each version part defined by the version configuration parsing regular expression. The default configuration would have current_major, current_minor, and current_patch available. new_version The new version serialized as a string new_<version part> Each version part defined by the version configuration parsing regular expression. The default configuration would have new_major, new_minor, and new_patch available.

Note

The following fields are only available when serializing a version.

<version part> Each version part defined by the version configuration parsing regular expression. The default configuration would have major, minor, and patch available."},{"location":"reference/formatting-context/#environment-variables","title":"Environment variables","text":"

Every environment variable available at runtime is included with a $ prefix. For example if USER was in the environment, {$USER} would render that value.

Tip

If you use environment variables in your version serialization, you might want to ensure they are set by executing export VAR=value before running the bump-my-version command.

"},{"location":"reference/search-and-replace-config/","title":"Search and replace configuration","text":"

Bump-my-version uses a combination of template strings using a formatting context and regular expressions to search the configured files for the old or current version and replace the text with the new version.

Bump My Version defaults to using a simple string search. If the search template is not a valid regular expression or if the no-regex flag is True. The search template is always rendered using the formatting context. The basic logic is:

  1. Escape the formatting context for use in a regular expression.
  2. Render the search string using the escaped formatting context.
  3. Attempt to compile the rendered search string as a regular expression.
  4. If the rendered search string is a valid regular expression, use it.
  5. If the rendered search string is not a valid regular expression or the no-regex flag is True, use the search string rendered with the unescaped context.
"},{"location":"reference/search-and-replace-config/#using-template-strings","title":"Using template strings","text":"

Both the search and replace templates are rendered using the formatting context. However, only the search template is also treated as a regular expression. The replacement fields available in the formatting context are enclosed in curly braces {}.

The search and replace templates can be multiple lines, like so:

[tool.bumpversion]\ncurrent_version = \"1.2.3\"\n\n[[tool.bumpversion.files]]\nfilename = \"config.ini\"\nsearch = \"[myproject]\\nversion={current_version}\"\nreplace = \"[myproject]\\nversion={new_version}\"\n

Alternatively, using TOML\u2019s multiline strings:

[tool.bumpversion]\ncurrent_version = \"1.2.3\"\n\n[[tool.bumpversion.files]]\nfilename = \"config.ini\"\nsearch = \"\"\"\n[myproject]\nversion={current_version}\"\"\"\n\nreplace = \"\"\"\n[myproject]\nversion={new_version}\"\"\"\n
"},{"location":"reference/search-and-replace-config/#using-regular-expressions","title":"Using regular expressions","text":"

Only the search template will use Python\u2019s regular expression syntax with minor changes. The template string is rendered using the formatting context. The resulting string is treated as a regular expression for searching unless configured otherwise.

Curly braces ({}) must be doubled in the regular expression to escape them from the string-formatting process.

If you are using a TOML-formatted configuration file, you must also escape backslashes (\\) in the regular expression. The TOML parser will treat a single backslash as an escape character.

The following template:

TOMLCFG
search = \"{current_version} date-released: \\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}\"\n
search = \"{current_version} date-released: \\d{{4}}-\\d{{2}}-\\d{{2}}\"\n

Gets rendered to:

1\\.2\\.3 date-released: \\d{4}-\\d{2}-\\d{2}\n

This string is used as a regular expression pattern to search.

"},{"location":"reference/search-and-replace-config/#regular-expression-special-characters","title":"Regular expression special characters","text":"

The ., ^, $, *, +, ?, (), [], {}, \\, | characters are special characters in regular expressions. If your search string contains these characters, you must escape them with a backslash (\\) to treat them as literal characters or set the no-regex flag to True.

For example, if you are looking for this string in a file:

[Unreleased] 2023-07-17\n

and you use this search pattern:

[Unreleased] \\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}\n

Bump My Version will not find the string. While the rendered regular expression [Unreleased] \\d{4}-\\d{2}-\\d{2} is valid, it is not searching for the literal [Unreleased]. Instead, it matches a single character in the list U, n, r, e, l, a, s, d.

You must escape the [ and ] to treat them as literal characters:

\\[Unreleased\\] \\\\d{{4}}-\\\\d{{2}}-\\\\d{{2}}\n
"},{"location":"reference/version-parts/","title":"Version parts","text":"
  • The version string is the rendering of some or all version parts.
  • While the version string may be rendered differently in various places, the value for all parts is maintained in Bump My Version\u2019s configuration.
  • The version parts are typically dependent on each other. Incrementing one part might change other elements.
  • You can compare two version strings (of the same project) and know which is more recent.
"},{"location":"reference/version-parts/#version-configuration","title":"Version configuration","text":"

A version configuration consists of the following:

  • A regular expression that will parse all the possible parts and name them
  • A list of one or more serialization formats

A version string consists of one or more parts; e.g., version 1.0.2 has three parts, separated by a dot (.) character.

The names of these parts are defined in the named groups within the parse regular expression. The default configuration calls them major, minor, and patch.

The serialize configuration value is a list of default formats. You have the option for multiple serialization formats to omit optional values. For example, the following configuration:

serialize = [\n    \"{major}.{minor}.{patch}\",\n    \"{major}.{minor}\",\n]\n

Bump-my-version will serialize using the first format if the patch value is not 0. If the patch value is 0, Bump My Version will use the second format.

"},{"location":"reference/version-parts/#version-part-configuration","title":"Version part configuration","text":"

A version part configuration consists of the following:

  • An incrementing function
  • An optional value
  • A first value
  • A flag indicating its dependence or independence of changes to other version parts
"},{"location":"reference/version-parts/#incrementing-functions","title":"Incrementing functions","text":"

There are two incrementing functions: numeric and value. The numeric function uses integer values and returns the next integer value. The values function uses a sequence of values and returns the next value until finished.

By default, parts use the numeric function starting at 0.

You can configure a part using the values function by providing a list of values in the version part\u2019s configuration. For example, for the release_name part:

[tool.bumpversion.parts.release_name]\nvalues = [\n    \"witty-warthog\", \n    \"ridiculous-rat\", \n    \"marvelous-mantis\",\n]\n
"},{"location":"reference/version-parts/#optional-values","title":"Optional values","text":"

By default, the first value of a version part is considered optional. An optional value may be omitted from the version serialization. Using the example from above:

serialize = [\n    \"{major}.{minor}.{patch}\",\n    \"{major}.{minor}\",\n]\n

Version 1.4.0 is rendered as 1.4 since the patch is 0; as the first value, it is optional.

Optional values are helpful for non-numeric version parts that indicate development stages, such as alpha or beta.

Example:

[tool.bumpversion]\ncurrent_version = \"1.0.0\"\nparse = \"\"\"(?x)\n    (?P<major>[0-9]+)\n    \\\\.(?P<minor>[0-9]+)\n    \\\\.(?P<patch>[0-9]+)\n    (?:\n        -(?P<pre_label>alpha|beta|stable)\n        (?:-(?P<pre_n>[0-9]+))?\n    )?\n\"\"\"\nserialize = [\n    \"{major}.{minor}.{patch}-{pre_label}-{pre_n}\",\n    \"{major}.{minor}.{patch}\",\n]\n\n[tool.bumpversion.parts.pre_label]\noptional_value = \"stable\"\nvalues =[\n    \"alpha\",\n    \"beta\",\n    \"stable\",\n]\n

Bumping the patch part of version 1.0.0 would change the version to 1.0.1-alpha-0. Bumping the pre_label part would change the version to 1.0.1-beta-0. Bumping the pre_label part again would change the version to 1.0.1. The stable-0 is not serialized because both stable and 0 are optional.

"},{"location":"reference/version-parts/#first-values","title":"First Values","text":"

You can specify the starting number with the first_value configuration for numeric version parts.

For example, if we added the following to the above configuration:

[tool.bumpversion.parts.pre_n]\nfirst_value = \"1\"\n

Bumping the patch value of version 1.0.0 would change the version to 1.0.1-alpha-1 instead of 1.0.1-alpha-0.

"},{"location":"reference/version-parts/#independent-values","title":"Independent Values","text":"

In the pattern {major}.{minor}.{patch}-{pre_label}-{pre_n}, each version part resets to its first value when the element preceding it changes. All these version parts are dependent.

You can include a value that incremented independently from the other parts, such as a build part: {major}.{minor}.{patch}-{pre_label}-{pre_n}+{build}\u2014in the configuration for that part, set independent=true.

[tool.bumpversion.parts.build]\nindependent = true\n
"},{"location":"reference/version-parts/#reference","title":"Reference","text":"
  • https://devopedia.org/semantic-versioning
  • https://semver.org
  • https://calver.org
"},{"location":"reference/api/SUMMARY/","title":"SUMMARY","text":"
  • bumpversion * aliases * autocast * bump * cli * config * create * files * files_legacy * models * utils * context * exceptions * files * indented_logger * scm * show * ui * utils * version_part * versioning * conventions * functions * models * serialization * visualize * yaml_dump
"},{"location":"reference/api/bumpversion/","title":"Index","text":""},{"location":"reference/api/bumpversion/aliases/","title":" aliases","text":"

Utilities for handling command aliases.

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup","title":"AliasedGroup","text":"

Bases: RichGroup

This following example implements a subclass of Group that accepts a prefix for a command.

If there were a command called push, it would accept pus as an alias (so long as it was unique)

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup.get_command","title":"get_command","text":"
get_command(\n    ctx: Context, cmd_name: str\n) -> Optional[click.Command]\n

Given a context and a command name, this returns a Command object if it exists or returns None.

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases.AliasedGroup.resolve_command","title":"resolve_command","text":"
resolve_command(ctx: Context, args: List[str]) -> tuple\n

Find the command and make sure the full command name is returned.

"},{"location":"reference/api/bumpversion/aliases/#bumpversion.aliases-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/autocast/","title":" autocast","text":"

Automatically detect the true Python type of a string and cast it to the correct type.

Based on https://github.com/cgreer/cgAutoCast/blob/master/cgAutoCast.py

Only used by Legacy configuration file parser.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.autocast_value","title":"autocast_value","text":"
autocast_value(var: Any) -> Any\n

Guess the string representation of the variable\u2019s type.

Parameters:

var

Value to autocast.

TYPE: Any

Returns:

Any

The autocasted value.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.boolify","title":"boolify","text":"
boolify(s: str) -> bool\n

Convert a string to a boolean.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.listify","title":"listify","text":"
listify(s: str) -> list\n

Convert a string representation of a list into list of homogeneous basic types.

Type of elements in list is determined via first element. Successive elements are cast to that type.

Parameters:

s

String representation of a list.

TYPE: str

Raises:

ValueError

If string does not represent a list.

TypeError

If string does not represent a list of homogeneous basic types.

Returns:

list

List of homogeneous basic types.

"},{"location":"reference/api/bumpversion/autocast/#bumpversion.autocast.noneify","title":"noneify","text":"
noneify(s: str) -> None\n

Convert a string to None.

"},{"location":"reference/api/bumpversion/bump/","title":" bump","text":"

Version changing methods.

"},{"location":"reference/api/bumpversion/bump/#bumpversion.bump-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/bump/#bumpversion.bump-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/bump/#bumpversion.bump.commit_and_tag","title":"commit_and_tag","text":"
commit_and_tag(\n    config: Config,\n    config_file: Optional[Path],\n    configured_files: List[ConfiguredFile],\n    ctx: ChainMap,\n    dry_run: bool = False,\n) -> None\n

Commit and tag the changes if a tool is configured.

Parameters:

config

The configuration

TYPE: Config

config_file

The configuration file to include in the commit, if it exists

TYPE: Optional[Path]

configured_files

A list of files to commit

TYPE: List[ConfiguredFile]

ctx

The context used to render the tag and tag message

TYPE: ChainMap

dry_run

True if the operation should be a dry run

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/bump/#bumpversion.bump.do_bump","title":"do_bump","text":"
do_bump(\n    version_part: Optional[str],\n    new_version: Optional[str],\n    config: Config,\n    config_file: Optional[Path] = None,\n    dry_run: bool = False,\n) -> None\n

Bump the version_part to the next value or set the version to new_version.

Parameters:

version_part

The version part to bump

TYPE: Optional[str]

new_version

The explicit version to set

TYPE: Optional[str]

config

The configuration to use

TYPE: Config

config_file

The configuration file to update

TYPE: Optional[Path]

DEFAULT: None

dry_run

True if the operation should be a dry run

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/bump/#bumpversion.bump.get_next_version","title":"get_next_version","text":"
get_next_version(\n    current_version: Version,\n    config: Config,\n    version_part: Optional[str],\n    new_version: Optional[str],\n) -> Version\n

Bump the version_part to the next value.

Parameters:

current_version

The current version

TYPE: Version

config

The current configuration

TYPE: Config

version_part

Optional part of the version to bump

TYPE: Optional[str]

new_version

Optional specific version to bump to

TYPE: Optional[str]

Returns:

Version

The new version

Raises:

ConfigurationError

If it can\u2019t generate the next version.

"},{"location":"reference/api/bumpversion/cli/","title":" cli","text":"

bump-my-version Command line interface.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/cli/#bumpversion.cli-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.bump","title":"bump","text":"
bump(\n    args: list,\n    config_file: Optional[str],\n    verbose: int,\n    allow_dirty: Optional[bool],\n    current_version: Optional[str],\n    new_version: Optional[str],\n    parse: Optional[str],\n    serialize: Optional[List[str]],\n    search: Optional[str],\n    replace: Optional[str],\n    regex: Optional[bool],\n    no_configured_files: bool,\n    ignore_missing_files: bool,\n    ignore_missing_version: bool,\n    dry_run: bool,\n    commit: Optional[bool],\n    tag: Optional[bool],\n    sign_tags: Optional[bool],\n    tag_name: Optional[str],\n    tag_message: Optional[str],\n    message: Optional[str],\n    commit_args: Optional[str],\n) -> None\n

Change the version.

ARGS may contain any of the following:

VERSION_PART is the part of the version to increase, e.g. minor. Valid values include those given in the --serialize / --parse option.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.cli","title":"cli","text":"
cli(ctx: Context) -> None\n

Version bump your Python project.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.replace","title":"replace","text":"
replace(\n    files: list,\n    config_file: Optional[str],\n    verbose: int,\n    allow_dirty: Optional[bool],\n    current_version: Optional[str],\n    new_version: Optional[str],\n    parse: Optional[str],\n    serialize: Optional[List[str]],\n    search: Optional[str],\n    replace: Optional[str],\n    regex: bool,\n    no_configured_files: bool,\n    ignore_missing_version: bool,\n    ignore_missing_files: bool,\n    dry_run: bool,\n) -> None\n

Replace the version in files.

FILES are additional file(s) to modify. If you want to rewrite only files specified on the command line, use with the --no-configured-files option.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.sample_config","title":"sample_config","text":"
sample_config(prompt: bool, destination: str) -> None\n

Print a sample configuration file.

"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.show","title":"show","text":"
show(\n    args: List[str],\n    config_file: Optional[str],\n    format_: str,\n    increment: Optional[str],\n) -> None\n

Show current configuration information.

ARGS may contain one or more configuration attributes. For example:

  • bump-my-version show current_version
  • bump-my-version show files.0.filename
  • bump-my-version show scm_info.branch_name
  • bump-my-version show current_version scm_info.distance_to_latest_tag
"},{"location":"reference/api/bumpversion/cli/#bumpversion.cli.show_bump","title":"show_bump","text":"
show_bump(\n    version: str, config_file: Optional[str], ascii: bool\n) -> None\n

Show the possible versions resulting from the bump subcommand.

"},{"location":"reference/api/bumpversion/context/","title":" context","text":"

Context for rendering messages and tags.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/context/#bumpversion.context-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/context/#bumpversion.context.base_context","title":"base_context","text":"
base_context(\n    scm_info: Optional[SCMInfo] = None,\n) -> ChainMap\n

The default context for rendering messages and tags.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.calver_string_to_regex","title":"calver_string_to_regex","text":"
calver_string_to_regex(calver_format: str) -> str\n

Convert the calver format string to a regex pattern.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.get_context","title":"get_context","text":"
get_context(\n    config: Config,\n    current_version: Optional[Version] = None,\n    new_version: Optional[Version] = None,\n) -> ChainMap\n

Return the context for rendering messages and tags.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.get_datetime_info","title":"get_datetime_info","text":"
get_datetime_info(current_dt: datetime.datetime) -> dict\n

Return the full structure of the given datetime for formatting.

"},{"location":"reference/api/bumpversion/context/#bumpversion.context.prefixed_environ","title":"prefixed_environ","text":"
prefixed_environ() -> dict\n

Return a dict of the environment with keys wrapped in ${}.

"},{"location":"reference/api/bumpversion/exceptions/","title":" exceptions","text":"

Custom exceptions for BumpVersion.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.BadInputError","title":"BadInputError","text":"
BadInputError(message: str, ctx: Optional[Context] = None)\n

Bases: BumpVersionError

User input was bad.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.BumpVersionError","title":"BumpVersionError","text":"
BumpVersionError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: UsageError

Custom base class for all BumpVersion exception types.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.ConfigurationError","title":"ConfigurationError","text":"
ConfigurationError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

A configuration key-value is missing or in the wrong type.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.DirtyWorkingDirectoryError","title":"DirtyWorkingDirectoryError","text":"
DirtyWorkingDirectoryError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

The working directory is dirty, and it is not allowed.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.FormattingError","title":"FormattingError","text":"
FormattingError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

We are unable to represent a version required by a format.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.InvalidVersionPartError","title":"InvalidVersionPartError","text":"
InvalidVersionPartError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

The specified part (e.g. \u2018bugfix\u2019) was not found.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.MissingValueError","title":"MissingValueError","text":"
MissingValueError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

A part required for a version format is empty.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.SignedTagsError","title":"SignedTagsError","text":"
SignedTagsError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

The VCS does not support signed tags.

"},{"location":"reference/api/bumpversion/exceptions/#bumpversion.exceptions.VersionNotFoundError","title":"VersionNotFoundError","text":"
VersionNotFoundError(\n    message: str, ctx: Optional[Context] = None\n)\n

Bases: BumpVersionError

A version number was not found in a source file.

"},{"location":"reference/api/bumpversion/files/","title":" files","text":"

Methods for changing files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile","title":"ConfiguredFile","text":"
ConfiguredFile(\n    file_change: FileChange,\n    version_config: VersionConfig,\n    search: Optional[str] = None,\n    replace: Optional[str] = None,\n)\n

A file to modify in a configured way.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile.get_file_contents","title":"get_file_contents","text":"
get_file_contents() -> str\n

Return the contents of the file.

Raises:

FileNotFoundError

if the file doesn\u2019t exist

Returns:

str

The contents of the file

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile.make_file_change","title":"make_file_change","text":"
make_file_change(\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Make the change to the file.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.ConfiguredFile.write_file_contents","title":"write_file_contents","text":"
write_file_contents(contents: str) -> None\n

Write the contents of the file.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.DataFileUpdater","title":"DataFileUpdater","text":"
DataFileUpdater(\n    file_change: FileChange,\n    version_part_configs: Dict[str, VersionComponentSpec],\n)\n

A class to handle updating files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.DataFileUpdater-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.DataFileUpdater.update_file","title":"update_file","text":"
update_file(\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Update the files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.FileUpdater","title":"FileUpdater","text":"
FileUpdater(\n    file_change: FileChange,\n    version_config: VersionConfig,\n    search: Optional[str] = None,\n    replace: Optional[str] = None,\n)\n

A class to handle updating files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.FileUpdater-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.FileUpdater.update_file","title":"update_file","text":"
update_file(\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Update the files.

"},{"location":"reference/api/bumpversion/files/#bumpversion.files-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/files/#bumpversion.files.contains_pattern","title":"contains_pattern","text":"
contains_pattern(search: re.Pattern, contents: str) -> bool\n

Does the search pattern match any part of the contents?

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.log_changes","title":"log_changes","text":"
log_changes(\n    file_path: str,\n    file_content_before: str,\n    file_content_after: str,\n    dry_run: bool = False,\n) -> None\n

Log the changes that would be made to the file.

Parameters:

file_path

The path to the file

TYPE: str

file_content_before

The file contents before the change

TYPE: str

file_content_after

The file contents after the change

TYPE: str

dry_run

True if this is a report-only job

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.modify_files","title":"modify_files","text":"
modify_files(\n    files: List[ConfiguredFile],\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Modify the files, searching and replacing values according to the FileConfig.

Parameters:

files

The list of configured files

TYPE: List[ConfiguredFile]

current_version

The current version

TYPE: Version

new_version

The next version

TYPE: Version

context

The context used for rendering the version

TYPE: MutableMapping

dry_run

True if this should be a report-only job

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/files/#bumpversion.files.resolve_file_config","title":"resolve_file_config","text":"
resolve_file_config(\n    files: List[FileChange],\n    version_config: VersionConfig,\n    search: Optional[str] = None,\n    replace: Optional[str] = None,\n) -> List[ConfiguredFile]\n

Resolve the files, searching and replacing values according to the FileConfig.

Parameters:

files

A list of file configurations

TYPE: List[FileChange]

version_config

How the version should be changed

TYPE: VersionConfig

search

The search pattern to use instead of any configured search pattern

TYPE: Optional[str]

DEFAULT: None

replace

The replace pattern to use instead of any configured replace pattern

TYPE: Optional[str]

DEFAULT: None

Returns:

List[ConfiguredFile]

A list of ConfiguredFiles

"},{"location":"reference/api/bumpversion/indented_logger/","title":" indented_logger","text":"

A logger adapter that adds an indent to the beginning of each message.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter","title":"IndentedLoggerAdapter","text":"
IndentedLoggerAdapter(\n    logger: logging.Logger,\n    extra: Optional[dict] = None,\n    depth: int = 2,\n    indent_char: str = \" \",\n    reset: bool = False,\n)\n

Bases: LoggerAdapter

Logger adapter that adds an indent to the beginning of each message.

Parameters:

logger

The logger to adapt.

TYPE: Logger

extra

Extra values to add to the logging context.

TYPE: Optional[dict]

DEFAULT: None

depth

The number of indent_char to generate for each indent level.

TYPE: int

DEFAULT: 2

indent_char

The character or string to use for indenting.

TYPE: str

DEFAULT: ' '

reset

True if the indent level should be reset to zero.

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.current_indent","title":"current_indent property","text":"
current_indent: int\n

The current indent level.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.indent_str","title":"indent_str property","text":"
indent_str: str\n

The indent string.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.dedent","title":"dedent","text":"
dedent(amount: int = 1) -> None\n

Decrease the indent level by amount.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.indent","title":"indent","text":"
indent(amount: int = 1) -> None\n

Increase the indent level by amount.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.process","title":"process","text":"
process(\n    msg: str, kwargs: Optional[MutableMapping[str, Any]]\n) -> Tuple[str, MutableMapping[str, Any]]\n

Process the message and add the indent.

Parameters:

msg

The logging message.

TYPE: str

kwargs

Keyword arguments passed to the logger.

TYPE: Optional[MutableMapping[str, Any]]

Returns:

Tuple[str, MutableMapping[str, Any]]

A tuple containing the message and keyword arguments.

"},{"location":"reference/api/bumpversion/indented_logger/#bumpversion.indented_logger.IndentedLoggerAdapter.reset","title":"reset","text":"
reset() -> None\n

Reset the indent level to zero.

"},{"location":"reference/api/bumpversion/scm/","title":" scm","text":"

Version control system management.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git","title":"Git","text":"

Bases: SourceCodeManager

Git implementation.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.add_path","title":"add_path classmethod","text":"
add_path(path: Union[str, Path]) -> None\n

Add a path to the VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.assert_nondirty","title":"assert_nondirty classmethod","text":"
assert_nondirty() -> None\n

Assert that the working directory is not dirty.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.latest_tag_info","title":"latest_tag_info classmethod","text":"
latest_tag_info(\n    tag_name: str, parse_pattern: str\n) -> SCMInfo\n

Return information about the latest tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Git.tag","title":"tag classmethod","text":"
tag(\n    name: str,\n    sign: bool = False,\n    message: Optional[str] = None,\n) -> None\n

Create a tag of the new_version in VCS.

If only name is given, bumpversion uses a lightweight tag. Otherwise, it utilizes an annotated tag.

Parameters:

name

The name of the tag

TYPE: str

sign

True to sign the tag

TYPE: bool

DEFAULT: False

message

An optional message to annotate the tag.

TYPE: Optional[str]

DEFAULT: None

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial","title":"Mercurial","text":"

Bases: SourceCodeManager

Mercurial implementation.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.add_path","title":"add_path classmethod","text":"
add_path(path: Union[str, Path]) -> None\n

Add a path to the VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.assert_nondirty","title":"assert_nondirty classmethod","text":"
assert_nondirty() -> None\n

Assert that the working directory is clean.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.latest_tag_info","title":"latest_tag_info classmethod","text":"
latest_tag_info(\n    tag_name: str, parse_pattern: str\n) -> SCMInfo\n

Return information about the latest tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.Mercurial.tag","title":"tag classmethod","text":"
tag(\n    name: str,\n    sign: bool = False,\n    message: Optional[str] = None,\n) -> None\n

Create a tag of the new_version in VCS.

If only name is given, bumpversion uses a lightweight tag. Otherwise, it utilizes an annotated tag.

Parameters:

name

The name of the tag

TYPE: str

sign

True to sign the tag

TYPE: bool

DEFAULT: False

message

A optional message to annotate the tag.

TYPE: Optional[str]

DEFAULT: None

Raises:

SignedTagsError

If sign is True

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SCMInfo","title":"SCMInfo dataclass","text":"
SCMInfo(\n    tool: Optional[Type[SourceCodeManager]] = None,\n    commit_sha: Optional[str] = None,\n    distance_to_latest_tag: int = 0,\n    current_version: Optional[str] = None,\n    branch_name: Optional[str] = None,\n    short_branch_name: Optional[str] = None,\n    dirty: Optional[bool] = None,\n)\n

Information about the current source code manager and state.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager","title":"SourceCodeManager","text":"

Base class for version control systems.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.add_path","title":"add_path classmethod","text":"
add_path(path: Union[str, Path]) -> None\n

Add a path to the VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.assert_nondirty","title":"assert_nondirty classmethod","text":"
assert_nondirty() -> None\n

Assert that the working directory is not dirty.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.commit","title":"commit classmethod","text":"
commit(\n    message: str,\n    current_version: str,\n    new_version: str,\n    extra_args: Optional[list] = None,\n) -> None\n

Commit the changes.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.commit_to_scm","title":"commit_to_scm classmethod","text":"
commit_to_scm(\n    files: List[Union[str, Path]],\n    config: Config,\n    context: MutableMapping,\n    extra_args: Optional[List[str]] = None,\n    dry_run: bool = False,\n) -> None\n

Commit the files to the source code management system.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.format_and_raise_error","title":"format_and_raise_error classmethod","text":"
format_and_raise_error(\n    exc: Union[TypeError, subprocess.CalledProcessError]\n) -> None\n

Format the error message from an exception and re-raise it as a BumpVersionError.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.get_all_tags","title":"get_all_tags classmethod","text":"
get_all_tags() -> List[str]\n

Return all tags in VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.get_version_from_tag","title":"get_version_from_tag classmethod","text":"
get_version_from_tag(\n    tag: str, tag_name: str, parse_pattern: str\n) -> Optional[str]\n

Return the version from a tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.is_usable","title":"is_usable classmethod","text":"
is_usable() -> bool\n

Is the VCS implementation usable.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.latest_tag_info","title":"latest_tag_info classmethod","text":"
latest_tag_info(\n    tag_name: str, parse_pattern: str\n) -> SCMInfo\n

Return information about the latest tag.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.tag","title":"tag classmethod","text":"
tag(\n    name: str,\n    sign: bool = False,\n    message: Optional[str] = None,\n) -> None\n

Create a tag of the new_version in VCS.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.SourceCodeManager.tag_in_scm","title":"tag_in_scm classmethod","text":"
tag_in_scm(\n    config: Config,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Tag the current commit in the source code management system.

"},{"location":"reference/api/bumpversion/scm/#bumpversion.scm-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/scm/#bumpversion.scm.get_scm_info","title":"get_scm_info","text":"
get_scm_info(tag_name: str, parse_pattern: str) -> SCMInfo\n

Return a dict with the latest source code management info.

"},{"location":"reference/api/bumpversion/show/","title":" show","text":"

Functions for displaying information about the version.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/show/#bumpversion.show-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/show/#bumpversion.show.do_show","title":"do_show","text":"
do_show(\n    *args,\n    config: Config,\n    format_: str = \"default\",\n    increment: Optional[str] = None\n) -> None\n

Show current version or configuration information.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.output_default","title":"output_default","text":"
output_default(value: dict) -> None\n

Output the value with key=value or just value if there is only one item.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.output_json","title":"output_json","text":"
output_json(value: dict) -> None\n

Output the value as json.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.output_yaml","title":"output_yaml","text":"
output_yaml(value: dict) -> None\n

Output the value as yaml.

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.resolve_name","title":"resolve_name","text":"
resolve_name(\n    obj: Any,\n    name: str,\n    default: Any = None,\n    err_on_missing: bool = False,\n) -> Any\n

Get a key or attr name from obj or default value.

Copied and modified from Django Template variable resolutions

Resolution methods:

  • Mapping key lookup
  • Attribute lookup
  • Sequence index

Parameters:

obj

The object to access

TYPE: Any

name

A dotted name to the value, such as mykey.0.name

TYPE: str

default

If the name cannot be resolved from the object, return this value

TYPE: Any

DEFAULT: None

err_on_missing

Raise a BadInputError if the name cannot be resolved

TYPE: bool

DEFAULT: False

Returns:

Any

The value at the resolved name or the default value.

Raises:

BadInputError

If we cannot resolve the name and err_on_missing is True

"},{"location":"reference/api/bumpversion/show/#bumpversion.show.resolve_name--noqa-dar401","title":"noqa: DAR401","text":""},{"location":"reference/api/bumpversion/ui/","title":" ui","text":"

Utilities for user interface.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/ui/#bumpversion.ui-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.get_indented_logger","title":"get_indented_logger","text":"
get_indented_logger(name: str) -> IndentedLoggerAdapter\n

Get a logger with indentation.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.print_error","title":"print_error","text":"
print_error(msg: str) -> None\n

Raise an error and exit.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.print_info","title":"print_info","text":"
print_info(msg: str) -> None\n

Echo a message to the console.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.print_warning","title":"print_warning","text":"
print_warning(msg: str) -> None\n

Echo a warning to the console.

"},{"location":"reference/api/bumpversion/ui/#bumpversion.ui.setup_logging","title":"setup_logging","text":"
setup_logging(verbose: int = 0) -> None\n

Configure the logging.

"},{"location":"reference/api/bumpversion/utils/","title":" utils","text":"

General utilities.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.extract_regex_flags","title":"extract_regex_flags","text":"
extract_regex_flags(regex_pattern: str) -> Tuple[str, str]\n

Extract the regex flags from the regex pattern.

Parameters:

regex_pattern

The pattern that might start with regex flags

TYPE: str

Returns:

Tuple[str, str]

A tuple of the regex pattern without the flag string and regex flag string

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.get_nested_value","title":"get_nested_value","text":"
get_nested_value(d: dict, path: str) -> Any\n

Retrieves the value of a nested key in a dictionary based on the given path.

Parameters:

d

The dictionary to search.

TYPE: dict

path

A string representing the path to the nested key, separated by periods.

TYPE: str

Returns:

Any

The value of the nested key.

Raises:

KeyError

If a key in the path does not exist.

ValueError

If an element in the path is not a dictionary.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.get_overrides","title":"get_overrides","text":"
get_overrides(**kwargs) -> dict\n

Return a dictionary containing only the overridden key-values.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.key_val_string","title":"key_val_string","text":"
key_val_string(d: dict) -> str\n

Render the dictionary as a comma-delimited key=value string.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.labels_for_format","title":"labels_for_format","text":"
labels_for_format(serialize_format: str) -> List[str]\n

Return a list of labels for the given serialize_format.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.recursive_sort_dict","title":"recursive_sort_dict","text":"
recursive_sort_dict(input_value: Any) -> Any\n

Sort a dictionary recursively.

"},{"location":"reference/api/bumpversion/utils/#bumpversion.utils.set_nested_value","title":"set_nested_value","text":"
set_nested_value(d: dict, value: Any, path: str) -> None\n

Sets the value of a nested key in a dictionary based on the given path.

Parameters:

d

The dictionary to search.

TYPE: dict

value

The value to set.

TYPE: Any

path

A string representing the path to the nested key, separated by periods.

TYPE: str

Raises:

ValueError

If an element in the path is not a dictionary.

"},{"location":"reference/api/bumpversion/version_part/","title":" version_part","text":"

Module for managing Versions and their internal parts.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig","title":"VersionConfig","text":"
VersionConfig(\n    parse: str,\n    serialize: Tuple[str],\n    search: str,\n    replace: str,\n    part_configs: Optional[\n        Dict[str, VersionComponentSpec]\n    ] = None,\n)\n

Hold a complete representation of a version string.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig.order","title":"order property","text":"
order: List[str]\n

Return the order of the labels in a serialization format.

Currently, order depends on the first given serialization format. This seems like a good idea because this should be the most complete format.

Returns:

List[str]

A list of version part labels in the order they should be rendered.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig.parse","title":"parse","text":"
parse(\n    version_string: Optional[str] = None,\n) -> Optional[Version]\n

Parse a version string into a Version object.

Parameters:

version_string

Version string to parse

TYPE: Optional[str]

DEFAULT: None

Returns:

Optional[Version]

A Version object representing the string.

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part.VersionConfig.serialize","title":"serialize","text":"
serialize(version: Version, context: MutableMapping) -> str\n

Serialize a version to a string.

Parameters:

version

The version to serialize

TYPE: Version

context

The context to use when serializing the version

TYPE: MutableMapping

Returns:

str

The serialized version as a string

"},{"location":"reference/api/bumpversion/version_part/#bumpversion.version_part-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/visualize/","title":" visualize","text":"

Visualize the bumpversion process.

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.Border","title":"Border dataclass","text":"
Border(\n    corner_bottom_right: str,\n    corner_top_right: str,\n    corner_top_left: str,\n    corner_bottom_left: str,\n    divider_left: str,\n    divider_up: str,\n    divider_down: str,\n    divider_right: str,\n    line: str,\n    pipe: str,\n    cross: str,\n)\n

A border definition.

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.connection_str","title":"connection_str","text":"
connection_str(\n    border: Border,\n    has_next: bool = False,\n    has_previous: bool = False,\n) -> str\n

Return the correct connection string based on the next and previous.

Parameters:

border

The border definition to draw the lines

TYPE: Border

has_next

If True, there is a next line

TYPE: bool

DEFAULT: False

has_previous

If True, there is a previous line

TYPE: bool

DEFAULT: False

Returns:

str

A string that connects left-to-right and top-to-bottom based on the next and previous

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.filter_version_parts","title":"filter_version_parts","text":"
filter_version_parts(config: Config) -> List[str]\n

Return the version parts that are in the configuration.

Parameters:

config

The configuration to check against

TYPE: Config

Returns:

List[str]

The version parts that are in the configuration

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.labeled_line","title":"labeled_line","text":"
labeled_line(\n    label: str,\n    border: Border,\n    fit_length: Optional[int] = None,\n) -> str\n

Return the version part string with the correct padding.

Parameters:

label

The label to render

TYPE: str

border

The border definition to draw the lines

TYPE: Border

fit_length

The length to fit the label to

TYPE: Optional[int]

DEFAULT: None

Returns:

str

A labeled line with leading and trailing spaces

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.lead_string","title":"lead_string","text":"
lead_string(\n    version_str: str, border: Border, blank: bool = False\n) -> str\n

Return the first part of a string with the bump character or spaces of the correct amount.

Examples:

>>> lead_string(\"1.0.0\", Border(*BOX_CHARS[\"light\"]))\n'1.0.0 \u2500\u2500 bump \u2500'\n>>> lead_string(\"1.0.0\", Border(*BOX_CHARS[\"light\"]), blank=True)\n'               '\n

Parameters:

version_str

The string to render as the starting point

TYPE: str

border

The border definition to draw the lines

TYPE: Border

blank

If True, return a blank string the same length as the version bump string

TYPE: bool

DEFAULT: False

Returns:

str

The version bump string or a blank string

"},{"location":"reference/api/bumpversion/visualize/#bumpversion.visualize.visualize","title":"visualize","text":"
visualize(\n    config: Config,\n    version_str: str,\n    box_style: str = \"light\",\n) -> None\n

Output a visualization of the bump-my-version bump process.

"},{"location":"reference/api/bumpversion/yaml_dump/","title":" yaml_dump","text":"

A simple YAML dumper to avoid extra dependencies.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.YAMLDumpers","title":"YAMLDumpers","text":"

Bases: UserDict

Registry of YAML dumpers.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.YAMLDumpers-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.YAMLDumpers.add_dumper","title":"add_dumper","text":"
add_dumper(data_type: type, dumper: DumperFunc) -> None\n

Add a YAML dumper.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.dump","title":"dump","text":"
dump(data: Any) -> str\n

Dump a value to a string buffer.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_bool","title":"format_bool","text":"
format_bool(val: bool) -> str\n

Return a YAML representation of a bool.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_date","title":"format_date","text":"
format_date(val: datetime.date) -> str\n

Return a YAML representation of a date.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_datetime","title":"format_datetime","text":"
format_datetime(val: datetime.datetime) -> str\n

Return a string representation of a value.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_dict","title":"format_dict","text":"
format_dict(val: dict) -> str\n

Return a YAML representation of a dict.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_float","title":"format_float","text":"
format_float(data: float) -> str\n

Return a YAML representation of a float.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_int","title":"format_int","text":"
format_int(val: int) -> str\n

Return a YAML representation of an int.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_none","title":"format_none","text":"
format_none(_: None) -> str\n

Return a YAML representation of None.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_sequence","title":"format_sequence","text":"
format_sequence(val: Union[list, tuple]) -> str\n

Return a string representation of a value.

"},{"location":"reference/api/bumpversion/yaml_dump/#bumpversion.yaml_dump.format_str","title":"format_str","text":"
format_str(val: str) -> str\n

Return a YAML representation of a string.

"},{"location":"reference/api/bumpversion/config/","title":"Index","text":"

Configuration management.

"},{"location":"reference/api/bumpversion/config/#bumpversion.config-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/#bumpversion.config-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/#bumpversion.config.check_current_version","title":"check_current_version","text":"
check_current_version(config: Config) -> str\n

Returns the current version.

If the current version is not specified in the config file, command line or env variable, it attempts to retrieve it via a tag.

Parameters:

config

The current configuration dictionary.

TYPE: Config

Returns:

str

The version number

Raises:

ConfigurationError

If it can\u2019t find the current version

"},{"location":"reference/api/bumpversion/config/#bumpversion.config.get_configuration","title":"get_configuration","text":"
get_configuration(\n    config_file: Union[str, Path, None] = None,\n    **overrides: Any\n) -> Config\n

Return the configuration based on any configuration files and overrides.

Parameters:

config_file

An explicit configuration file to use, otherwise search for one

TYPE: Union[str, Path, None]

DEFAULT: None

**overrides

Specific configuration key-values to override in the configuration

TYPE: Any

DEFAULT: {}

Returns:

Config

The configuration

"},{"location":"reference/api/bumpversion/config/#bumpversion.config.set_config_defaults","title":"set_config_defaults","text":"
set_config_defaults(\n    parsed_config: dict[str, Any], **overrides: Any\n) -> dict[str, Any]\n

Apply the defaults to the parsed config.

"},{"location":"reference/api/bumpversion/config/create/","title":" create","text":"

Module for creating a new config file.

"},{"location":"reference/api/bumpversion/config/create/#bumpversion.config.create-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/create/#bumpversion.config.create.create_configuration","title":"create_configuration","text":"
create_configuration(\n    destination: str, prompt: bool\n) -> TOMLDocument\n

Create a new configuration as a TOMLDocument.

Parameters:

destination

stdout or a path to a new or existing file.

TYPE: str

prompt

True if the user should be prompted for input.

TYPE: bool

Returns:

TOMLDocument

The TOMLDocument structure with the updated configuration.

"},{"location":"reference/api/bumpversion/config/create/#bumpversion.config.create.get_defaults_from_dest","title":"get_defaults_from_dest","text":"
get_defaults_from_dest(\n    destination: str,\n) -> Tuple[dict, TOMLDocument]\n

Get the default configuration and the configuration from the destination.

"},{"location":"reference/api/bumpversion/config/files/","title":" files","text":"

Contains methods for finding and reading configuration files.

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.find_config_file","title":"find_config_file","text":"
find_config_file(\n    explicit_file: Union[str, Path, None] = None\n) -> Union[Path, None]\n

Find the configuration file, if it exists.

If no explicit configuration file is passed, it will search in several files to find its configuration.

Parameters:

explicit_file

The configuration file to explicitly use.

TYPE: Union[str, Path, None]

DEFAULT: None

Returns:

Union[Path, None]

The configuration file path

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.read_config_file","title":"read_config_file","text":"
read_config_file(\n    config_file: Union[str, Path, None] = None\n) -> Dict[str, Any]\n

Read the configuration file, if it exists.

If no explicit configuration file is passed, it will search in several files to find its configuration.

Parameters:

config_file

The configuration file to explicitly use.

TYPE: Union[str, Path, None]

DEFAULT: None

Returns:

Dict[str, Any]

A dictionary of read key-values

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.read_toml_file","title":"read_toml_file","text":"
read_toml_file(file_path: Path) -> Dict[str, Any]\n

Parse a TOML file and return the bumpversion section.

Parameters:

file_path

The path to the TOML file.

TYPE: Path

Returns:

dict

A dictionary of the bumpversion section.

TYPE: Dict[str, Any]

"},{"location":"reference/api/bumpversion/config/files/#bumpversion.config.files.update_config_file","title":"update_config_file","text":"
update_config_file(\n    config_file: Union[str, Path],\n    config: Config,\n    current_version: Version,\n    new_version: Version,\n    context: MutableMapping,\n    dry_run: bool = False,\n) -> None\n

Update the current_version key in the configuration file.

Parameters:

config_file

The configuration file to explicitly use.

TYPE: Union[str, Path]

config

The configuration to use.

TYPE: Config

current_version

The current version.

TYPE: Version

new_version

The new version.

TYPE: Version

context

The context to use for serialization.

TYPE: MutableMapping

dry_run

True if the update should be a dry run.

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/config/files_legacy/","title":" files_legacy","text":"

This module handles the legacy config file format.

"},{"location":"reference/api/bumpversion/config/files_legacy/#bumpversion.config.files_legacy-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/files_legacy/#bumpversion.config.files_legacy.read_ini_file","title":"read_ini_file","text":"
read_ini_file(file_path: Path) -> Dict[str, Any]\n

Parse an INI file and return a dictionary of sections and their options.

Parameters:

file_path

The path to the INI file.

TYPE: Path

Returns:

dict

A dictionary of sections and their options.

TYPE: Dict[str, Any]

"},{"location":"reference/api/bumpversion/config/files_legacy/#bumpversion.config.files_legacy.update_ini_config_file","title":"update_ini_config_file","text":"
update_ini_config_file(\n    config_file: Union[str, Path],\n    current_version: str,\n    new_version: str,\n    dry_run: bool = False,\n) -> None\n

Update the current_version key in the configuration file.

Instead of parsing and re-writing the config file with new information, it will use a regular expression to just replace the current_version value. The idea is it will avoid unintentional changes (like formatting) to the config file.

Parameters:

config_file

The configuration file to explicitly use.

TYPE: Union[str, Path]

current_version

The serialized current version.

TYPE: str

new_version

The serialized new version.

TYPE: str

dry_run

True if the update should be a dry run.

TYPE: bool

DEFAULT: False

"},{"location":"reference/api/bumpversion/config/models/","title":" models","text":"

Bump My Version configuration models.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config","title":"Config","text":"

Bases: BaseSettings

Bump Version configuration.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.files_to_modify","title":"files_to_modify property","text":"
files_to_modify: List[FileChange]\n

Return a list of files to modify.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.resolved_filemap","title":"resolved_filemap property","text":"
resolved_filemap: Dict[str, List[FileChange]]\n

Return the cached resolved filemap.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.version_config","title":"version_config property","text":"
version_config: 'VersionConfig'\n

Return the version configuration.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.add_files","title":"add_files","text":"
add_files(filename: Union[str, List[str]]) -> None\n

Add a filename to the list of files.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.Config.version_spec","title":"version_spec","text":"
version_spec(\n    version: Optional[str] = None,\n) -> \"VersionSpec\"\n

Return the version specification.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange","title":"FileChange","text":"

Bases: BaseModel

A change to make to a file.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange.__hash__","title":"__hash__","text":"
__hash__()\n

Return a hash of the model.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models.FileChange.get_search_pattern","title":"get_search_pattern","text":"
get_search_pattern(\n    context: MutableMapping,\n) -> Tuple[re.Pattern, str]\n

Render the search pattern and return the compiled regex pattern and the raw pattern.

Parameters:

context

The context to use for rendering the search pattern

TYPE: MutableMapping

Returns:

Tuple[Pattern, str]

A tuple of the compiled regex pattern and the raw pattern as a string.

"},{"location":"reference/api/bumpversion/config/models/#bumpversion.config.models-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/utils/","title":" utils","text":"

Helper functions for the config module.

"},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils.get_all_file_configs","title":"get_all_file_configs","text":"
get_all_file_configs(config_dict: dict) -> List[FileChange]\n

Make sure all version parts are included.

"},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils.get_all_part_configs","title":"get_all_part_configs","text":"
get_all_part_configs(\n    config_dict: dict,\n) -> Dict[str, VersionComponentSpec]\n

Make sure all version parts are included.

"},{"location":"reference/api/bumpversion/config/utils/#bumpversion.config.utils.resolve_glob_files","title":"resolve_glob_files","text":"
resolve_glob_files(\n    file_cfg: FileChange,\n) -> List[FileChange]\n

Return a list of file configurations that match the glob pattern.

Parameters:

file_cfg

The file configuration containing the glob pattern

TYPE: FileChange

Returns:

List[FileChange]

A list of resolved file configurations according to the pattern.

"},{"location":"reference/api/bumpversion/versioning/","title":"Index","text":"

Module for managing Versions and their internal parts.

"},{"location":"reference/api/bumpversion/versioning/conventions/","title":" conventions","text":"

Standard version conventions.

"},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions.pep440_version_spec","title":"pep440_version_spec","text":"
pep440_version_spec() -> VersionSpec\n

Return a VersionSpec for PEP 440.

"},{"location":"reference/api/bumpversion/versioning/conventions/#bumpversion.versioning.conventions.semver_spec","title":"semver_spec","text":"
semver_spec() -> VersionSpec\n

Return a VersionSpec for SEMVER.

"},{"location":"reference/api/bumpversion/versioning/functions/","title":" functions","text":"

Generators for version parts.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.CalVerFunction","title":"CalVerFunction","text":"
CalVerFunction(calver_format: str)\n

Bases: PartFunction

This is a class that provides a CalVer function for version parts.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.CalVerFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.CalVerFunction.bump","title":"bump","text":"
bump(value: Optional[str] = None) -> str\n

Return the optional value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.IndependentFunction","title":"IndependentFunction","text":"
IndependentFunction(value: Union[str, int, None] = None)\n

Bases: PartFunction

This is a class that provides an independent function for version parts.

It simply returns the optional value, which is equal to the first value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.IndependentFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.IndependentFunction.bump","title":"bump","text":"
bump(value: Optional[str] = None) -> str\n

Return the optional value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.NumericFunction","title":"NumericFunction","text":"
NumericFunction(\n    optional_value: Union[str, int, None] = None,\n    first_value: Union[str, int, None] = None,\n)\n

Bases: PartFunction

This is a class that provides a numeric function for version parts.

It simply starts with the provided first_value (0 by default) and increases it following the sequence of integer numbers.

The optional value of this function is equal to the first value.

This function also supports alphanumeric parts, altering just the numeric part (e.g. \u2018r3\u2019 \u2013> \u2018r4\u2019). Only the first numeric group found in the part is considered (e.g. \u2018r3-001\u2019 \u2013> \u2018r4-001\u2019).

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.NumericFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.NumericFunction.bump","title":"bump","text":"
bump(value: Union[str, int]) -> str\n

Increase the first numerical value by one.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.PartFunction","title":"PartFunction","text":"

Base class for a version part function.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.PartFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.PartFunction.bump","title":"bump","text":"
bump(value: str) -> str\n

Increase the value.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.ValuesFunction","title":"ValuesFunction","text":"
ValuesFunction(\n    values: List[str],\n    optional_value: Optional[str] = None,\n    first_value: Optional[str] = None,\n)\n

Bases: PartFunction

This is a class that provides a values list based function for version parts.

It is initialized with a list of values and iterates through them when bumping the part.

The default optional value of this function is equal to the first value, but may be otherwise specified.

When trying to bump a part which has already the maximum value in the list you get a ValueError exception.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.ValuesFunction-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions.ValuesFunction.bump","title":"bump","text":"
bump(value: str) -> str\n

Return the item after value in the list.

"},{"location":"reference/api/bumpversion/versioning/functions/#bumpversion.versioning.functions-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/","title":" models","text":"

Models for managing versioning of software projects.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version","title":"Version","text":"
Version(\n    version_spec: VersionSpec,\n    components: Dict[str, VersionComponent],\n    original: Optional[str] = None,\n)\n

The specification of a version and its parts.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version.bump","title":"bump","text":"
bump(component_name: str) -> 'Version'\n

Increase the value of the specified component, reset its dependents, and return a new Version.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version.required_components","title":"required_components","text":"
required_components() -> List[str]\n

Return the names of the parts that are required.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.Version.values","title":"values","text":"
values() -> Dict[str, VersionComponent]\n

Return the values of the parts.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent","title":"VersionComponent","text":"
VersionComponent(\n    values: Optional[list] = None,\n    optional_value: Optional[str] = None,\n    first_value: Union[str, int, None] = None,\n    independent: bool = False,\n    always_increment: bool = False,\n    calver_format: Optional[str] = None,\n    source: Optional[str] = None,\n    value: Union[str, int, None] = None,\n)\n

Represent part of a version number.

Determines the PartFunction that rules how the part behaves when increased or reset based on the configuration given.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.is_independent","title":"is_independent property","text":"
is_independent: bool\n

Is the part independent of the other parts?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.is_optional","title":"is_optional property","text":"
is_optional: bool\n

Is the part optional?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.value","title":"value property","text":"
value: str\n

Return the value of the part.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.bump","title":"bump","text":"
bump() -> 'VersionComponent'\n

Return a part with bumped value.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.copy","title":"copy","text":"
copy() -> 'VersionComponent'\n

Return a copy of the part.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponent.null","title":"null","text":"
null() -> 'VersionComponent'\n

Return a part with first value.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec","title":"VersionComponentSpec","text":"

Bases: BaseModel

Configuration of a version component.

This is used to read in the configuration from the bumpversion config file.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec-attributes","title":"Attributes","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.always_increment","title":"always_increment class-attribute instance-attribute","text":"
always_increment: bool = False\n

Should the component always increment, even if it is not necessary?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.calver_format","title":"calver_format class-attribute instance-attribute","text":"
calver_format: Optional[str] = None\n

The format string for a CalVer component.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.depends_on","title":"depends_on class-attribute instance-attribute","text":"
depends_on: Optional[str] = None\n

The name of the component this component depends on.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.first_value","title":"first_value class-attribute instance-attribute","text":"
first_value: Union[str, int, None] = None\n

The first value to increment from.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.independent","title":"independent class-attribute instance-attribute","text":"
independent: bool = False\n

Is the component independent of the other components?

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.optional_value","title":"optional_value class-attribute instance-attribute","text":"
optional_value: Optional[str] = None\n

The value that is optional to include in the version.

  • Defaults to first value in values or 0 in the case of numeric.
  • Empty string means nothing is optional.
  • CalVer components ignore this.
"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.values","title":"values class-attribute instance-attribute","text":"
values: Optional[list] = None\n

The possible values for the component. If it and calver_format is None, the component is numeric.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.create_component","title":"create_component","text":"
create_component(\n    value: Union[str, int, None] = None\n) -> VersionComponent\n

Generate a version component from the configuration.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionComponentSpec.set_always_increment_with_calver","title":"set_always_increment_with_calver classmethod","text":"
set_always_increment_with_calver(data: Any) -> Any\n

Set always_increment to True if calver_format is present.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec","title":"VersionSpec","text":"
VersionSpec(\n    components: Dict[str, VersionComponentSpec],\n    order: Optional[List[str]] = None,\n)\n

The specification of a version\u2019s components and their relationships.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec.create_version","title":"create_version","text":"
create_version(values: Dict[str, str]) -> 'Version'\n

Generate a version from the given values.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models.VersionSpec.get_dependents","title":"get_dependents","text":"
get_dependents(component_name: str) -> List[str]\n

Return the parts that depend on the given part.

"},{"location":"reference/api/bumpversion/versioning/models/#bumpversion.versioning.models-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/serialization/","title":" serialization","text":"

Functions for serializing and deserializing version objects.

"},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization-classes","title":"Classes","text":""},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization-functions","title":"Functions","text":""},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization.multisort","title":"multisort","text":"
multisort(xs: list, specs: tuple) -> list\n

Sort a list of dictionaries by multiple keys.

From https://docs.python.org/3/howto/sorting.html#sort-stability-and-complex-sorts

Parameters:

xs

The list of dictionaries to sort

TYPE: list

specs

A tuple of (key, reverse) pairs

TYPE: tuple

Returns:

list

The sorted list

"},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization.parse_version","title":"parse_version","text":"
parse_version(\n    version_string: str, parse_pattern: str\n) -> Dict[str, str]\n

Parse a version string into a dictionary of the parts and values using a regular expression.

Parameters:

version_string

Version string to parse

TYPE: str

parse_pattern

The regular expression pattern to use for parsing

TYPE: str

Returns:

Dict[str, str]

A dictionary of version part labels and their values, or an empty dictionary

Dict[str, str]

if the version string doesn\u2019t match.

Raises:

BumpVersionError

If the parse_pattern is not a valid regular expression

"},{"location":"reference/api/bumpversion/versioning/serialization/#bumpversion.versioning.serialization.serialize","title":"serialize","text":"
serialize(\n    version: Version,\n    serialize_patterns: List[str],\n    context: MutableMapping,\n) -> str\n

Attempts to serialize a version with the given serialization format.

  • valid serialization patterns are those that are renderable with the given context
  • formats that contain all required components are preferred
  • the shortest valid serialization pattern is used
  • if two patterns are equally short, the first one is used
  • if no valid serialization pattern is found, an error is raised

Parameters:

version

The version to serialize

TYPE: Version

serialize_patterns

The serialization format to use, using Python\u2019s format string syntax

TYPE: List[str]

context

The context to use when serializing the version

TYPE: MutableMapping

Raises:

FormattingError

if a serialization pattern

Returns:

str

The serialized version as a string

"},{"location":"reference/subcommands/","title":"Subcommand reference","text":"

Bump-my-version uses subcommands to focus its functionality.

  • bump triggers the version incrementing workflow
  • replace replaces the version in files without triggering a version increment.
  • sample-config helps new users configure bumpy-my-version by printing a sample configuration file.
  • show provides access to current configuration information.
  • show-bump helps developers understand the current versioning convention by showing the possible versions resulting from the bump subcommand.
"},{"location":"reference/subcommands/show/","title":"The show subcommand","text":"

The main purpose of the show subcommand is to provide access to configuration data via scripts.

"},{"location":"reference/subcommands/show/#basic-use","title":"Basic use","text":"

The configuration object is a dict containing nested data structures. The arguments and options of this command relate to extracting data from the configuration object and presenting the extracted data.

"},{"location":"reference/subcommands/show/#specifying-the-output-data","title":"Specifying the output data","text":"

The positional arguments determine the data shown. If nothing or all is passed, the entire configuration is shown.

Positional arguments are specified using a format like Django variable resolution.

Examples:

  • a.b specifies the \u201cb\u201d key in the nested dictionaries: {\"a\": {\"b\": \"value\"}}
  • a.3 specifies the 4th item (the first is 0) of the list at key \u201ca\u201d: {\"a\": [\"no\", \"nay\", \"nyet\", \"value\"]}
"},{"location":"reference/subcommands/show/#specifying-the-output-format","title":"Specifying the output format","text":"

If only one positional argument is passed, the default format only shows its value. If no positional arguments, several positional arguments, or all is passed, the output from pprint.pprint is shown.

This makes getting the current version easy:

$ bump-my-version show current_version\n1.0.1\n

You can request the output be formatted as YAML or JSON:

$ bump-my-version show --format yaml current_version\ncurrent_version: \"1.0.1\"\n$ bump-my-version show --format json current_version\n{\n  \"current_version\": \"1.0.1\"\n}\n
"},{"location":"reference/subcommands/show/#including-the-incremented-version-before-bumping","title":"Including the incremented version before bumping","text":"

Your workflow might want to know the new version before you actually do the bumping. The --increment or -i option accepts a version part to bump and adds a new_version key into the configuration.

$ bump-my-version --increment patch show\n1.0.2\n$ bump-my-version --increment minor show\n1.1.0\n$ bump-my-version --increment major show\n2.0.0\n
"},{"location":"tutorials/","title":"Tutorials","text":"
  • Versioning using semantic versioning
  • Basic usage
"},{"location":"tutorials/semantic-versioning-example/","title":"Semantic versioning example","text":""},{"location":"tutorials/semantic-versioning-example/#create-a-default-configuration","title":"Create a default configuration","text":"

The default configuration uses a simplified version of semantic versioning.

Generating a default configuration
$ bump-my-version sample-config --no-prompt --destination .bumpversion.toml\n$ cat .bumpversion.toml\n[tool.bumpversion]\ncurrent_version = \"0.1.0\"\nparse = \"(?P<major>\\\\d+)\\\\.(?P<minor>\\\\d+)\\\\.(?P<patch>\\\\d+)\"\nserialize = [\"{major}.{minor}.{patch}\"]\nsearch = \"{current_version}\"\nreplace = \"{new_version}\"\nregex = false\nignore_missing_version = false\ntag = false\nsign_tags = false\ntag_name = \"v{new_version}\"\ntag_message = \"Bump version: {current_version} \u2192 {new_version}\"\nallow_dirty = false\ncommit = false\nmessage = \"Bump version: {current_version} \u2192 {new_version}\"\ncommit_args = \"\"\n
"},{"location":"tutorials/semantic-versioning-example/#visualize-the-versioning-path","title":"Visualize the versioning path","text":"

You can see the potential versioning paths with the show-bump subcommand.

Showing the potential versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0\n               \u251c\u2500 minor \u2500 0.2.0\n               \u2570\u2500 patch \u2500 0.1.1\n$ bump-my-version show-bump 1.2.3\n1.2.3 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0\n               \u251c\u2500 minor \u2500 1.3.0\n               \u2570\u2500 patch \u2500 1.2.4\n

The default configuration only allows bumping the major, minor, or patch version. What if you wanted to support pre-release versions?

"},{"location":"tutorials/semantic-versioning-example/#add-support-for-pre-release-versions","title":"Add support for pre-release versions","text":"

Alter the parse configuration to support pre-release versions. This parse option uses an extended (or verbose) regular expression to extract the version parts from the current version.

New parse configuration
parse = \"\"\"(?x)\n    (?P<major>0|[1-9]\\\\d*)\\\\.\n    (?P<minor>0|[1-9]\\\\d*)\\\\.\n    (?P<patch>0|[1-9]\\\\d*)\n    (?:\n        -                             # dash separator for pre-release section\n        (?P<pre_l>[a-zA-Z-]+)         # pre-release label\n        (?P<pre_n>0|[1-9]\\\\d*)        # pre-release version number\n    )?                                # pre-release section is optional\n\"\"\"\n

Alter the serialize configuration to support pre-release versions.

New serialize configuration
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{pre_n}\",\n    \"{major}.{minor}.{patch}\",\n]\n

Add a new configuration section for the pre_l part.

New pre_l configuration
[tool.bumpversion.parts.pre_l]\nvalues = [\"dev\", \"rc\", \"final\"]\noptional_value = \"final\"\n
"},{"location":"tutorials/semantic-versioning-example/#visualize-the-new-versioning-path","title":"Visualize the new versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u251c\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n               \u2570\u2500 pre_n \u2500 0.1.0-final1\n

The pre_l is not bump-able because it is already at the maximum value. The pre_n is bump-able because it is not at the maximum value.

If we run bump-my-version show-bump 1.0.0-dev0, we can see the new versioning path for a dev starting version.

Showing the new versioning path for a dev version
$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u251c\u2500 pre_l \u2500 1.0.0-rc0\n                    \u2570\u2500 pre_n \u2500 1.0.0-dev1\n

Finally, we can see the new versioning path for a rc starting version.

Showing the new versioning path for an rc version
$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u251c\u2500 pre_l \u2500 1.0.0\n                   \u2570\u2500 pre_n \u2500 1.0.0-rc1\n

The full development and release path is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
  • bump pre_n \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
  • bump pre_n \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase using bump-my-version bump pre_n.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidates increase using bump-my-version bump pre_n.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"tutorials/semantic-versioning-example/#automate-the-pre-release-numbering","title":"Automate the pre-release numbering","text":"

The pre_n or pre-release number is a number that increases with each pre-release. You can automate this my changing the serialization configuration.

Serialize configuration with pre_n automation
serialize = [\n    \"{major}.{minor}.{patch}-{pre_l}{distance_to_latest_tag}\",\n    \"{major}.{minor}.{patch}\",\n]\n

The distance_to_latest_tag is a special value that is replaced with the number of commits since the last tag. This is a good value to use for the pre_n because it will always increase with each commit.

"},{"location":"tutorials/semantic-versioning-example/#visualize-the-pre_n-versioning-path","title":"Visualize the pre_n versioning path","text":"

Now when you run bump-my-version show-bump, you can see the new pre-release versioning path.

Showing the new versioning path with pre_n automation
$ bump-my-version show-bump\n0.1.0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 1.0.0-dev0\n               \u251c\u2500 minor \u2500 0.2.0-dev0\n               \u251c\u2500 patch \u2500 0.1.1-dev0\n               \u2570\u2500 pre_l \u2500 invalid: The part has already the maximum value among ['dev', 'rc', 'final'] and cannot be bumped.\n$ bump-my-version show-bump 1.0.0-dev0\n1.0.0-dev0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                    \u251c\u2500 minor \u2500 1.1.0-dev0\n                    \u251c\u2500 patch \u2500 1.0.1-dev0\n                    \u2570\u2500 pre_l \u2500 1.0.0-rc0\n$ bump-my-version show-bump 1.0.0-rc0 \n1.0.0-rc0 \u2500\u2500 bump \u2500\u252c\u2500 major \u2500 2.0.0-dev0\n                   \u251c\u2500 minor \u2500 1.1.0-dev0\n                   \u251c\u2500 patch \u2500 1.0.1-dev0\n                   \u2570\u2500 pre_l \u2500 1.0.0\n

The pre_n path is now missing because it is automated.

The full development and release path now is:

  • 1.0.0
  • bump patch \u2192 1.0.1-dev0
    • each commit will increase \u2192 1.0.1-dev1
  • bump pre_l \u2192 1.0.1-rc0
    • each commit will increase \u2192 1.0.1-rc1
  • bump pre_l \u2192 1.0.1
  1. You must decide on the next version before you start developing.
  2. Development versions increase automatically with each commit.
  3. Switch from development to release candidate using bump-my-version bump pre_l.
  4. Release candidate versions increase automatically with each commit.
  5. Switch from the release candidate to the final release using bump-my-version bump pre_l.
"},{"location":"tutorials/usage/","title":"Usage","text":"

There are two modes of operation: On the command line for single-file operation and using a configuration file (pyproject.toml or .bumpversion.toml) for more complex multi-file processes. We recommend using a configuration file for all but the simplest of projects.

Warning

The invocation of bump-my-version changed in version 0.6.0. It splits functionality into sub-commands. It remains backward-compatible with previous versions. Previous usage is discouraged and may be removed in a 1.0 release.

"},{"location":"tutorials/usage/#incrementing-a-version","title":"Incrementing a version","text":"
bump-my-version bump [OPTIONS] [ARGS]...\n

The bump sub-command triggers a version increment. The complete list of options is available. The ARGS may contain a VERSION_PART or FILES

"},{"location":"tutorials/usage/#version_part","title":"VERSION_PART","text":"

[optional]

The part of the version to increase, e.g., minor.

Valid values include those given in the --serialize / --parse option.

For example, if the current version is 0.5.1 and you want to bump it to 0.6.0:

bump-my-version bump minor\n
"},{"location":"tutorials/usage/#files","title":"FILES","text":"

[optional] default: None

The additional file(s) to modify.

This file is added to the list of files specified in the configuration file. If you want to rewrite only files specified on the command line, use --no-configured-files.

For example, if the current version is 1.1.9 and you want to bump the version to 2.0.0 and also change the version in the _version.txt file:

bump-my-version bump major _version.txt\n

If you want to bump the current version of 1.1.9 to 2.0.0\u00a0and only change the _version.txt file:

bump-my-version bump --no-configured-files major _version.txt\n
"},{"location":"tutorials/usage/#showing-configuration-information","title":"Showing configuration information","text":"
bump-my-version show [OPTIONS] [ARGS]\n

The show subcommand allows you to output the entire or parts of the configuration to the console. The default invocation will output in the default format. The default format changes if one or more than one item is requested. If more than one item is asked for, it outputs the result of Python\u2019s pprint function. If only one thing is asked for, it outputs that value only.

$ bump-my-version show current_version\n1.0.0\n$ bump-my-version show current_version commit\n{'current_version': '1.0.0', 'commit': False}\n

You can use the --increment option to enable a new_version key.

$ bump-my-version show --increment minor current_version new_version\n{'current_version': '1.0.0', 'new_version': '1.1.0'}\n

You can also specify the output to be in JSON or YAML format:

$ bump-my-version show --format yaml current_version\ncurrent_version: \"1.0.0\"\n$ bump-my-version show --format yaml current_version commit\ncurrent_version: \"1.0.0\"\ncommit: false\n$ bump-my-version show --format json current_version\n{\n  \"current_version\": \"1.0.0\"\n}\n$ bump-my-version show --format json current_version commit\n{\n  \"current_version\": \"1.0.0\",\n  \"commit\": false,\n}\n
"},{"location":"tutorials/usage/#searching-and-replacing-without-bumping","title":"Searching and replacing without bumping","text":"

More complex workflows may require you to change one or more files without changing the current_version in the configuration file.

The replace sub-command works identically to the bump sub-command except for the following:

  • It will not commit or tag any changes
  • It will not increment the version
  • It will not change the configuration file

Note

If you do not include the --new-version option, the new_version context variable will be None.

One way of providing the --new-version option is to use the bump-my-version show subcommand with an environment variable:

$ export BUMPVERSION_NEW_VERSION=$(bump-my-version show new_version --increment <versionpart>)\n$ bump-my-version replace\n
"}]} \ No newline at end of file diff --git a/sitemap.xml.gz b/sitemap.xml.gz index 28ea21d9..e2ead427 100644 Binary files a/sitemap.xml.gz and b/sitemap.xml.gz differ diff --git a/tutorials/usage/index.html b/tutorials/usage/index.html index 31e04025..5c52cc46 100644 --- a/tutorials/usage/index.html +++ b/tutorials/usage/index.html @@ -2111,14 +2111,14 @@

Searching and replacing without
  • It will not increment the version
  • It will not change the configuration file
  • -

    ```{admonition} NOTE

    -

    If you do not include the --new-version option, the new_version context variable will be None. -

    One way of providing the `--new-version` option is to use the `bump-my-version show` subcommand with an environment variable:
    -
    -```console
    -$ export BUMPVERSION_NEW_VERSION=$(bump-my-version show new_version --increment <versionpart>)
    -$ bump-my-version replace
    -

    +
    +

    Note

    +

    If you do not include the --new-version option, the new_version context variable will be None.

    +
    +

    One way of providing the --new-version option is to use the bump-my-version show subcommand with an environment variable:

    +
    $ export BUMPVERSION_NEW_VERSION=$(bump-my-version show new_version --increment <versionpart>)
    +$ bump-my-version replace
    +
    @@ -2139,7 +2139,7 @@

    Searching and replacing without - March 27, 2024 + July 1, 2024 @@ -2150,11 +2150,11 @@

    Searching and replacing without - +