Centralized monorepo version-sync tool driven by versions.yaml.
Project description
scitrera-repo-tools
Monorepo maintenance toolkit. The primary subcommand, sync-versions, is
driven by versions.yaml; auxiliary subcommands (npm-audit, missing-deps,
directory-split) reuse the same config or stand alone.
Install
pip install scitrera-repo-tools
# or, from source:
pip install -e .
Every subcommand is available either as a top-level console script or via the
repo-tools dispatcher:
sync-versions ...
repo-tools sync-versions ...
python -m scitrera_repo_tools sync-versions ...
Drop-in shims live in scripts/ (update-versions.py, npm-audit.py,
missing-deps.py, directory-split.py). Copy any of them into a target repo
and they will use the installed package if available, otherwise fall back to
uvx and finally print install instructions.
sync-versions
From any directory inside a monorepo containing a versions.yaml:
sync-versions # apply updates (preserves local refs)
sync-versions --check # dry-run, exit 1 on drift
sync-versions --verbose # show every file inspected
sync-versions --config path/to/versions.yaml
Release mode
By default, sync-versions preserves local-reference dep specifiers
(file:../foo, workspace:*, link:, git+..., PEP 508 pkg @ git+...)
so local development keeps working. Before publishing to PyPI/npm, opt in
to rewrite those into canonical version pins from versions.yaml:
sync-versions --release # rewrite local refs to version pins
sync-versions --release --check # preview the release-pass diff in CI
Typical pre-publish flow:
sync-versions --release
git diff # review the version-pin substitutions
# ... build + publish (npm publish / uv publish) ...
git checkout -- . # restore local refs for ongoing dev
versions.yaml schema
# Top-level project versions
my-python-pkg: 0.1.22
my-ts-pkg: 0.1.22
# External dep pins per language (optional)
preferred_versions:
python:
"pydantic": "2.13.4" # bare -> `==2.13.4`; literal w/ operator preserved
typescript:
"@modelcontextprotocol/sdk": "^1.26.0"
go:
"google.golang.org/grpc": "v1.65.0" # bare or `v`-prefixed both accepted
"google.golang.org/protobuf": "1.34.1"
# Per-project file rules (replaces the hardcoded PROJECT_RULES dict)
project_rules:
my-python-pkg:
- { type: pyproject, path: my-python-pkg/pyproject.toml }
- { type: init_py, path: my-python-pkg/src/my_pkg/__init__.py }
my-ts-pkg:
- { type: package, path: my-ts-pkg/package.json }
# Internal monorepo cross-reference sync (optional)
dependency_mappings:
python:
packages:
"my-internal-dir": "my-published-name"
dependencies:
my-consumer:
- "my-internal-dir"
# Lockfile fallback for nulls in preferred_versions (optional)
sources:
python:
- "uv.lock"
# Global Go toolchain directives (optional, no-inject)
# Walks every go.mod referenced in project_rules.gomod_require.
go_toolchain:
go: "1.25" # rewrites the `go X.Y` directive
toolchain: "1.25.10" # rewrites `toolchain goX.Y.Z` (Go 1.21+ feature)
npm-audit
Runs npm audit (and optionally npm audit fix) across every TypeScript
package declared in versions.yaml (i.e. every project_rules entry with a
type: package rule). Mirrors the bash convention of bailing on missing
lockfiles, auto-running npm ci when node_modules is absent, and returning
a non-zero exit on any audit failure.
npm-audit # audit every TS project
npm-audit --fix # non-breaking fix + audit
npm-audit --fix --force # include breaking fixes
npm-audit --level high # high + critical only
npm-audit my-ts-pkg another-ts-pkg # subset by versions.yaml project name
missing-deps
Reads pyproject.toml and prints declared dependencies that are not yet
installed in the current environment. Useful for piping into a selective
pip install without re-resolving the full graph.
missing-deps # print missing deps from [project].dependencies
missing-deps --extra test # also include the `[test]` extra
missing-deps --ignore some-pkg # skip specific packages
missing-deps --print-installed # report installed versions to stderr
directory-split
Splits a directory into N approximately-equal buckets via greedy bin-packing.
Top-level entries are treated as atomic units; top-level directories go one
level deeper so their children can spread across buckets (preventing one large
dir from dominating). Output: <parent>/<basename>-1 … <parent>/<basename>-N.
Deterministic for fixed inputs.
directory-split ./data 4 # split into 4 buckets
directory-split ./data 4 --exclude "*.log" # skip log files at top level
directory-split ./data 4 --exclude .git --exclude node_modules
License
BSD 3-Clause.
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 scitrera_repo_tools-0.1.9.tar.gz.
File metadata
- Download URL: scitrera_repo_tools-0.1.9.tar.gz
- Upload date:
- Size: 35.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
55e825b8dec6ef1630954748b38812664a994094f1a9535d448682f07e8d880c
|
|
| MD5 |
7e954a43731cb608375de7ef044a1e1f
|
|
| BLAKE2b-256 |
66cd2f0f22ea8d67d460a291262cba528daf7bab9ae5eb9b5e10b6601c006bf4
|
Provenance
The following attestation bundles were made for scitrera_repo_tools-0.1.9.tar.gz:
Publisher:
release.yml on scitrera/repo-tools
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
scitrera_repo_tools-0.1.9.tar.gz -
Subject digest:
55e825b8dec6ef1630954748b38812664a994094f1a9535d448682f07e8d880c - Sigstore transparency entry: 1603318132
- Sigstore integration time:
-
Permalink:
scitrera/repo-tools@a629bf471d3153babcf797b3803d52c4c1306008 -
Branch / Tag:
refs/tags/v0.1.9 - Owner: https://github.com/scitrera
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@a629bf471d3153babcf797b3803d52c4c1306008 -
Trigger Event:
push
-
Statement type:
File details
Details for the file scitrera_repo_tools-0.1.9-py3-none-any.whl.
File metadata
- Download URL: scitrera_repo_tools-0.1.9-py3-none-any.whl
- Upload date:
- Size: 38.8 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 |
4ebc94272b6a0f8eed67b7da4fbe8bdb33cd4af103f3f0a41d5c5da224707d88
|
|
| MD5 |
71077dd1bd1572e943f5754f9ac32f57
|
|
| BLAKE2b-256 |
b3b7269930d8e1677791fde63777d666941066c8faa50808eba5a8e441152c3c
|
Provenance
The following attestation bundles were made for scitrera_repo_tools-0.1.9-py3-none-any.whl:
Publisher:
release.yml on scitrera/repo-tools
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
scitrera_repo_tools-0.1.9-py3-none-any.whl -
Subject digest:
4ebc94272b6a0f8eed67b7da4fbe8bdb33cd4af103f3f0a41d5c5da224707d88 - Sigstore transparency entry: 1603318240
- Sigstore integration time:
-
Permalink:
scitrera/repo-tools@a629bf471d3153babcf797b3803d52c4c1306008 -
Branch / Tag:
refs/tags/v0.1.9 - Owner: https://github.com/scitrera
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@a629bf471d3153babcf797b3803d52c4c1306008 -
Trigger Event:
push
-
Statement type: