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

VersionControlHookManager PythonLinter MarkdownLinter 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 is a package and tool that scaffolds and initializes a complete, fully configured, installed and working python project with one command and makes the process of developing and maintaining it more seamless and efficient by automating things like configuration management, CLI generation, testing infrastructure, and more.

Requirements

  • Python 3.12+
  • Git
  • uv

Quick Start

uv init
uv add pyrig
uv run pyrig init

See the Getting Started Guide for detailed setup instructions to also fully integrate with GitHub and CI/CD from the start.

Features

Project Scaffolding & Initialization

pyrig init generates a complete project in one command that works out of the box. This includes everything a modern python project needs:

  • Standardized directory structure
  • Fully configured dev tools (linters, formatters, type checkers, test frameworks, git hooks, etc.)
  • End-to-end CI/CD pipeline with GitHub Actions and integrated repository protection
  • Complete and working CLI
  • And much more...

File & Configuration Management

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. Run pyrig mkroot to create or update all config files at once. Run pyrig subcls to generate a subclass for overriding a specific file.

Automatic CLI

pyrig init sets up a CLI for your project that works immediately. Generate and add new commands by running pyrig mkcmd <command-name>. An automatic version command is included that shows the version of your project. Run my-project version to see it in action.

Mirror Test Generation & Maintenance

Generate test skeletons with pyrig mktests. This will generate test skeletons for all source modules and update them automatically as your project evolves.

Test Fixtures

pyrig enables automatic sharing and registration of pytest fixtures. Run pyrig mkfixture <fixture-name> to generate a new fixture that is automatically registered and available across all your tests.

Build Artifacts

PyInstaller integration and extensible build system for generating executables, distributable packages, and more. Run pyrig subcls to create a custom builder for your specific build needs. Run pyrig build to execute the build process and generate artifacts. Run pyrig resources to create a resources package for your project.

Multi-Package Inheritance and Extensibility Architecture

Override and customize any and all behaviour to suit your project's needs. pyrig's classes are designed for inheritance and composition, allowing you to create custom configurations, tools, builders, and more by subclassing and simply overriding methods. pyrig will automatically discover and use your custom classes without any additional configuration. Run pyrig subcls to generate a subclass for any pyrig class.

CI/CD & Repository Protection

Pyrig generates GitHub Actions workflows for CI/CD and automatically configures and applies repository protection settings and branch protection rules to ensure your repository is protected. Run pyrig protect-repo to apply or update repository protection settings or simply use the fully working CI/CD pipeline to apply them automatically.

Commands

Run pyrig <command> --help for more information about a specific command and its usage.

uv run pyrig init                    # Full project initialization
uv run pyrig mkroot                  # Create/update all concrete config files
uv run pyrig mktests                 # Generate test skeletons
uv run pyrig mkinits                 # Create missing __init__.py files
uv run pyrig mkfixture <name>        # Generate a new pytest fixture
uv run pyrig mkcmd <name>            # Create a new CLI subcommand stub
uv run pyrig subcls                  # generate and override subclasses
uv run pyrig build                   # Build artifacts (PyInstaller, etc.)
uv run pyrig resources               # Scaffold the resources package
uv run pyrig protect-repo            # Configure repository protection
uv run pyrig scratch                 # Execute the project's .scratch.py file
uv run pyrig rmpyc                   # Remove __pycache__ directories
uv run pyrig version                 # Show pyrig version
uv run my-project --help             # Your project's CLI
uv run my-project version            # Show your project's version

Documentation

Full Documentation The manually written documentation
CodeWiki AI-generated documentation
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.8.0.tar.gz (147.3 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.8.0-py3-none-any.whl (216.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyrig-11.8.0.tar.gz
  • Upload date:
  • Size: 147.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","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.8.0.tar.gz
Algorithm Hash digest
SHA256 bb2abcc7f523b949bbdbfc8e8b170b82f7675f1d53f0b164601a4e5814cb66d3
MD5 131acc95d812cd0d3216a84c6bed64cc
BLAKE2b-256 a4325539085889171db4dc8a6f5c2c86d71a804edb44e85e0cf3085b88d933f5

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyrig-11.8.0-py3-none-any.whl
  • Upload date:
  • Size: 216.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","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.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a4048a78c2d28a5928c1bcee1af9f2f2cf247d4b1a449a9ddebf308b9a856ba3
MD5 57980cabfaa5d4e01f56fd1645a29f19
BLAKE2b-256 7a2b0964cbe58c11bbc16c04d15778ba8191df9d2a9496f99c657a09aeb74518

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