Less uncompromising Python code formatter
Project description
gray
Less uncompromising Python code formatter.
Gray stands on the shoulders of giants:
- isort - imports sorting and more
- pyupgrade - automatically upgrades syntax for newer versions of Python
- autoflake - remove unused imports and variables
- add-trailing-comma
- trim - remove trailing whitespaces
- unify - unify quotes style
- fixit - various code formatters on LibCST
Usage
usage:
gray myapp.py
gray myproj/ tests/
gray --log-level debug --formatters isort,unify ~/app
Less uncompromising Python code formatter.
positional arguments:
paths Paths to format (default: (PosixPath('.'),))
optional arguments:
-h, --help show this help message and exit
--pool-size POOL_SIZE
process pool size (default: 8)
--do-not-detect-venv Don't try to detect virtualenv (default: False)
Logging options:
--log-level {debug,info,warning,error,fatal}
--log-format {stream,color,json,syslog}
Formatters options:
-f FORMATTERS, --formatters FORMATTERS
Enabled formatters separated by comma (default: add-
trailing-comma,autoflake,fixit,isort,pyupgrade,trim,unify)
--min-python-version MIN_PYTHON_VERSION
Minimum python version to support (default: (3, 9))
pyupgrade options:
--pyupgrade-keep-percent-format PYUPGRADE_KEEP_PERCENT_FORMAT
Do not upgrade percent formatted strings to f-strings
(default: False)
unify options:
--unify-quote UNIFY_QUOTE
preferred quote (default: ")
isort options:
--isort-line-length ISORT_LINE_LENGTH
isort section (default: 80)
--isort-virtual-env ISORT_VIRTUAL_ENV
virtual env path (default:
/Users/dizballanze/apps/gray/env)
--isort-include-trailing-comma ISORT_INCLUDE_TRAILING_COMMA
include a trailing comma on multi line imports
(default: 1)
--isort-lines-after-imports ISORT_LINES_AFTER_IMPORTS
empty lines after imports (default: 2)
autoflake options:
--autoflake-ignore-init-module-imports AUTOFLAKE_IGNORE_INIT_MODULE_IMPORTS
--autoflake-expand-star-imports AUTOFLAKE_EXPAND_STAR_IMPORTS
--autoflake-remove-all-unused-imports AUTOFLAKE_REMOVE_ALL_UNUSED_IMPORTS
--autoflake-remove-duplicate-keys AUTOFLAKE_REMOVE_DUPLICATE_KEYS
--autoflake-remove-unused-variables AUTOFLAKE_REMOVE_UNUSED_VARIABLES
trim options:
--trim-leading-newlines TRIM_LEADING_NEWLINES
fixit options:
--fixit-redundant-fstrings FIXIT_REDUNDANT_FSTRINGS
--fixit-redundant-lambdas FIXIT_REDUNDANT_LAMBDAS
--fixit-redundant-list-comprehensions FIXIT_REDUNDANT_LIST_COMPREHENSIONS
--fixit-to-comprehensions FIXIT_TO_COMPREHENSIONS
--fixit-to-literals FIXIT_TO_LITERALS
--fixit-to-fstrings FIXIT_TO_FSTRINGS
Args that start with '--' (eg. --pool-size) can also be set in a config file
(/Users/apple/.gray or /etc/gray.conf or ./gray.conf). Config file syntax
allows: key=value, flag=true, stuff=[a,b,c] (for details, see syntax at
https://goo.gl/R74nmi). If an arg is specified in more than one place, then
commandline values override config file values which override defaults.
Git Hook
You can setup gray formatting before each commit with pre-commit git hook.
Add following file to .git/hooks/pre-commit
and make it executable with
chmod +x .git/hooks/pre-commit
.
#!/usr/bin/env python
from gray.hooks import git_pre_commit
exit(git_pre_commit(stop_on_modify=True))
If stop_on_modify
argument is True
, hook will prevent commit if there are
any unstaged changes in files you about to commit.
Otherwise, any unstaged changes in this files will be added to the index by the hook.
Config file
Gray is looking for config file in ./gray.conf
, /etc/gray.conf
or ~/.gray
.
Example of grayconf:
formatters = add-trailing-comma,isort,unify
min-python-version = 3.5
Features
- TODO
Git pre-commit hook
Use pre-commit. Once you
have it installed, add this to the
.pre-commit-config.yaml
in your repository:
repos:
- repo: https://github.com/dizballanze/gray
rev: master # Replace by any tag/branch: https://github.com/dizballanze/gray/tags
hooks:
- id: gray
and run pre-commit install
.
Using with Sourcetree
Sourcetree may run without gray
being available via PATH
.
MacOS
Make sure gray
is available via PATH
and run open /Applications/Sourcetree.app
.
Or better create an Automator
workflow
with source ~/.bash_profile && open /Applications/Sourcetree.app
script.
History
0.7.0
- pre-commit support (by @tzoiker)
0.6.2
- isort: keep line breaks before local imports
0.6.1
- Fix isort imports grouping
0.6.0
- Bump isort to 5.4.2
- Use parentheses in multiline imports
0.5.0
- Add autoflake formatter
- Add trim formatter
0.4.0
- Minimum python version option
- Pyupgrade options
- Detecting and skipping virtualenv
0.3.0
- Multiprocessing support (by @mosquito)
0.2.0
- Pre-commit hook
- Some formating options
0.1.0 (2020-04-06)
- First release on PyPI.
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 gray-0.8.1.tar.gz
.
File metadata
- Download URL: gray-0.8.1.tar.gz
- Upload date:
- Size: 15.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cd3d5d747a6abde579d5ffe344141b00c83896f0807cb30401a7f97e56c48d73 |
|
MD5 | 81035f5bacf54387cf96fec91c8b7d75 |
|
BLAKE2b-256 | aa094b9a24e500b6a27d13d5bcb7e75d6a096eb348b7fdf85585cf9b58cf0185 |
File details
Details for the file gray-0.8.1-py2.py3-none-any.whl
.
File metadata
- Download URL: gray-0.8.1-py2.py3-none-any.whl
- Upload date:
- Size: 16.4 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.10.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 300fecbe4732da1dadba1ec610c61b0c327475d20b47b0543a7eedec9a1a5c7d |
|
MD5 | cea3fd0e0098e500554302ddb7cb7d49 |
|
BLAKE2b-256 | ae5521c3a73303f8063eaf9cbafa9ffd0ade88431385511ac3a69d759bbb55d0 |