]> git.madduck.net Git - etc/vim.git/blob - CHANGES.md

madduck's git repository

Every one of the projects in this repository is available at the canonical URL git://git.madduck.net/madduck/pub/<projectpath> — see each project's metadata for the exact URL.

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.

SSH access, as well as push access can be individually arranged.

If you use my repositories frequently, consider adding the following snippet to ~/.gitconfig and using the third clone URL listed for each project:

[url "git://git.madduck.net/madduck/"]
  insteadOf = madduck:

tell users to use -t py310 (#2668)
[etc/vim.git] / CHANGES.md
1 # Change Log
2
3 ## Unreleased
4
5 ### _Black_
6
7 - Point users to using `--target-version py310` if we detect 3.10-only syntax (#2668)
8 - Cell magics are now only processed if they are known Python cell magics. Earlier, all
9   cell magics were tokenized, leading to possible indentation errors e.g. with
10   `%%writefile`. (#2630)
11 - Fix Python 3.10 support on platforms without ProcessPoolExecutor (#2631)
12 - Remove dependency on `regex` (#2644) (#2663)
13 - Fix `match` statements with open sequence subjects, like `match a, b:` or
14   `match a, *b:` (#2639) (#2659)
15 - Fix `match`/`case` statements that contain `match`/`case` soft keywords multiple
16   times, like `match re.match()` (#2661)
17 - Fix `case` statements with an inline body (#2665)
18 - Fix styling of starred expressions inside `match` subject (#2667)
19 - Fix assignment to environment variables in Jupyter Notebooks (#2642)
20 - Add `flake8-simplify` and `flake8-comprehensions` plugins (#2653)
21 - Fix determination of f-string expression spans (#2654)
22 - Fix parser error location on invalid syntax in a `match` statement (#2649)
23 - Fix bad formatting of error messages about EOF in multi-line statements (#2343)
24 - Functions and classes in blocks now have more consistent surrounding spacing (#2472)
25
26 ## 21.11b1
27
28 ### _Black_
29
30 - Bumped regex version minimum to 2021.4.4 to fix Pattern class usage (#2621)
31
32 ## 21.11b0
33
34 ### _Black_
35
36 - Warn about Python 2 deprecation in more cases by improving Python 2 only syntax
37   detection (#2592)
38 - Add experimental PyPy support (#2559)
39 - Add partial support for the match statement. As it's experimental, it's only enabled
40   when `--target-version py310` is explicitly specified (#2586)
41 - Add support for parenthesized with (#2586)
42 - Declare support for Python 3.10 for running Black (#2562)
43
44 ### Integrations
45
46 - Fixed vim plugin with Python 3.10 by removing deprecated distutils import (#2610)
47 - The vim plugin now parses `skip_magic_trailing_comma` from pyproject.toml (#2613)
48
49 ## 21.10b0
50
51 ### _Black_
52
53 - Document stability policy, that will apply for non-beta releases (#2529)
54 - Add new `--workers` parameter (#2514)
55 - Fixed feature detection for positional-only arguments in lambdas (#2532)
56 - Bumped typed-ast version minimum to 1.4.3 for 3.10 compatibility (#2519)
57 - Fixed a Python 3.10 compatibility issue where the loop argument was still being passed
58   even though it has been removed (#2580)
59 - Deprecate Python 2 formatting support (#2523)
60
61 ### _Blackd_
62
63 - Remove dependency on aiohttp-cors (#2500)
64 - Bump required aiohttp version to 3.7.4 (#2509)
65
66 ### _Black-Primer_
67
68 - Add primer support for --projects (#2555)
69 - Print primer summary after individual failures (#2570)
70
71 ### Integrations
72
73 - Allow to pass `target_version` in the vim plugin (#1319)
74 - Install build tools in docker file and use multi-stage build to keep the image size
75   down (#2582)
76
77 ## 21.9b0
78
79 ### Packaging
80
81 - Fix missing modules in self-contained binaries (#2466)
82 - Fix missing toml extra used during installation (#2475)
83
84 ## 21.8b0
85
86 ### _Black_
87
88 - Add support for formatting Jupyter Notebook files (#2357)
89 - Move from `appdirs` dependency to `platformdirs` (#2375)
90 - Present a more user-friendly error if .gitignore is invalid (#2414)
91 - The failsafe for accidentally added backslashes in f-string expressions has been
92   hardened to handle more edge cases during quote normalization (#2437)
93 - Avoid changing a function return type annotation's type to a tuple by adding a
94   trailing comma (#2384)
95 - Parsing support has been added for unparenthesized walruses in set literals, set
96   comprehensions, and indices (#2447).
97 - Pin `setuptools-scm` build-time dependency version (#2457)
98 - Exclude typing-extensions version 3.10.0.1 due to it being broken on Python 3.10
99   (#2460)
100
101 ### _Blackd_
102
103 - Replace sys.exit(-1) with raise ImportError as it plays more nicely with tools that
104   scan installed packages (#2440)
105
106 ### Integrations
107
108 - The provided pre-commit hooks no longer specify `language_version` to avoid overriding
109   `default_language_version` (#2430)
110
111 ## 21.7b0
112
113 ### _Black_
114
115 - Configuration files using TOML features higher than spec v0.5.0 are now supported
116   (#2301)
117 - Add primer support and test for code piped into black via STDIN (#2315)
118 - Fix internal error when `FORCE_OPTIONAL_PARENTHESES` feature is enabled (#2332)
119 - Accept empty stdin (#2346)
120 - Provide a more useful error when parsing fails during AST safety checks (#2304)
121
122 ### Docker
123
124 - Add new `latest_release` tag automation to follow latest black release on docker
125   images (#2374)
126
127 ### Integrations
128
129 - The vim plugin now searches upwards from the directory containing the current buffer
130   instead of the current working directory for pyproject.toml. (#1871)
131 - The vim plugin now reads the correct string normalization option in pyproject.toml
132   (#1869)
133 - The vim plugin no longer crashes Black when there's boolean values in pyproject.toml
134   (#1869)
135
136 ## 21.6b0
137
138 ### _Black_
139
140 - Fix failure caused by `fmt: skip` and indentation (#2281)
141 - Account for += assignment when deciding whether to split string (#2312)
142 - Correct max string length calculation when there are string operators (#2292)
143 - Fixed option usage when using the `--code` flag (#2259)
144 - Do not call `uvloop.install()` when _Black_ is used as a library (#2303)
145 - Added `--required-version` option to require a specific version to be running (#2300)
146 - Fix incorrect custom breakpoint indices when string group contains fake f-strings
147   (#2311)
148 - Fix regression where `R` prefixes would be lowercased for docstrings (#2285)
149 - Fix handling of named escapes (`\N{...}`) when `--experimental-string-processing` is
150   used (#2319)
151
152 ### Integrations
153
154 - The official Black action now supports choosing what version to use, and supports the
155   major 3 OSes. (#1940)
156
157 ## 21.5b2
158
159 ### _Black_
160
161 - A space is no longer inserted into empty docstrings (#2249)
162 - Fix handling of .gitignore files containing non-ASCII characters on Windows (#2229)
163 - Respect `.gitignore` files in all levels, not only `root/.gitignore` file (apply
164   `.gitignore` rules like `git` does) (#2225)
165 - Restored compatibility with Click 8.0 on Python 3.6 when LANG=C used (#2227)
166 - Add extra uvloop install + import support if in python env (#2258)
167 - Fix --experimental-string-processing crash when matching parens are not found (#2283)
168 - Make sure to split lines that start with a string operator (#2286)
169 - Fix regular expression that black uses to identify f-expressions (#2287)
170
171 ### _Blackd_
172
173 - Add a lower bound for the `aiohttp-cors` dependency. Only 0.4.0 or higher is
174   supported. (#2231)
175
176 ### Packaging
177
178 - Release self-contained x86_64 MacOS binaries as part of the GitHub release pipeline
179   (#2198)
180 - Always build binaries with the latest available Python (#2260)
181
182 ### Documentation
183
184 - Add discussion of magic comments to FAQ page (#2272)
185 - `--experimental-string-processing` will be enabled by default in the future (#2273)
186 - Fix typos discovered by codespell (#2228)
187 - Fix Vim plugin installation instructions. (#2235)
188 - Add new Frequently Asked Questions page (#2247)
189 - Fix encoding + symlink issues preventing proper build on Windows (#2262)
190
191 ## 21.5b1
192
193 ### _Black_
194
195 - Refactor `src/black/__init__.py` into many files (#2206)
196
197 ### Documentation
198
199 - Replaced all remaining references to the
200   [`master`](https://github.com/psf/black/tree/main) branch with the
201   [`main`](https://github.com/psf/black/tree/main) branch. Some additional changes in
202   the source code were also made. (#2210)
203 - Sigificantly reorganized the documentation to make much more sense. Check them out by
204   heading over to [the stable docs on RTD](https://black.readthedocs.io/en/stable/).
205   (#2174)
206
207 ## 21.5b0
208
209 ### _Black_
210
211 - Set `--pyi` mode if `--stdin-filename` ends in `.pyi` (#2169)
212 - Stop detecting target version as Python 3.9+ with pre-PEP-614 decorators that are
213   being called but with no arguments (#2182)
214
215 ### _Black-Primer_
216
217 - Add `--no-diff` to black-primer to suppress formatting changes (#2187)
218
219 ## 21.4b2
220
221 ### _Black_
222
223 - Fix crash if the user configuration directory is inaccessible. (#2158)
224
225 - Clarify
226   [circumstances](https://github.com/psf/black/blob/master/docs/the_black_code_style.md#pragmatism)
227   in which _Black_ may change the AST (#2159)
228
229 - Allow `.gitignore` rules to be overridden by specifying `exclude` in `pyproject.toml`
230   or on the command line. (#2170)
231
232 ### _Packaging_
233
234 - Install `primer.json` (used by `black-primer` by default) with black. (#2154)
235
236 ## 21.4b1
237
238 ### _Black_
239
240 - Fix crash on docstrings ending with "\\ ". (#2142)
241
242 - Fix crash when atypical whitespace is cleaned out of dostrings (#2120)
243
244 - Reflect the `--skip-magic-trailing-comma` and `--experimental-string-processing` flags
245   in the name of the cache file. Without this fix, changes in these flags would not take
246   effect if the cache had already been populated. (#2131)
247
248 - Don't remove necessary parentheses from assignment expression containing assert /
249   return statements. (#2143)
250
251 ### _Packaging_
252
253 - Bump pathspec to >= 0.8.1 to solve invalid .gitignore exclusion handling
254
255 ## 21.4b0
256
257 ### _Black_
258
259 - Fixed a rare but annoying formatting instability created by the combination of
260   optional trailing commas inserted by `Black` and optional parentheses looking at
261   pre-existing "magic" trailing commas. This fixes issue #1629 and all of its many many
262   duplicates. (#2126)
263
264 - `Black` now processes one-line docstrings by stripping leading and trailing spaces,
265   and adding a padding space when needed to break up """". (#1740)
266
267 - `Black` now cleans up leading non-breaking spaces in comments (#2092)
268
269 - `Black` now respects `--skip-string-normalization` when normalizing multiline
270   docstring quotes (#1637)
271
272 - `Black` no longer removes all empty lines between non-function code and decorators
273   when formatting typing stubs. Now `Black` enforces a single empty line. (#1646)
274
275 - `Black` no longer adds an incorrect space after a parenthesized assignment expression
276   in if/while statements (#1655)
277
278 - Added `--skip-magic-trailing-comma` / `-C` to avoid using trailing commas as a reason
279   to split lines (#1824)
280
281 - fixed a crash when PWD=/ on POSIX (#1631)
282
283 - fixed "I/O operation on closed file" when using --diff (#1664)
284
285 - Prevent coloured diff output being interleaved with multiple files (#1673)
286
287 - Added support for PEP 614 relaxed decorator syntax on python 3.9 (#1711)
288
289 - Added parsing support for unparenthesized tuples and yield expressions in annotated
290   assignments (#1835)
291
292 - added `--extend-exclude` argument (PR #2005)
293
294 - speed up caching by avoiding pathlib (#1950)
295
296 - `--diff` correctly indicates when a file doesn't end in a newline (#1662)
297
298 - Added `--stdin-filename` argument to allow stdin to respect `--force-exclude` rules
299   (#1780)
300
301 - Lines ending with `fmt: skip` will now be not formatted (#1800)
302
303 - PR #2053: Black no longer relies on typed-ast for Python 3.8 and higher
304
305 - PR #2053: Python 2 support is now optional, install with
306   `python3 -m pip install black[python2]` to maintain support.
307
308 - Exclude `venv` directory by default (#1683)
309
310 - Fixed "Black produced code that is not equivalent to the source" when formatting
311   Python 2 docstrings (#2037)
312
313 ### _Packaging_
314
315 - Self-contained native _Black_ binaries are now provided for releases via GitHub
316   Releases (#1743)
317
318 ## 20.8b1
319
320 ### _Packaging_
321
322 - explicitly depend on Click 7.1.2 or newer as `Black` no longer works with versions
323   older than 7.0
324
325 ## 20.8b0
326
327 ### _Black_
328
329 - re-implemented support for explicit trailing commas: now it works consistently within
330   any bracket pair, including nested structures (#1288 and duplicates)
331
332 - `Black` now reindents docstrings when reindenting code around it (#1053)
333
334 - `Black` now shows colored diffs (#1266)
335
336 - `Black` is now packaged using 'py3' tagged wheels (#1388)
337
338 - `Black` now supports Python 3.8 code, e.g. star expressions in return statements
339   (#1121)
340
341 - `Black` no longer normalizes capital R-string prefixes as those have a
342   community-accepted meaning (#1244)
343
344 - `Black` now uses exit code 2 when specified configuration file doesn't exit (#1361)
345
346 - `Black` now works on AWS Lambda (#1141)
347
348 - added `--force-exclude` argument (#1032)
349
350 - removed deprecated `--py36` option (#1236)
351
352 - fixed `--diff` output when EOF is encountered (#526)
353
354 - fixed `# fmt: off` handling around decorators (#560)
355
356 - fixed unstable formatting with some `# type: ignore` comments (#1113)
357
358 - fixed invalid removal on organizing brackets followed by indexing (#1575)
359
360 - introduced `black-primer`, a CI tool that allows us to run regression tests against
361   existing open source users of Black (#1402)
362
363 - introduced property-based fuzzing to our test suite based on Hypothesis and
364   Hypothersmith (#1566)
365
366 - implemented experimental and disabled by default long string rewrapping (#1132),
367   hidden under a `--experimental-string-processing` flag while it's being worked on;
368   this is an undocumented and unsupported feature, you lose Internet points for
369   depending on it (#1609)
370
371 ### Vim plugin
372
373 - prefer virtualenv packages over global packages (#1383)
374
375 ## 19.10b0
376
377 - added support for PEP 572 assignment expressions (#711)
378
379 - added support for PEP 570 positional-only arguments (#943)
380
381 - added support for async generators (#593)
382
383 - added support for pre-splitting collections by putting an explicit trailing comma
384   inside (#826)
385
386 - added `black -c` as a way to format code passed from the command line (#761)
387
388 - --safe now works with Python 2 code (#840)
389
390 - fixed grammar selection for Python 2-specific code (#765)
391
392 - fixed feature detection for trailing commas in function definitions and call sites
393   (#763)
394
395 - `# fmt: off`/`# fmt: on` comment pairs placed multiple times within the same block of
396   code now behave correctly (#1005)
397
398 - _Black_ no longer crashes on Windows machines with more than 61 cores (#838)
399
400 - _Black_ no longer crashes on standalone comments prepended with a backslash (#767)
401
402 - _Black_ no longer crashes on `from` ... `import` blocks with comments (#829)
403
404 - _Black_ no longer crashes on Python 3.7 on some platform configurations (#494)
405
406 - _Black_ no longer fails on comments in from-imports (#671)
407
408 - _Black_ no longer fails when the file starts with a backslash (#922)
409
410 - _Black_ no longer merges regular comments with type comments (#1027)
411
412 - _Black_ no longer splits long lines that contain type comments (#997)
413
414 - removed unnecessary parentheses around `yield` expressions (#834)
415
416 - added parentheses around long tuples in unpacking assignments (#832)
417
418 - added parentheses around complex powers when they are prefixed by a unary operator
419   (#646)
420
421 - fixed bug that led _Black_ format some code with a line length target of 1 (#762)
422
423 - _Black_ no longer introduces quotes in f-string subexpressions on string boundaries
424   (#863)
425
426 - if _Black_ puts parenthesis around a single expression, it moves comments to the
427   wrapped expression instead of after the brackets (#872)
428
429 - `blackd` now returns the version of _Black_ in the response headers (#1013)
430
431 - `blackd` can now output the diff of formats on source code when the `X-Diff` header is
432   provided (#969)
433
434 ## 19.3b0
435
436 - new option `--target-version` to control which Python versions _Black_-formatted code
437   should target (#618)
438
439 - deprecated `--py36` (use `--target-version=py36` instead) (#724)
440
441 - _Black_ no longer normalizes numeric literals to include `_` separators (#696)
442
443 - long `del` statements are now split into multiple lines (#698)
444
445 - type comments are no longer mangled in function signatures
446
447 - improved performance of formatting deeply nested data structures (#509)
448
449 - _Black_ now properly formats multiple files in parallel on Windows (#632)
450
451 - _Black_ now creates cache files atomically which allows it to be used in parallel
452   pipelines (like `xargs -P8`) (#673)
453
454 - _Black_ now correctly indents comments in files that were previously formatted with
455   tabs (#262)
456
457 - `blackd` now supports CORS (#622)
458
459 ## 18.9b0
460
461 - numeric literals are now formatted by _Black_ (#452, #461, #464, #469):
462
463   - numeric literals are normalized to include `_` separators on Python 3.6+ code
464
465   - added `--skip-numeric-underscore-normalization` to disable the above behavior and
466     leave numeric underscores as they were in the input
467
468   - code with `_` in numeric literals is recognized as Python 3.6+
469
470   - most letters in numeric literals are lowercased (e.g., in `1e10`, `0x01`)
471
472   - hexadecimal digits are always uppercased (e.g. `0xBADC0DE`)
473
474 - added `blackd`, see
475   [its documentation](https://github.com/psf/black/blob/18.9b0/README.md#blackd) for
476   more info (#349)
477
478 - adjacent string literals are now correctly split into multiple lines (#463)
479
480 - trailing comma is now added to single imports that don't fit on a line (#250)
481
482 - cache is now populated when `--check` is successful for a file which speeds up
483   consecutive checks of properly formatted unmodified files (#448)
484
485 - whitespace at the beginning of the file is now removed (#399)
486
487 - fixed mangling [pweave](http://mpastell.com/pweave/) and
488   [Spyder IDE](https://www.spyder-ide.org/) special comments (#532)
489
490 - fixed unstable formatting when unpacking big tuples (#267)
491
492 - fixed parsing of `__future__` imports with renames (#389)
493
494 - fixed scope of `# fmt: off` when directly preceding `yield` and other nodes (#385)
495
496 - fixed formatting of lambda expressions with default arguments (#468)
497
498 - fixed `async for` statements: _Black_ no longer breaks them into separate lines (#372)
499
500 - note: the Vim plugin stopped registering `,=` as a default chord as it turned out to
501   be a bad idea (#415)
502
503 ## 18.6b4
504
505 - hotfix: don't freeze when multiple comments directly precede `# fmt: off` (#371)
506
507 ## 18.6b3
508
509 - typing stub files (`.pyi`) now have blank lines added after constants (#340)
510
511 - `# fmt: off` and `# fmt: on` are now much more dependable:
512
513   - they now work also within bracket pairs (#329)
514
515   - they now correctly work across function/class boundaries (#335)
516
517   - they now work when an indentation block starts with empty lines or misaligned
518     comments (#334)
519
520 - made Click not fail on invalid environments; note that Click is right but the
521   likelihood we'll need to access non-ASCII file paths when dealing with Python source
522   code is low (#277)
523
524 - fixed improper formatting of f-strings with quotes inside interpolated expressions
525   (#322)
526
527 - fixed unnecessary slowdown when long list literals where found in a file
528
529 - fixed unnecessary slowdown on AST nodes with very many siblings
530
531 - fixed cannibalizing backslashes during string normalization
532
533 - fixed a crash due to symbolic links pointing outside of the project directory (#338)
534
535 ## 18.6b2
536
537 - added `--config` (#65)
538
539 - added `-h` equivalent to `--help` (#316)
540
541 - fixed improper unmodified file caching when `-S` was used
542
543 - fixed extra space in string unpacking (#305)
544
545 - fixed formatting of empty triple quoted strings (#313)
546
547 - fixed unnecessary slowdown in comment placement calculation on lines without comments
548
549 ## 18.6b1
550
551 - hotfix: don't output human-facing information on stdout (#299)
552
553 - hotfix: don't output cake emoji on non-zero return code (#300)
554
555 ## 18.6b0
556
557 - added `--include` and `--exclude` (#270)
558
559 - added `--skip-string-normalization` (#118)
560
561 - added `--verbose` (#283)
562
563 - the header output in `--diff` now actually conforms to the unified diff spec
564
565 - fixed long trivial assignments being wrapped in unnecessary parentheses (#273)
566
567 - fixed unnecessary parentheses when a line contained multiline strings (#232)
568
569 - fixed stdin handling not working correctly if an old version of Click was used (#276)
570
571 - _Black_ now preserves line endings when formatting a file in place (#258)
572
573 ## 18.5b1
574
575 - added `--pyi` (#249)
576
577 - added `--py36` (#249)
578
579 - Python grammar pickle caches are stored with the formatting caches, making _Black_
580   work in environments where site-packages is not user-writable (#192)
581
582 - _Black_ now enforces a PEP 257 empty line after a class-level docstring (and/or
583   fields) and the first method
584
585 - fixed invalid code produced when standalone comments were present in a trailer that
586   was omitted from line splitting on a large expression (#237)
587
588 - fixed optional parentheses being removed within `# fmt: off` sections (#224)
589
590 - fixed invalid code produced when stars in very long imports were incorrectly wrapped
591   in optional parentheses (#234)
592
593 - fixed unstable formatting when inline comments were moved around in a trailer that was
594   omitted from line splitting on a large expression (#238)
595
596 - fixed extra empty line between a class declaration and the first method if no class
597   docstring or fields are present (#219)
598
599 - fixed extra empty line between a function signature and an inner function or inner
600   class (#196)
601
602 ## 18.5b0
603
604 - call chains are now formatted according to the
605   [fluent interfaces](https://en.wikipedia.org/wiki/Fluent_interface) style (#67)
606
607 - data structure literals (tuples, lists, dictionaries, and sets) are now also always
608   exploded like imports when they don't fit in a single line (#152)
609
610 - slices are now formatted according to PEP 8 (#178)
611
612 - parentheses are now also managed automatically on the right-hand side of assignments
613   and return statements (#140)
614
615 - math operators now use their respective priorities for delimiting multiline
616   expressions (#148)
617
618 - optional parentheses are now omitted on expressions that start or end with a bracket
619   and only contain a single operator (#177)
620
621 - empty parentheses in a class definition are now removed (#145, #180)
622
623 - string prefixes are now standardized to lowercase and `u` is removed on Python 3.6+
624   only code and Python 2.7+ code with the `unicode_literals` future import (#188, #198,
625   #199)
626
627 - typing stub files (`.pyi`) are now formatted in a style that is consistent with PEP
628   484 (#207, #210)
629
630 - progress when reformatting many files is now reported incrementally
631
632 - fixed trailers (content with brackets) being unnecessarily exploded into their own
633   lines after a dedented closing bracket (#119)
634
635 - fixed an invalid trailing comma sometimes left in imports (#185)
636
637 - fixed non-deterministic formatting when multiple pairs of removable parentheses were
638   used (#183)
639
640 - fixed multiline strings being unnecessarily wrapped in optional parentheses in long
641   assignments (#215)
642
643 - fixed not splitting long from-imports with only a single name
644
645 - fixed Python 3.6+ file discovery by also looking at function calls with unpacking.
646   This fixed non-deterministic formatting if trailing commas where used both in function
647   signatures with stars and function calls with stars but the former would be
648   reformatted to a single line.
649
650 - fixed crash on dealing with optional parentheses (#193)
651
652 - fixed "is", "is not", "in", and "not in" not considered operators for splitting
653   purposes
654
655 - fixed crash when dead symlinks where encountered
656
657 ## 18.4a4
658
659 - don't populate the cache on `--check` (#175)
660
661 ## 18.4a3
662
663 - added a "cache"; files already reformatted that haven't changed on disk won't be
664   reformatted again (#109)
665
666 - `--check` and `--diff` are no longer mutually exclusive (#149)
667
668 - generalized star expression handling, including double stars; this fixes
669   multiplication making expressions "unsafe" for trailing commas (#132)
670
671 - _Black_ no longer enforces putting empty lines behind control flow statements (#90)
672
673 - _Black_ now splits imports like "Mode 3 + trailing comma" of isort (#127)
674
675 - fixed comment indentation when a standalone comment closes a block (#16, #32)
676
677 - fixed standalone comments receiving extra empty lines if immediately preceding a
678   class, def, or decorator (#56, #154)
679
680 - fixed `--diff` not showing entire path (#130)
681
682 - fixed parsing of complex expressions after star and double stars in function calls
683   (#2)
684
685 - fixed invalid splitting on comma in lambda arguments (#133)
686
687 - fixed missing splits of ternary expressions (#141)
688
689 ## 18.4a2
690
691 - fixed parsing of unaligned standalone comments (#99, #112)
692
693 - fixed placement of dictionary unpacking inside dictionary literals (#111)
694
695 - Vim plugin now works on Windows, too
696
697 - fixed unstable formatting when encountering unnecessarily escaped quotes in a string
698   (#120)
699
700 ## 18.4a1
701
702 - added `--quiet` (#78)
703
704 - added automatic parentheses management (#4)
705
706 - added [pre-commit](https://pre-commit.com) integration (#103, #104)
707
708 - fixed reporting on `--check` with multiple files (#101, #102)
709
710 - fixed removing backslash escapes from raw strings (#100, #105)
711
712 ## 18.4a0
713
714 - added `--diff` (#87)
715
716 - add line breaks before all delimiters, except in cases like commas, to better comply
717   with PEP 8 (#73)
718
719 - standardize string literals to use double quotes (almost) everywhere (#75)
720
721 - fixed handling of standalone comments within nested bracketed expressions; _Black_
722   will no longer produce super long lines or put all standalone comments at the end of
723   the expression (#22)
724
725 - fixed 18.3a4 regression: don't crash and burn on empty lines with trailing whitespace
726   (#80)
727
728 - fixed 18.3a4 regression: `# yapf: disable` usage as trailing comment would cause
729   _Black_ to not emit the rest of the file (#95)
730
731 - when CTRL+C is pressed while formatting many files, _Black_ no longer freaks out with
732   a flurry of asyncio-related exceptions
733
734 - only allow up to two empty lines on module level and only single empty lines within
735   functions (#74)
736
737 ## 18.3a4
738
739 - `# fmt: off` and `# fmt: on` are implemented (#5)
740
741 - automatic detection of deprecated Python 2 forms of print statements and exec
742   statements in the formatted file (#49)
743
744 - use proper spaces for complex expressions in default values of typed function
745   arguments (#60)
746
747 - only return exit code 1 when --check is used (#50)
748
749 - don't remove single trailing commas from square bracket indexing (#59)
750
751 - don't omit whitespace if the previous factor leaf wasn't a math operator (#55)
752
753 - omit extra space in kwarg unpacking if it's the first argument (#46)
754
755 - omit extra space in
756   [Sphinx auto-attribute comments](http://www.sphinx-doc.org/en/stable/ext/autodoc.html#directive-autoattribute)
757   (#68)
758
759 ## 18.3a3
760
761 - don't remove single empty lines outside of bracketed expressions (#19)
762
763 - added ability to pipe formatting from stdin to stdin (#25)
764
765 - restored ability to format code with legacy usage of `async` as a name (#20, #42)
766
767 - even better handling of numpy-style array indexing (#33, again)
768
769 ## 18.3a2
770
771 - changed positioning of binary operators to occur at beginning of lines instead of at
772   the end, following
773   [a recent change to PEP 8](https://github.com/python/peps/commit/c59c4376ad233a62ca4b3a6060c81368bd21e85b)
774   (#21)
775
776 - ignore empty bracket pairs while splitting. This avoids very weirdly looking
777   formattings (#34, #35)
778
779 - remove a trailing comma if there is a single argument to a call
780
781 - if top level functions were separated by a comment, don't put four empty lines after
782   the upper function
783
784 - fixed unstable formatting of newlines with imports
785
786 - fixed unintentional folding of post scriptum standalone comments into last statement
787   if it was a simple statement (#18, #28)
788
789 - fixed missing space in numpy-style array indexing (#33)
790
791 - fixed spurious space after star-based unary expressions (#31)
792
793 ## 18.3a1
794
795 - added `--check`
796
797 - only put trailing commas in function signatures and calls if it's safe to do so. If
798   the file is Python 3.6+ it's always safe, otherwise only safe if there are no `*args`
799   or `**kwargs` used in the signature or call. (#8)
800
801 - fixed invalid spacing of dots in relative imports (#6, #13)
802
803 - fixed invalid splitting after comma on unpacked variables in for-loops (#23)
804
805 - fixed spurious space in parenthesized set expressions (#7)
806
807 - fixed spurious space after opening parentheses and in default arguments (#14, #17)
808
809 - fixed spurious space after unary operators when the operand was a complex expression
810   (#15)
811
812 ## 18.3a0
813
814 - first published version, Happy 🍰 Day 2018!
815
816 - alpha quality
817
818 - date-versioned (see: <https://calver.org/>)