Skip to main content

Safe, atomic formatting with black and µsort

Project description

µfmt

Safe, atomic formatting with black and µsort

version documentation changelog license

µfmt is a safe, atomic code formatter for Python built on top of black and µsort:

Black makes code review faster by producing the smallest diffs possible. Blackened code looks the same regardless of the project you’re reading.

μsort is a safe, minimal import sorter. Its primary goal is to make no “dangerous” changes to code, and to make no changes on code style.

µfmt formats files in-memory, first with µsort and then with black, before writing any changes back to disk. This enables a combined, atomic step in CI/CD workflows for checking or formatting files, without any chance of conflict or intermediate changes between the import sorter and the code formatter.

Install

µfmt requires Python 3.6 or newer. You can install it from PyPI:

$ pip install ufmt

If you want to prevent unexpected formatting changes that can break your CI workflow, make sure to pin your transitive dependencies–including black, µsort, and µfmt–to your preferred versions.

If you use requirements.txt, this might look like:

black==22.3.0
ufmt==1.3.2
usort==1.0.2

Usage

To format one or more files or directories in place:

$ ufmt format <path> [<path> ...]

To validate files are formatted correctly, like for CI workflows:

$ ufmt check <path> [<path> ...]

To validate formatting and generate a diff of necessary changes:

$ ufmt diff <path> [<path> ...]

pre-commit hook

µfmt provides a pre-commit hook. To format your diff before every commit, add the following to your .pre-commit-config.yaml file:

  - repo: https://github.com/omnilib/ufmt
    rev: v1.3.2
    hooks:
      - id: ufmt

You can change the rev to any version >= 1.3.0. To pin black and usort, use the additional_dependencies option:

    hooks: 
      - id: ufmt 
        additional_dependencies: 
          - black == 22.3.0
          - usort == 1.0.2

License

µfmt is copyright John Reese, and licensed under the MIT license. I am providing code in this repository to you under an open source license. This is my personal repository; the license you receive to my code is from me and not from my employer. See the LICENSE file for details.

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

ufmt-2.0.0a4.tar.gz (64.8 kB view details)

Uploaded Source

Built Distribution

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

ufmt-2.0.0a4-py3-none-any.whl (19.0 kB view details)

Uploaded Python 3

File details

Details for the file ufmt-2.0.0a4.tar.gz.

File metadata

  • Download URL: ufmt-2.0.0a4.tar.gz
  • Upload date:
  • Size: 64.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.27.1

File hashes

Hashes for ufmt-2.0.0a4.tar.gz
Algorithm Hash digest
SHA256 57a63fd57683c3d6023d6bcea87f2c28123f2e886c4045d2dfb7e10ce6915abb
MD5 c1436ca94e953d9e623083d2aa2cefc2
BLAKE2b-256 55a6b62df5de6de2537b7f68fcb66dd3ea4c1939e2ad559e5f56c1c5767e16e1

See more details on using hashes here.

File details

Details for the file ufmt-2.0.0a4-py3-none-any.whl.

File metadata

  • Download URL: ufmt-2.0.0a4-py3-none-any.whl
  • Upload date:
  • Size: 19.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.27.1

File hashes

Hashes for ufmt-2.0.0a4-py3-none-any.whl
Algorithm Hash digest
SHA256 5dc2bd14529ec7ec7e83e1df22d5b1897cdb61809c1be4225930867554faeea4
MD5 4b64045bba2938896e65f85f9c6b3b5c
BLAKE2b-256 1535bde4923e684655bff1fb0f134304f0284a69c9fb90a3e38765769f66a33e

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