Skip to main content

Pyink is a python formatter, forked from Black with slightly different behavior.

Project description

Pyink, pronounced pī-ˈiŋk, is a Python formatter, forked from Black with a few different formatting behaviors. We intend to keep rebasing on top of Black's latest changes.

Why Pyink?

We would love to adopt Black, but adopting it overnight is too disruptive to the thousands of developers working in our monorepo. We also have other Python tooling that assumes certain formatting, it would be a too big task to update them all at once. We decided to maintain a few local patches to Black as a medium-term solution, and release them as a separate tool called Pyink.

Pyink is intended to be an adoption helper, and we wish to remove as many patches as possible in the future.

What are the main differences?

  • Support only formatting selected line ranges, using the --pyink-lines= argument (see psf/black#830).

  • Support two-space indentation, using the pyink-indentation option.

  • Support inferring preferred quote style by calculating the majority in a file, using the pyink-use-majority-quotes option.

  • Do not wrap trailing pragma comments if the line exceeds the length only because of the pragma (see psf/black#2843). Example

    # Pyink:
    result = some_other_module._private_function(arg="value")  # pylint: disable=protected-access
    
    # Black:
    result = some_other_module._private_function(
        arg="value"
    )  # pylint: disable=protected-access
    
  • Do not wrap imports in parentheses and move them to separate lines (see psf/black#3324). Example:

    # Pyink:
    from very_long_top_level_package_name.sub_package.another_level import a_long_module
    
    # Black:
    from very_long_top_level_package_name.sub_package.another_level import (
        a_long_module,
    )
    
  • Prefer not breaking lines between immediately nested brackets (see psf/black#1811). Example:

    # Pyink:
    secrets = frozenset({
        1001,
        1002,
        1003,
        1004,
        1005,
        1006,
        1007,
        1008,
        1009,
    })
    
    # Black:
    secrets = frozenset(
        {
            1001,
            1002,
            1003,
            1004,
            1005,
            1006,
            1007,
            1008,
            1009,
        }
    )
    
  • Add an empty line between class statements without docstrings, and the first method. We expect we will simply remove this difference from Pyink at some point. Example:

    # Pyink:
    class MyTest(unittest.TestCase):
    
        def test_magic(self):
            ...
    
    # Black:
    class MyTest(unittest.TestCase):
        def test_magic(self):
            ...
    
  • Module docstrings are formatted same as other docstrings (see psf/black#3493).

  • Temporarily disabled the following Black future style changes:

Historical differences

These are differences that existed in the past. We have upstreamed them to Black so they are now identical.

  • Wrap concatenated strings in parens for function arguments (see psf/black#3292). Example:

    # New:
    function_call(
        (
            " lorem ipsum dolor sit amet consectetur adipiscing elit sed do eiusmod tempor"
            " incididunt ut labore et dolore magna aliqua Ut enim ad minim"
        ),
        " veniam quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo",
    )
    
    # Old:
    function_call(
        " lorem ipsum dolor sit amet consectetur adipiscing elit sed do eiusmod tempor"
        " incididunt ut labore et dolore magna aliqua Ut enim ad minim",
        " veniam quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo",
    )
    
  • Prefer splitting right hand side of assignment statements (see psf/black#1498). Example:

    # New:
    some_dictionary["some_key"] = (
        some_long_expression_causing_long_line
    )
    
    # Old:
    some_dictionary[
        "some_key"
    ] = some_long_expression_causing_long_line
    

How do I use Pyink?

Same as black, except you'll use pyink. All black command line options are supported by pyink. To configure the options in the pyproject.toml file, you need to put them in the [tool.pyink] section instead of [tool.black].

There are also a few Pyink only options:

  --pyink / --no-pyink            Enable the Pyink formatting mode. Disabling
                                  it should behave the same as Black.
                                  [default: pyink]
  --pyink-indentation [2|4]       The number of spaces used for indentation.
                                  [default: 4]
  --pyink-lines START-END         Range of lines to format. Must be specified
                                  as "START-END", index is 1-based and
                                  inclusive on both ends.
  --pyink-use-majority-quotes     When normalizing string quotes, infer
                                  preferred quote style by calculating the
                                  majority in the file. Multi-line strings and
                                  docstrings are excluded from this as they
                                  always use double quotes.

Is there a VS Code extension for Pyink?

No, but with a bit workaround, you can use the Black Formatter extension. After installing Pyink and the extension, you can set these in VS Code's settings.json:

{
    "[python]": {
        "editor.defaultFormatter": "ms-python.black-formatter"
    },
    "black-formatter.path": [
        "path/to/pyink"
    ]
}

Why the name?

We want a name with the same number of characters as Black, to make patching easier. And squid ink is black.

License

MIT

Contributing

See the contribution guide.

Changelog

See CHANGES.md.

Disclaimer

This is not an officially supported Google product.

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

pyink-23.1.1.tar.gz (213.9 kB view details)

Uploaded Source

Built Distribution

pyink-23.1.1-py3-none-any.whl (112.5 kB view details)

Uploaded Python 3

File details

Details for the file pyink-23.1.1.tar.gz.

File metadata

  • Download URL: pyink-23.1.1.tar.gz
  • Upload date:
  • Size: 213.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for pyink-23.1.1.tar.gz
Algorithm Hash digest
SHA256 b1020226e46bde48dc13dcda5e3b4b7da7f8265ebffcd84de73053146aac1f98
MD5 6de0f3851570db47f40aca22af9a9b12
BLAKE2b-256 eb143cf3d3c62f67a4867d554fff475be90693cf3c15aafcabee9ff6caa2882a

See more details on using hashes here.

Provenance

File details

Details for the file pyink-23.1.1-py3-none-any.whl.

File metadata

  • Download URL: pyink-23.1.1-py3-none-any.whl
  • Upload date:
  • Size: 112.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.2

File hashes

Hashes for pyink-23.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b0d157280e6de42530247e60892a75e76f9ec2bfdc95dd3c56e6245a54d7d2a5
MD5 9db77ffa269fa40a060512a1e021e010
BLAKE2b-256 eea43b4212de2a42d7ca141c9b49405380a904537afa6235f65953792651d1de

See more details on using hashes here.

Provenance

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page