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.
20 # We use preview style for formatting Black itself. If you
21 # want stable formatting across releases, you should keep
25 # Build system information and other project-specific configuration below.
26 # NOTE: You don't need this in your own Black configuration.
29 requires = ["hatchling>=1.8.0", "hatch-vcs", "hatch-fancy-pypi-readme"]
30 build-backend = "hatchling.build"
34 description = "The uncompromising code formatter."
36 requires-python = ">=3.7"
38 { name = "Łukasz Langa", email = "lukasz@langa.pl" },
50 "Development Status :: 5 - Production/Stable",
51 "Environment :: Console",
52 "Intended Audience :: Developers",
53 "License :: OSI Approved :: MIT License",
54 "Operating System :: OS Independent",
55 "Programming Language :: Python",
56 "Programming Language :: Python :: 3 :: Only",
57 "Programming Language :: Python :: 3.7",
58 "Programming Language :: Python :: 3.8",
59 "Programming Language :: Python :: 3.9",
60 "Programming Language :: Python :: 3.10",
61 "Topic :: Software Development :: Libraries :: Python Modules",
62 "Topic :: Software Development :: Quality Assurance",
66 "mypy_extensions>=0.4.3",
69 "tomli>=1.1.0; python_full_version < '3.11.0a7'",
70 "typed-ast>=1.4.2; python_version < '3.8' and implementation_name == 'cpython'",
71 "typing_extensions>=3.10.0.0; python_version < '3.10'",
73 dynamic = ["readme", "version"]
75 [project.optional-dependencies]
76 colorama = ["colorama>=0.4.3"]
77 uvloop = ["uvloop>=0.15.2"]
87 black = "black:patched_main"
88 blackd = "blackd:patched_main [d]"
91 Changelog = "https://github.com/psf/black/blob/main/CHANGES.md"
92 Homepage = "https://github.com/psf/black"
94 [tool.hatch.metadata.hooks.fancy-pypi-readme]
95 content-type = "text/markdown"
97 { path = "README.md" },
98 { path = "CHANGES.md" },
104 [tool.hatch.build.hooks.vcs]
105 version-file = "src/_black_version.py"
107 version = "{version}"
110 [tool.hatch.build.targets.sdist]
111 exclude = ["/profiling"]
113 [tool.hatch.build.targets.wheel]
114 only-include = ["src"]
117 [tool.hatch.build.targets.wheel.hooks.mypyc]
118 enable-by-default = false
120 "hatch-mypyc>=0.13.0",
122 # Required stubs to be removed when the packages support PEP 561 themselves
123 "types-typed-ast>=1.4.2",
125 require-runtime-dependencies = true
127 # There's no good reason for blackd to be compiled.
129 # Not performance sensitive, so save bytes + compilation time:
130 "/src/blib2to3/__init__.py",
131 "/src/blib2to3/pgen2/__init__.py",
132 "/src/black/output.py",
133 "/src/black/concurrency.py",
134 "/src/black/files.py",
135 "/src/black/report.py",
136 # Breaks the test suite when compiled (and is also useless):
137 "/src/black/debug.py",
138 # Compiled modules can't be run directly and that's a problem here:
139 "/src/black/__main__.py",
141 options = { debug_level = "0" }
145 # So these are the environments we target:
146 # - Python: CPython 3.7+ only
147 # - Architecture (64-bit only): amd64 / x86_64, universal2, and arm64
148 # - OS: Linux (no musl), Windows, and macOS
150 skip = ["*-manylinux_i686", "*-musllinux_*", "*-win32", "pp-*"]
151 # This is the bare minimum needed to run the test suite. Pulling in the full
152 # test_requirements.txt would download a bunch of other packages not necessary
153 # here and would slow down the testing step a fair bit.
154 test-requires = ["pytest>=6.1.1"]
155 test-command = 'pytest {project} -k "not incompatible_with_mypyc"'
156 test-extras = ["d"," jupyter"]
157 # Skip trying to test arm64 builds on Intel Macs. (so cross-compilation doesn't
159 test-skip = ["*-macosx_arm64", "*-macosx_universal2:arm64"]
161 [tool.cibuildwheel.environment]
162 HATCH_BUILD_HOOKS_ENABLE = "1"
163 MYPYC_OPT_LEVEL = "3"
164 MYPYC_DEBUG_LEVEL = "0"
165 # The dependencies required to build wheels with mypyc aren't specified in
166 # [build-system].requires so we'll have to manage the build environment ourselves.
167 PIP_NO_BUILD_ISOLATION = "no"
168 # CPython 3.11 wheels aren't available for aiohttp and building a Cython extension
169 # from source also doesn't work.
170 AIOHTTP_NO_EXTENSIONS = "1"
172 [tool.cibuildwheel.linux]
174 "yum install -y clang gcc",
177 [tool.cibuildwheel.linux.environment]
178 HATCH_BUILD_HOOKS_ENABLE = "1"
179 MYPYC_OPT_LEVEL = "3"
180 MYPYC_DEBUG_LEVEL = "0"
181 # Black needs Clang to compile successfully on Linux.
183 AIOHTTP_NO_EXTENSIONS = "1"
189 skip_gitignore = true
190 skip_glob = ["src/blib2to3", "tests/data", "profiling"]
191 known_first_party = ["black", "blib2to3", "blackd", "_black_version"]
193 [tool.pytest.ini_options]
194 # Option below requires `tests/optional.py`
195 addopts = "--strict-config --strict-markers"
197 "no_blackd: run when `d` extra NOT installed",
198 "no_jupyter: run when `jupyter` extra NOT installed",
201 "incompatible_with_mypyc: run when testing mypyc compiled black"
206 # this is mitigated by a try/catch in https://github.com/psf/black/pull/2974/
207 # this ignore can be removed when support for aiohttp 3.7 is dropped.
208 '''ignore:Decorator `@unittest_run_loop` is no longer needed in aiohttp 3\.8\+:DeprecationWarning''',
209 # this is mitigated by a try/catch in https://github.com/psf/black/pull/3198/
210 # this ignore can be removed when support for aiohttp 3.x is dropped.
211 '''ignore:Middleware decorator is deprecated since 4\.0 and its behaviour is default, you can simply remove this decorator:DeprecationWarning''',
212 # this is mitigated by https://github.com/python/cpython/issues/79071 in python 3.8+
213 # this ignore can be removed when support for 3.7 is dropped.
214 '''ignore:Bare functions are deprecated, use async ones:DeprecationWarning''',
215 # aiohttp is using deprecated cgi modules - Safe to remove when fixed:
216 # https://github.com/aio-libs/aiohttp/issues/6905
217 '''ignore:'cgi' is deprecated and slated for removal in Python 3.13:DeprecationWarning''',