A pluggable framework for building codemods in Python
Project description
codemodder-python
This is the Python version of the Codemodder Framework.
Codemodder is sponsored by pixee.ai.
Development Status
As of v0.80.0 the codemod API is relatively stable. However, backwards compatibility between releases will not be guaranteed until version 1.0.0.
See CHANGELOG.md for detailed release notes.
Installation
The codemodder
package is available on PyPI. To install, run:
$ pip install codemodder
To install the package from source, use pip
:
$ pip install /path/to/codemodder-python
Running codemodder
CLI
Codemodder can be run as a CLI. The codemodder package provides an executable called codemodder
. This should be available on your path by default after installation.
For basic usage, run the codemodder
command with a target directory path:
$ codemodder /path/to/my-project
Note that by default codemodder
will make changes to files in your target directory. To run codemodder
without making updates on disk, use the --dry-run
flag:
$ codemodder --dry-run /path/to/my-project
To list all available codemods (including any that are registered with installed plugins), use the --list
option:
$ codemodder --list
For a full list of options, use the --help
flag:
$ codemodder --help
Library
You can also run codemodder
as a library by importing the module and running run
. For basic usage, pass a target directory path and the dry_run
argument:
import codemodder
output, exit_code = codemodder.run("/path/to/my-project", dry_run=True)
Unlike the CLI which has a default dry_run
of False
, when calling codemodder
as a library you must indicate if you want codemodder
to make changes to your files.
Architecture
Codemods are composed of the following key components:
- Detector
- Transformer(s)
- Metadata
Custom Codemods
The Python codemodder supports a plugin infrastructure for custom codemods. For users interested in developing a custom codemod plugin, we recommend starting with the Cookiecutter template.
Documentation
Coming soon!
Contributing
See CONTRIBUTING.md.
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
Built Distribution
File details
Details for the file codemodder-3.12.0.tar.gz
.
File metadata
- Download URL: codemodder-3.12.0.tar.gz
- Upload date:
- Size: 737.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f3883d0d469597572cf1c6a90a6b66caa4f51c5a651f2dc4f20d4624e600d835 |
|
MD5 | b54916b5fcc8ab95663b8f61c79785ed |
|
BLAKE2b-256 | 9e5a3ee4206af5b60dd39e34ca98bb8cc387411cd21e0aff6fd82b2a43cec168 |
File details
Details for the file codemodder-3.12.0-py3-none-any.whl
.
File metadata
- Download URL: codemodder-3.12.0-py3-none-any.whl
- Upload date:
- Size: 286.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c60968c6c37214ca27041ae79277a9055d6d55c895c922c65c1db694855cdda2 |
|
MD5 | d45f580d98f1a44711d0bb0864284231 |
|
BLAKE2b-256 | 6029b1fee201b2f447dcababa00ab15c467fc55aee9c92a7788567762a1e66f0 |