All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@git.madduck.net.
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
1 # Example configuration for Black.
3 # NOTE: you have to use single-quoted strings in TOML for regular expressions.
4 # It's the equivalent of r-strings in Python. Multiline strings are treated as
5 # verbose regular expressions by Black. Use [ ] to denote a significant space
10 target-version = ['py37', 'py38']
14 # The following are specific to Black, you probably don't want those.
19 # We use preview style for formatting Black itself. If you
20 # want stable formatting across releases, you should keep
24 # Build system information and other project-specific configuration below.
25 # NOTE: You don't need this in your own Black configuration.
28 requires = ["hatchling>=1.8.0", "hatch-vcs", "hatch-fancy-pypi-readme"]
29 build-backend = "hatchling.build"
33 description = "The uncompromising code formatter."
34 license = { text = "MIT" }
35 requires-python = ">=3.8"
37 { name = "Łukasz Langa", email = "lukasz@langa.pl" },
49 "Development Status :: 5 - Production/Stable",
50 "Environment :: Console",
51 "Intended Audience :: Developers",
52 "License :: OSI Approved :: MIT License",
53 "Operating System :: OS Independent",
54 "Programming Language :: Python",
55 "Programming Language :: Python :: 3 :: Only",
56 "Programming Language :: Python :: 3.8",
57 "Programming Language :: Python :: 3.9",
58 "Programming Language :: Python :: 3.10",
59 "Programming Language :: Python :: 3.11",
60 "Topic :: Software Development :: Libraries :: Python Modules",
61 "Topic :: Software Development :: Quality Assurance",
65 "mypy_extensions>=0.4.3",
69 "tomli>=1.1.0; python_version < '3.11'",
70 "typing_extensions>=4.0.1; python_version < '3.11'",
72 dynamic = ["readme", "version"]
74 [project.optional-dependencies]
75 colorama = ["colorama>=0.4.3"]
76 uvloop = ["uvloop>=0.15.2"]
86 black = "black:patched_main"
87 blackd = "blackd:patched_main [d]"
90 Changelog = "https://github.com/psf/black/blob/main/CHANGES.md"
91 Homepage = "https://github.com/psf/black"
93 [tool.hatch.metadata.hooks.fancy-pypi-readme]
94 content-type = "text/markdown"
96 { path = "README.md" },
97 { path = "CHANGES.md" },
103 [tool.hatch.build.hooks.vcs]
104 version-file = "src/_black_version.py"
106 version = "{version}"
109 [tool.hatch.build.targets.sdist]
110 exclude = ["/profiling"]
112 [tool.hatch.build.targets.wheel]
113 only-include = ["src"]
116 [tool.hatch.build.targets.wheel.hooks.mypyc]
117 enable-by-default = false
119 "hatch-mypyc>=0.16.0",
121 "click==8.1.3", # avoid https://github.com/pallets/click/issues/2558
123 require-runtime-dependencies = true
125 # There's no good reason for blackd to be compiled.
127 # Not performance sensitive, so save bytes + compilation time:
128 "/src/blib2to3/__init__.py",
129 "/src/blib2to3/pgen2/__init__.py",
130 "/src/black/output.py",
131 "/src/black/concurrency.py",
132 "/src/black/files.py",
133 "/src/black/report.py",
134 # Breaks the test suite when compiled (and is also useless):
135 "/src/black/debug.py",
136 # Compiled modules can't be run directly and that's a problem here:
137 "/src/black/__main__.py",
139 options = { debug_level = "0" }
143 # So these are the environments we target:
144 # - Python: CPython 3.8+ only
145 # - Architecture (64-bit only): amd64 / x86_64, universal2, and arm64
146 # - OS: Linux (no musl), Windows, and macOS
148 skip = ["*-manylinux_i686", "*-musllinux_*", "*-win32", "pp-*"]
149 # This is the bare minimum needed to run the test suite. Pulling in the full
150 # test_requirements.txt would download a bunch of other packages not necessary
151 # here and would slow down the testing step a fair bit.
152 test-requires = ["pytest>=6.1.1"]
153 test-command = 'pytest {project} -k "not incompatible_with_mypyc"'
154 test-extras = ["d"," jupyter"]
155 # Skip trying to test arm64 builds on Intel Macs. (so cross-compilation doesn't
157 test-skip = ["*-macosx_arm64", "*-macosx_universal2:arm64"]
159 [tool.cibuildwheel.environment]
160 HATCH_BUILD_HOOKS_ENABLE = "1"
161 MYPYC_OPT_LEVEL = "3"
162 MYPYC_DEBUG_LEVEL = "0"
163 # CPython 3.11 wheels aren't available for aiohttp and building a Cython extension
164 # from source also doesn't work.
165 AIOHTTP_NO_EXTENSIONS = "1"
167 [tool.cibuildwheel.linux]
169 "yum install -y clang gcc",
172 [tool.cibuildwheel.linux.environment]
173 HATCH_BUILD_HOOKS_ENABLE = "1"
174 MYPYC_OPT_LEVEL = "3"
175 MYPYC_DEBUG_LEVEL = "0"
176 # Black needs Clang to compile successfully on Linux.
178 AIOHTTP_NO_EXTENSIONS = "1"
184 skip_gitignore = true
185 skip_glob = ["tests/data", "profiling"]
186 known_first_party = ["black", "blib2to3", "blackd", "_black_version"]
188 [tool.pytest.ini_options]
189 # Option below requires `tests/optional.py`
190 addopts = "--strict-config --strict-markers"
192 "no_blackd: run when `d` extra NOT installed",
193 "no_jupyter: run when `jupyter` extra NOT installed",
196 "incompatible_with_mypyc: run when testing mypyc compiled black"
201 # this is mitigated by a try/catch in https://github.com/psf/black/pull/2974/
202 # this ignore can be removed when support for aiohttp 3.7 is dropped.
203 '''ignore:Decorator `@unittest_run_loop` is no longer needed in aiohttp 3\.8\+:DeprecationWarning''',
204 # this is mitigated by a try/catch in https://github.com/psf/black/pull/3198/
205 # this ignore can be removed when support for aiohttp 3.x is dropped.
206 '''ignore:Middleware decorator is deprecated since 4\.0 and its behaviour is default, you can simply remove this decorator:DeprecationWarning''',
207 # aiohttp is using deprecated cgi modules - Safe to remove when fixed:
208 # https://github.com/aio-libs/aiohttp/issues/6905
209 '''ignore:'cgi' is deprecated and slated for removal in Python 3.13:DeprecationWarning''',
210 # Work around https://github.com/pytest-dev/pytest/issues/10977 for Python 3.12
211 '''ignore:(Attribute s|Attribute n|ast.Str|ast.Bytes|ast.NameConstant|ast.Num) is deprecated and will be removed in Python 3.14:DeprecationWarning'''