Skip to main content

pyrig is a python toolkit that rigs up your project by standardizing and automating project setup, configuration and maintenance

Project description

pyrig

SecurityChecker DependencyAuditor

VersionController RemoteVersionController ContainerEngine Pyrigger PackageManager

DocsBuilder Documentation

PreCommitter Linter MDLinter TypeChecker

PackageIndex ProgrammingLanguage License

ProjectTester ProjectCoverageTester

CI CD


pyrig is a python toolkit that rigs up your project by standardizing and automating project setup, configuration and maintenance


What is pyrig?

pyrig generates and maintains a complete, production-ready Python project from a single command. It creates all the files you need — source structure, tests, CI/CD, documentation, configs — and keeps them in sync as your project evolves. Rerun it anytime: pyrig is idempotent.

Quick Start

uv init
uv add pyrig
uv run pyrig init

See the Getting Started Guide for detailed setup instructions.

Features

Idempotent Project Scaffolding

pyrig init generates a complete project in one command — source tree, tests, CI/CD workflows, documentation, configs, and a working CLI. Run it again anytime to sync everything; pyrig never overwrites your customizations.

Getting Started · Generated Structure

Config File System

Every generated file is backed by a Python class that validates and merges automatically. Override any config by subclassing, or define entirely new config files — pyrig discovers and manages them for you.

Config Architecture

Automatic CLI

pyrig init sets up a CLI for your project that works immediately. Add commands by defining functions in <package>.rig.cli.subcommands — they're discovered automatically. Shared commands propagate across the entire dependency chain.

CLI docs

Testing Infrastructure

  • pytest as the test runner with autouse fixtures that enforce best practices
  • pyrig mktests generates test skeletons mirroring your source structure
  • Autouse fixtures validate project invariants — init files, config correctness, dependency freshness

Test Structure · Autouse Fixtures

Multi-Package Inheritance (.I pattern)

Override almost any behavior — configs, tools, CLI commands, builders — by subclassing the pyrig-provided class. pyrig discovers your implementation automatically and uses it instead of the default.

This enables creating a personal pyrig package with your own standards, adding it as a dependency to any project, and having pyrig init apply everything automatically.

Tool Architecture · Config Architecture

Tool Wrappers

Type-safe wrappers around uv, git, ruff, pytest, bandit, and more. Customizable via subclassing for organization-wide or per-project overrides.

Tools · Tooling Choices

Builders, Resources & Packaging

  • Builders — PyInstaller integration and extensible build system
  • Resources — Reliable file access in both development and PyInstaller bundles
  • Packaginguv_build backend with console script integration

Builders · Resources

CI/CD & Repository Automation

Generates GitHub Actions workflows, branch protection configs, issue/PR templates, and release flows. Verbosity flags (-v, -vv, -q) provide flexible logging across all commands.

Workflows · Branch Protection

CLI Commands

uv run pyrig init           # Full project initialization
uv run pyrig mkroot         # Create/update all config files
uv run pyrig mktests        # Generate test skeletons
uv run pyrig mkinits        # Create missing __init__.py files
uv run pyrig build          # Build artifacts (PyInstaller, etc.)
uv run pyrig protect-repo   # Configure repository protection
uv run pyrig scratch        # Execute the project's .scratch file
uv run pyrig rmpyc          # Remove __pycache__ directories
uv run my-project --help    # Your project's CLI
uv run my-project version   # Show pyrig or project version

CLI Reference

Documentation

Getting Started Complete setup guide
Full Documentation Comprehensive reference
Trade-offs What you give up and what you gain
CodeWiki AI-generated docs
Tutorials YouTube tutorials for pyrig

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

pyrig-11.1.27.tar.gz (129.7 kB view details)

Uploaded Source

Built Distribution

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

pyrig-11.1.27-py3-none-any.whl (198.6 kB view details)

Uploaded Python 3

File details

Details for the file pyrig-11.1.27.tar.gz.

File metadata

  • Download URL: pyrig-11.1.27.tar.gz
  • Upload date:
  • Size: 129.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pyrig-11.1.27.tar.gz
Algorithm Hash digest
SHA256 2be84e71a59c9c1534f7f0fa47a211b08faf64abbd9e2af24099330d2b922617
MD5 3b16d1350fde7cc5cb6b6e07fecadac8
BLAKE2b-256 5b7bc8df2f7ae77bc6af1573eb63a3064019062b972dd8c8fd7c081f52fbf1bf

See more details on using hashes here.

File details

Details for the file pyrig-11.1.27-py3-none-any.whl.

File metadata

  • Download URL: pyrig-11.1.27-py3-none-any.whl
  • Upload date:
  • Size: 198.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pyrig-11.1.27-py3-none-any.whl
Algorithm Hash digest
SHA256 647d092ec507b9c92e7dc30a87bad2f4a150b76c3dd5237e0d7391f454f81971
MD5 01394adb36c94335809c4add9a61f9c7
BLAKE2b-256 24ad92cc19b0d3aac51c12bf1f44e4f90f771fa78de37337a33bb4111fa32d83

See more details on using hashes here.

Supported by

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