The Codebase Bemanification Tool
Project description
beman-tidy: The Codebase Bemanification Tool
beman-tidy is a tool aimed at Beman Project contributors to check (--dry-run)
and apply (--fix-inplace) the Beman Standard
to their repositories.
Note 2025-06-07: The first iteration of the tool will not support --fix-inplace in order to
expedite adoption across the Beman Project.
Installation
uv tool install beman-tidy
To update:
uv tool upgrade beman-tidy
Post-install sanity check:
beman-tidy --help
Requirements
- Python 3.12+
uv(Python package and project manager - Installation)
Compatibility
- Linux
- macOS
- Windows
Usage
- Display help:
$ beman-tidy --help
usage: beman-tidy [-h] [--fix-inplace | --no-fix-inplace] [--verbose | --no-verbose] [--require-all | --no-require-all] [--checks CHECKS] [--config CONFIG] repo_path
positional arguments:
repo_path path to the repository to check
options:
-h, --help show this help message and exit
--fix-inplace, --no-fix-inplace
Try to automatically fix found issues
--verbose, --no-verbose
print verbose output for each check
--require-all, --no-require-all
all checks are required regardless of the check type (e.g., Recommendation becomes Requirement)
--checks CHECKS array of checks to run
--config CONFIG path to the configuration file (default: .beman-tidy.yaml in repo root)
- Run beman-tidy on the exemplar repository (default: dry-run mode)
# dry-run, require-all, non-verbose
$ beman-tidy --require-all /path/to/exemplar
Summary Requirement: 18 checks passed, 1 checks failed, 5 checks skipped, 23 checks not implemented.
Summary Recommendation: 0 checks passed, 0 checks failed, 0 checks skipped, 0 checks not implemented.
Coverage Requirement: 95.83% (23/24 checks passed).
Coverage Recommendation: 0.00% (0/0 checks passed).
Coverage TOTAL: 95.83% (23/24 checks passed).
# dry-run, no-require-all, non-verbose
$ beman-tidy /path/to/exemplar
Summary Requirement: 13 checks passed, 1 checks failed, 3 checks skipped, 9 checks not implemented.
Summary Recommendation: 5 checks passed, 0 checks failed, 2 checks skipped, 14 checks not implemented.
Coverage Requirement: 66.67% (16/24 checks passed).
Coverage Recommendation: 100.00% (7/7 checks passed).
Coverage TOTAL: 74.19% (23/31 checks passed).
or verbose mode without errors:
# dry-run, require-all, verbose mode - no errors
$ beman-tidy --require-all --verbose /path/to/exemplar
beman-tidy pipeline started ...
Running check [Requirement][license.approved] ...
[info ][license.approved ]: Valid Apache License - Version 2.0 with LLVM Exceptions found in LICENSE file.
check [Requirement][license.approved] ... passed
Running check [Requirement][license.apache_llvm] ...
check [Requirement][license.apache_llvm] ... passed
Running check [Requirement][license.criteria] ...
[skipped ][license.criteria ]: beman-tidy cannot actually check license.criteria. Please ignore this message if license.approved has passed. See https://github.com/bemanproject/beman/blob/main/docs/beman_standard.md#licensecriteria for more information.
Running check [Requirement][license.criteria] ... skipped
...
Running check [Requirement][readme.title] ...
check [Requirement][readme.title] ... passed
Running check [Requirement][readme.badges] ...
check [Requirement][readme.badges] ... passed
Running check [Requirement][readme.implements] ...
check [Requirement][readme.implements] ... passed
...
beman-tidy pipeline finished.
Summary Requirement: 19 checks passed, 0 checks failed, 3 checks skipped, 23 checks not implemented.
Summary Recommendation: 0 checks passed, 0 checks failed, 2 checks skipped, 0 checks not implemented.
Coverage Requirement: 100.00% (24/24 checks passed).
Coverage Recommendation: 0.00% (0/0 checks passed).
Coverage TOTAL: 100.00% (24/24 checks passed).
or verbose mode with errors:
# dry-run, require-all, verbose mode - with errors
$ beman-tidy --require-all --verbose /path/to/exemplar
beman-tidy pipeline started ...
Running check [Requirement][license.approved] ...
[info ][license.approved ]: Valid Apache License - Version 2.0 with LLVM Exceptions found in LICENSE file.
check [Requirement][license.approved] ... passed
Running check [Requirement][license.apache_llvm] ...
check [Requirement][license.apache_llvm] ... passed
Running check [Requirement][license.criteria] ...
[skipped ][license.criteria ]: beman-tidy cannot actually check license.criteria. Please ignore this message if license.approved has passed. See https://github.com/bemanproject/beman/blob/main/docs/beman_standard.md#licensecriteria for more information.
Running check [Requirement][license.criteria] ... skipped
...
Running check [Requirement][readme.implements] ...
check [Requirement][readme.implements] ... passed
Running check [Requirement][readme.library_status] ...
[error ][readme.library_status ]: The file '/Users/dariusn/dev/dn/git/Beman/exemplar/README.md' does not contain exactly one of the required statuses from ['**Status**: [Under development and not yet ready for production use.](https://github.com/bemanproject/beman/blob/main/docs/beman_library_maturity_model.md#under-development-and-not-yet-ready-for-production-use)', '**Status**: [Production ready. API may undergo changes.](https://github.com/bemanproject/beman/blob/main/docs/beman_library_maturity_model.md#production-ready-api-may-undergo-changes)', '**Status**: [Production ready. Stable API.](https://github.com/bemanproject/beman/blob/main/docs/beman_library_maturity_model.md#production-ready-stable-api)', '**Status**: [Retired. No longer maintained or actively developed.](https://github.com/bemanproject/beman/blob/main/docs/beman_library_maturity_model.md#retired-no-longer-maintained-or-actively-developed)']
check [Requirement][readme.library_status] ... failed
...
beman-tidy pipeline finished.
Summary Requirement: 18 checks passed, 1 checks failed, 3 checks skipped, 23 checks not implemented.
Summary Recommendation: 0 checks passed, 0 checks failed, 2 checks skipped, 0 checks not implemented.
Coverage Requirement: 95.83% (23/24 checks passed).
Coverage Recommendation: 0.00% (0/0 checks passed).
Coverage TOTAL: 95.83% (23/24 checks passed).
- Run beman-tidy on the exemplar repository (fix issues in-place):
beman-tidy --fix-inplace --verbose path/to/exemplar
CI Usage (GitHub Actions)
This repository already includes a full workflow in .github/workflows/beman-tidy.yml covering linting,
tests, build/install, and running beman-tidy on bemanproject/exemplar.
Configuration
beman-tidy attempts to read configuration for each source file from a .beman-tidy.yaml file located in the root of your repository. You can also specify a custom configuration file path using the --config option.
The following configuration options may be used in a .beman-tidy.yaml file:
-
ignored_paths- A list of paths to be excluded from all checks.- To ignore a specific file, provide its full path relative to the repository root.
- To ignore a directory, provide the path to that directory. This will ignore the directory itself and all files and subdirectories within it. A trailing slash (
/) is optional.
-
Example:
ignored_paths: # Ignores a single file - include/beman/optional/detail/stl_interfaces/config.hpp # Ignores a directory and everything inside it - include/beman/optional/another_dir
-
disabled_rules- A list of rule names (or patterns) to be completely skipped during checks.- To disable a specific rule, provide its exact name (e.g.,
readme.title). - To disable all rules in a category, use a glob pattern with
*(e.g.,readme.*to skip all readme checks). - To disable a specific rule across all categories, use
*.rule_name(e.g.,*.title). - Unknown patterns that don't match any known rule will produce a warning and be skipped.
- Disabled rules appear as "disabled" in the summary and are excluded from coverage calculations.
- To disable a specific rule, provide its exact name (e.g.,
-
Example:
disabled_rules: # Disable a single rule - readme.title # Disable all readme checks - readme.* # Disable all rules named "title" across categories - "*.title"
Fix-inplace Status
- The CLI exposes
--fix-inplace, but auto-fix support is currently limited.
Troubleshooting / FAQ
- Why is a check reported as skipped?
- Some checks are intentionally skippable/dummy implementations and emit a reason in verbose mode.
- Why do I see "not implemented" in the summary?
- The check exists in the Beman Standard snapshot but does not yet have an implemented checker.
- How do I ignore files/directories?
- Use
ignored_pathsin.beman-tidy.yaml.
- Use
- How do I disable specific rules?
- Use
disabled_rulesin.beman-tidy.yaml. You can specify exact rule names or glob patterns likereadme.*.
- Use
- How do I get more detail?
- Run with
--verboseto print per-check diagnostics.
- Run with
Integrating beman-tidy into Your Library
Please refer to the How to Integrate beman-tidy pre-commit Hook in Your Library for more details.
Contributing on beman-tidy
Please refer to the Beman Tidy Development Guide for more details.
License
Licensed under Apache-2.0 WITH LLVM-exception. See LICENSE.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file beman_tidy-0.5.1.tar.gz.
File metadata
- Download URL: beman_tidy-0.5.1.tar.gz
- Upload date:
- Size: 41.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1ace8cd4b491903ddc66336cb604f85cd401a6e8a0bc9a120c6a91b8b041ad57
|
|
| MD5 |
cbdebafde3000dca5dfef0323a4de828
|
|
| BLAKE2b-256 |
00615d19c5cf3cf9e115b63e6b1e35d99df32f895d50d861f3e8d19d2d9ba970
|
Provenance
The following attestation bundles were made for beman_tidy-0.5.1.tar.gz:
Publisher:
publish.yml on bemanproject/beman-tidy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
beman_tidy-0.5.1.tar.gz -
Subject digest:
1ace8cd4b491903ddc66336cb604f85cd401a6e8a0bc9a120c6a91b8b041ad57 - Sigstore transparency entry: 1625509404
- Sigstore integration time:
-
Permalink:
bemanproject/beman-tidy@f259aafb6423a4203925a2956fcf1f363b31fda5 -
Branch / Tag:
refs/tags/v0.5.1 - Owner: https://github.com/bemanproject
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@f259aafb6423a4203925a2956fcf1f363b31fda5 -
Trigger Event:
release
-
Statement type:
File details
Details for the file beman_tidy-0.5.1-py3-none-any.whl.
File metadata
- Download URL: beman_tidy-0.5.1-py3-none-any.whl
- Upload date:
- Size: 53.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a4af4bae45ccb876976bf567ff7cb5af776a6b35cf3a519372af0624b6ae9524
|
|
| MD5 |
3e632f7e584bc9735fb87c1f60c75eb2
|
|
| BLAKE2b-256 |
3409cad87cc7953b00498486696f05ea95dd2e28192414b1a79b47912c4d83ed
|
Provenance
The following attestation bundles were made for beman_tidy-0.5.1-py3-none-any.whl:
Publisher:
publish.yml on bemanproject/beman-tidy
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
beman_tidy-0.5.1-py3-none-any.whl -
Subject digest:
a4af4bae45ccb876976bf567ff7cb5af776a6b35cf3a519372af0624b6ae9524 - Sigstore transparency entry: 1625509416
- Sigstore integration time:
-
Permalink:
bemanproject/beman-tidy@f259aafb6423a4203925a2956fcf1f363b31fda5 -
Branch / Tag:
refs/tags/v0.5.1 - Owner: https://github.com/bemanproject
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@f259aafb6423a4203925a2956fcf1f363b31fda5 -
Trigger Event:
release
-
Statement type: