Skip to main content

The Non-Destructive Configuration Steward for Python Projects.

Project description

ApexCodexPy

The Non-Destructive Configuration Steward for Python Projects.

ApexCodexPy is a CLI tool designed to enforce consistent linting and typing standards across multiple projects. Unlike standard runners, ApexCodexPy synchronizes your pyproject.toml with a "Gold Standard" configuration without destroying existing project-specific settings or comments.

🚀 Purpose

Modern Python development often suffers from "Config Drift"—where different projects slowly diverge in their ruff or mypy settings. ApexCodexPy solves this by:

Enforcing Standards

Overwriting critical linting rules with a centralized set of best practices.

Preserving Context

Using tomlkit to ensure that your handwritten comments and formatting remain intact.

Dry-Run Capability

Allowing developers to see exactly what would change before any modifications are written to disk.

📦 Installation & Integration

From PyPI

Since ApexCodexPy is available on PyPI, you can add it directly to your project using Poetry:

poetry add apexcodexpy --group dev

🛠 Usage

1. Synchronize Configuration

Align your pyproject.toml with the ApexCodexPy standards.

# Preview changes (Dry Run)
codex update --dry-run

# Apply changes
codex update

2. Run Linting & Formatting checks

Run the enforced toolchain (Ruff and Mypy) on your project.

# Standard run (verbose)
codex lint

# No output (suppress stdout/stderr)
codex lint --silent

3. Auto formating and fixing

Run the enforced toolchain (Ruff and Mypy) on your project.

# Standard run (verbose)
codex fix

# No output (suppress stdout/stderr)
codex fix --silent

🧩 Standards Enforced

ApexCodexPy currently enforces a strict ruff.lint.select list including:

Name Code
pyflakes F
pycodestyle (Errors) E
pycodestyle (Warnings) W
isort I
pep8-naming N
pyupgrade UP
flake8-bugbear B
flake8-builtins A
flake8-comprehensions C4
flake8-print T20
flake8-pytest-style PT
flake8-raise RSE
flake8-return RET
flake8-simplify SIM
flake8-unused-arguments ARG

It also enforces mypy.strict = true.

👨‍💻 For Developers: How it Works

Non-Destructive Merge

The core logic resides in a functional deep_merge. It takes the project's current TOML and the ApexCodexPy standards, returns a new configuration, and preserves all tomlkit item metadata (inline comments).

Architecture: Strategy Pattern

  • Task Protocol: implementations run various tools and report their results.
  • Device Protocol: used by reporter to output results.
  • Reporter: standard output format.
  • PyCodex: Class that ties everything together.

To add a new tool:

  • Create a new Task implementation.
  • Add the tool's standard config to get_standards().
  • Register the task in PyCodex.
  • Add CLI command using the above-mentioned PyCodex method.

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

apexcodexpy-0.1.3.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

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

apexcodexpy-0.1.3-py3-none-any.whl (20.7 kB view details)

Uploaded Python 3

File details

Details for the file apexcodexpy-0.1.3.tar.gz.

File metadata

  • Download URL: apexcodexpy-0.1.3.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.4 CPython/3.11.15 Linux/6.17.0-1010-azure

File hashes

Hashes for apexcodexpy-0.1.3.tar.gz
Algorithm Hash digest
SHA256 f3f1f214e15a862fb4526958b459d355dcef2c6c6529f3212650c382594f57fa
MD5 a3c025967338b3ec7fd505d08865a7e7
BLAKE2b-256 3cb2b2d169ed705903ad1983890872f4a4087ed046d0e867cec0de0e3d95a6a7

See more details on using hashes here.

File details

Details for the file apexcodexpy-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: apexcodexpy-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 20.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.3.4 CPython/3.11.15 Linux/6.17.0-1010-azure

File hashes

Hashes for apexcodexpy-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 b7a451c780fe1658bfed34efb1b0cd266f6335596e8f38424d894e438be1aa35
MD5 72febc7b668d2e14e4c2d63921081908
BLAKE2b-256 5a8cb08892cd06ed1b66ccc88d7b5d4f7240e3a3186e073dd7b46b346fc18ad5

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