]> 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:

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