Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/petr-muller/pyff
Python Diff
https://github.com/petr-muller/pyff
diff python semantic syntax
Last synced: 2 months ago
JSON representation
Python Diff
- Host: GitHub
- URL: https://github.com/petr-muller/pyff
- Owner: petr-muller
- License: apache-2.0
- Created: 2018-02-02T15:54:04.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-10-10T20:45:36.000Z (about 1 year ago)
- Last Synced: 2024-10-13T18:09:48.925Z (3 months ago)
- Topics: diff, python, semantic, syntax
- Language: Python
- Size: 133 KB
- Stars: 9
- Watchers: 3
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# pyff: Python Diff
Python Diff compares two versions of Python code (modules, packages,
directories containing Python modules and/or packages) and detects syntactical
and semantical differences between them.[![Build Status](https://travis-ci.org/petr-muller/pyff.svg?branch=master)](https://travis-ci.org/petr-muller/pyff) [![Maintainability](https://api.codeclimate.com/v1/badges/bb1aa4b86fed8097aa0f/maintainability)](https://codeclimate.com/github/petr-muller/pyff/maintainability) [![Codacy Badge](https://api.codacy.com/project/badge/Grade/b970a7c6c6314ab3b28bddaeab523457)](https://www.codacy.com/app/afri/pyff?utm_source=github.com&utm_medium=referral&utm_content=petr-muller/pyff&utm_campaign=Badge_Grade) [![Coverage Status](https://coveralls.io/repos/github/petr-muller/pyff/badge.svg?branch=master)](https://coveralls.io/github/petr-muller/pyff?branch=master)
## Installation
You can install pyff from [Python Package Index](https://pypi.org/) as
`pythodiff` (unfortunately, a name `pyff` was taken already):```
pip install pythondiff
```## Usage
You can run `pyff` to compare two Python modules:
```
pyff old.py new.py
```For comparing Python packages, there is the `pyff-package` executable:
```
pyff-package old_package new_package
```You can also compare directories using the `pyff-dir` executable. In this case,
`pyff` finds all Python content in both directories (recurively) and compares
everything it finds:```
pyff-dir old_directory new_directory
```Finally, `pyff-git` can compare Python content between two revisions in a given
Git repository. As with the `pyff-dir` case, this finds all Python content in
the repository.```
pyff-git https://github.com/petr-muller/pyff.git master^ master
```## Development
The development of `pyff` is far from complete: most of the basic features (code
elements being removed, changed or added) are there but not all of them. Some
Python code can also confuse `pyff` or even make it crash. PRs or issue reports
are happily accepted.`pyff` is written using a modern (3.6+) Python version and has both unit and
integration tests. The unit test coverage goal is 100% but it is OK to not cover
some elementary (or really hard to unit-test) code, provided the code is marked
with a `# pragma: no cover` comment. [pytest](https://pytest.org) is used as a
unit test driver. All code is statically checked with
[Pylint](https://www.pylint.org/) and also annotated with Python type hints. The
[mypy](http://mypy-lang.org/) checker is used to check them. You can install all
necessary test requirements using pip:```
pip install -r requirements-tests.txt
```There are shell helpers in `helpers/helpers.sh` that make
executing all checks easier:```
$ . helpers/helpers.sh
$ ft # Fast Test: run just unit tests, without pylint and mypy checks
$ st # Slow Test: run all (unit and integration) tests, pylint and mypy
```The integration tests are executed using an excellent
[clitest](https://github.com/aureliojargas/clitest) tool.## Future
`pyff` is a pre-1.0.0 version: basically a toy project of mine. A brief list of
TODOs for me to consider doing a 1.0.0 version is in [#19](#19). My idea is to
bring `pyff` to a small GitHub PR-commenting bot that would comment PRs to
Python repositories with a nice, human-readable summary of changes.