Skip to main content

Automatically fix Python code using ChatGPT

Project description

Auto Code Fixer

Auto Code Fixer is a CLI tool that detects runtime failures and automatically fixes Python code using OpenAI.

It is designed for real projects where an entry script imports multiple local modules. The tool runs your code in an isolated sandbox + venv, installs missing external dependencies, and applies fixes only after the code executes successfully.


Installation

pip install auto-code-fixer

Quick start

auto-code-fixer path/to/main.py --project-root . --ask

If you want it to overwrite without asking:

auto-code-fixer path/to/main.py --project-root . --no-ask

What it fixes (core behavior)

✅ Local/internal imports are treated as project code

If your entry file imports something like:

from mylib import add

…and mylib.py exists inside the project, Auto Code Fixer will:

  • copy main.py + mylib.py into a sandbox
  • execute inside the sandbox
  • if the traceback points to mylib.py, it will fix mylib.py
  • then apply the fix back to your repo (with backups)

✅ External imports are auto-installed

If execution fails with:

ModuleNotFoundError: No module named 'requests'

…it will run:

pip install requests

…but only inside the sandbox venv (so your system env isn’t polluted).


Safety

Backups

Before overwriting any file, it creates a backup:

  • file.py.bak (or .bak1, .bak2, ...)

Dry run

auto-code-fixer path/to/main.py --project-root . --dry-run

Advanced options

Run a custom command (pytest, etc.)

Instead of python main.py, run tests:

auto-code-fixer . --project-root . --run "pytest -q" --no-ask

Model selection

export AUTO_CODE_FIXER_MODEL=gpt-4.1-mini
# or
auto-code-fixer main.py --model gpt-4.1-mini

Max retries / timeout

auto-code-fixer main.py --max-retries 8 --timeout 30

Optional AI planning (which file to edit)

auto-code-fixer main.py --ai-plan

This enables a helper that can suggest which local file to edit. It is best-effort.

Optional structured patch protocol (JSON + sha256)

auto-code-fixer main.py --patch-protocol

When enabled, the model is asked to return strict JSON with {files:[{path,new_content,sha256}]}. The tool verifies the SHA-256 hash of new_content before applying edits, and falls back to the legacy full-text mode if parsing/validation fails.

Optional formatting / linting (best-effort)

auto-code-fixer main.py --format black
auto-code-fixer main.py --lint ruff --fix

These run inside the sandbox venv and are skipped if the tools are not installed.


Environment variables

  • OPENAI_API_KEY (required unless you always pass --api-key)
  • AUTO_CODE_FIXER_MODEL (default model)
  • AUTO_CODE_FIXER_ASK=true|false
  • AUTO_CODE_FIXER_VERBOSE=true|false

Notes

  • This tool edits code. Use it on a git repo so you can review diffs.
  • For maximum safety, run with --ask and/or --dry-run.

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

auto_code_fixer-0.3.6.tar.gz (18.5 kB view details)

Uploaded Source

Built Distribution

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

auto_code_fixer-0.3.6-py3-none-any.whl (20.4 kB view details)

Uploaded Python 3

File details

Details for the file auto_code_fixer-0.3.6.tar.gz.

File metadata

  • Download URL: auto_code_fixer-0.3.6.tar.gz
  • Upload date:
  • Size: 18.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for auto_code_fixer-0.3.6.tar.gz
Algorithm Hash digest
SHA256 b3ed0cbfd712fdcfb4589ef9fd55abf614d48e90ee1307a523dafb1de941419f
MD5 4c0c2457326944d9ad3e7c8fdb450119
BLAKE2b-256 879e63ecb642197be2675bc96b0c343ac9da151b510418b7831a81f63d8e770e

See more details on using hashes here.

File details

Details for the file auto_code_fixer-0.3.6-py3-none-any.whl.

File metadata

File hashes

Hashes for auto_code_fixer-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 d928965a1955fb4124426754b69d6d0cb53cfda9f530abcb270ea75e75d665e4
MD5 ff593df56f403c01ce7228186f30be88
BLAKE2b-256 3874d2edf7b66367ea1d0a2d2204453987ba2fc1965a2df44253c4a2b11b9d8b

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