blob: be1ffb14746be8c4657f5da2df521f79f28a5d68 [file] [log] [blame]
Bill Wendlingdcafd5f2015-09-12 15:26:03 -07001# Change Log
2# All notable changes to this project will be documented in this file.
3# This project adheres to [Semantic Versioning](http://semver.org/).
4
Bill Wendling0b8364e2017-11-14 23:45:50 -08005## [0.20.0] 2017-11-14
Matthew Suozzof0211052017-11-01 17:52:28 -04006### Added
7- Improve splitting of comprehensions and generators. Add
8 `SPLIT_PENALTY_COMPREHENSION` knob to control preference for keeping
9 comprehensions on a single line and `SPLIT_COMPLEX_COMPREHENSION` to enable
10 splitting each clause of complex comprehensions onto its own line.
Bill Wendling8c07cc12017-10-16 00:37:58 -070011### Changed
12- Take into account a named function argument when determining if we should
13 split before the first argument in a function call.
Bill Wendling1dc75ac2017-10-16 02:45:46 -070014- Split before the first argument in a function call if the arguments contain a
15 dictionary that doesn't fit on a single line.
Bill Wendlingb1c7ca82017-10-21 00:02:49 -070016- Improve splitting of elements in a tuple. We want to split if there's a
17 function call in the tuple that doesn't fit on the line.
Bill Wendling7bfc0a92017-10-16 03:22:19 -070018### Fixed
19- Enforce spaces between ellipses and keywords.
Bill Wendlingbd9d9552017-10-16 22:45:17 -070020- When calculating the split penalty for a "trailer", process the child nodes
21 afterwards because their penalties may change. For example if a list
22 comprehension is an argument.
Bill Wendlingd404b702017-10-16 23:16:14 -070023- Don't enforce a split before a comment after the opening of a container if it
24 doesn't it on the current line. We try hard not to move such comments around.
Bill Wendlingca46e862017-10-24 00:46:11 -070025- Use a TextIOWrapper when reading from stdin in Python3. This is necessary for
26 some encodings, like cp936, used on Windows.
Matthew Suozzo2112ad22017-10-29 18:23:03 -040027- Remove the penalty for a split before the first argument in a function call
28 where the only argument is a generator expression.
Bill Wendling8c07cc12017-10-16 00:37:58 -070029
Bill Wendling4d9b9052017-10-14 15:02:31 -070030## [0.19.0] 2017-10-14
Bill Wendling9680f732017-10-09 01:11:38 -070031### Added
32- Added `SPLIT_BEFORE_EXPRESSION_AFTER_OPENING_PAREN` that enforces a split
33 after the opening paren of an expression that's surrounded by parens.
Bill Wendling5f83cfb2017-10-08 01:12:27 -070034### Changed
35- Split before the ending bracket of a comma-terminated tuple / argument list
36 if it's not a single element tuple / arg list.
Bill Wendlingba55eb12017-09-19 14:30:02 -070037### Fixed
38- Prefer to split after a comma in an argument list rather than in the middle
39 of an argument.
Bill Wendling61f93c32017-10-01 00:35:30 -070040- A non-multiline string may have newlines if it contains continuation markers
41 itself. Don't add a newline after the string when retaining the vertical
42 space.
Bill Wendling9df211b2017-10-01 01:12:22 -070043- Take into account the "async" keyword when determining if we must split
44 before the first argument.
Bill Wendling74911872017-10-04 02:59:30 -070045- Increase affinity for "atom" arguments in function calls. This helps prevent
46 lists from being separated when they don't need to be.
Bill Wendlingb00e4f62017-10-07 03:22:12 -070047- Don't place a dictionary argument on its own line if it's the last argument
48 in the function call where that function is part of a builder-style call.
Bill Wendlinga531f212017-10-12 15:58:29 -070049- Append the "var arg" type to a star in a star_expr.
Bill Wendlingba55eb12017-09-19 14:30:02 -070050
Bill Wendling7ef7e142017-09-18 16:59:48 -070051## [0.18.0] 2017-09-18
Bill Wendling8a3b71f2017-08-26 02:34:03 -070052### Added
53- Option `ALLOW_SPLIT_BEFORE_DICT_VALUE` allows a split before a value. If
54 False, then it won't be split even if it goes over the column limit.
Bill Wendling855860e2017-08-24 21:31:33 -070055### Changed
56- Use spaces around the '=' in a typed name argument to align with 3.6 syntax.
Bill Wendling8012f592017-08-21 01:23:18 -070057### Fixed
58- Allow semicolons if the line is disabled.
Bouwe Andelaf6dba622017-08-21 21:33:23 +020059- Fix issue where subsequent comments at decreasing levels of indentation
60 were improperly aligned and/or caused output with invalid syntax.
Bill Wendling562e04c2017-08-23 02:32:11 -070061- Fix issue where specifying a line range removed a needed line before a
62 comment.
Bill Wendling6e7f5a82017-08-24 20:15:08 -070063- Fix spacing between unary operators if one is 'not'.
Bill Wendling578854b2017-08-24 22:26:59 -070064- Indent the dictionary value correctly if there's a multi-line key.
Bill Wendling8ee1b532017-09-06 13:58:32 -070065- Don't remove needed spacing before a comment in a dict when in "chromium"
66 style.
Bill Wendling6412ce72017-09-18 16:18:48 -070067- Increase indent for continuation line with same indent as next logical line
68 with 'async with' statement.
Bill Wendling8012f592017-08-21 01:23:18 -070069
Bill Wendling5f737202017-08-20 22:03:12 -070070## [0.17.0] 2017-08-20
Jiri Kuncarf14bd172017-07-21 09:45:31 +020071### Added
72- Option `NO_SPACES_AROUND_SELECTED_BINARY_OPERATORS` prevents adding spaces
73 around selected binary operators, in accordance with the current style guide.
Kevin Coxc565e832017-07-21 13:50:47 +010074### Changed
75- Adjust blank lines on formatting boundaries when using the `--lines` option.
Bill Wendling71d9b2e2017-08-01 13:38:54 -070076- Return 1 if a diff changed the code. This is in line with how GNU diff acts.
Max Vorobev3b903112017-08-26 14:43:48 +030077- Add `-vv` flag to print out file names as they are processed
Richard Wallacad4ce2017-08-04 15:08:40 +010078### Fixed
79- Corrected how `DEDENT_CLOSING_BRACKETS` and `COALESCE_BRACKETS` interacted.
Bill Wendlingb0de56d2017-08-12 15:21:12 -070080- Fix return value to return a boolean.
Anton Yuzhaninovdb85e872017-07-19 22:45:45 -040081- Correct vim plugin not to clobber edited code if yapf returns an error.
Justin Huang767edac2017-08-12 17:36:41 -070082- Ensured comma-terminated tuples with multiple elements are split onto separate lines.
Kevin Coxc565e832017-07-21 13:50:47 +010083
Bill Wendling4aa43d82017-07-13 00:45:39 -070084## [0.16.3] 2017-07-13
Bill Wendling81a6d842017-07-12 23:58:17 -070085### Changed
86- Add filename information to a ParseError excetion.
Bill Wendling77ca21d2017-03-28 00:41:18 -070087### Fixed
Bill Wendling4aa43d82017-07-13 00:45:39 -070088- A token that ends in a continuation marker may have more than one newline in
89 it, thus changing its "lineno" value. This can happen if multiple
90 continuation markers are used with no intervening tokens. Adjust the line
91 number to account for the lines covered by those markers.
92- Make sure to split after a comment even for "pseudo" parentheses.
93
94## [0.16.2] 2017-05-19
95### Fixed
Bill Wendling77ca21d2017-03-28 00:41:18 -070096- Treat expansion operators ('*', '**') in a similar way to function calls to
97 avoid splitting directly after the opening parenthesis.
98- Increase the penalty for splitting after the start of a tuple.
Bill Wendlinge67e3532017-03-31 00:43:00 -070099- Increase penalty for excess characters.
Bill Wendling16becc52017-04-02 19:52:49 -0700100- Check that we have enough children before trying to access them all.
Bill Wendlingda3697c2017-04-13 00:32:09 -0700101- Remove trailing whitespaces from comments.
Bill Wendlinga36bb6d2017-04-16 18:51:53 -0700102- Split before a function call in a list if the full list isn't able to fit on
103 a single line.
Bill Wendling1cfcbd12017-04-17 19:38:28 -0700104- Trying not to split around the '=' of a named assign.
Bill Wendling81a6d842017-07-12 23:58:17 -0700105- Changed split before the first argument behavior to ignore compound
106 statements like if and while, but not function declarations.
107- Changed coalesce brackets not to line split before closing bracket.
Bill Wendling77ca21d2017-03-28 00:41:18 -0700108
Bill Wendling5ca31092017-03-22 11:41:07 -0700109## [0.16.1] 2017-03-22
Bill Wendling5a1e3312017-02-14 18:40:43 -0800110### Changed
111- Improved performance of cloning the format decision state object. This
112 improved the time in one *large* case from 273.485s to 234.652s.
Bill Wendlingc2f520c2017-02-15 22:03:18 -0800113- Relax the requirement that a named argument needs to be on one line. Going
114 over the column limit is more of an issue to pylint than putting named args
115 on multiple lines.
Bill Wendling79b82ef2017-02-17 00:24:51 -0800116- Don't make splitting penalty decisions based on the original formatting. This
117 can and does lead to non-stable formatting, where yapf will reformat the same
118 code in different ways.
Bill Wendlinga9529662017-02-06 21:47:39 -0800119### Fixed
120- Ensure splitting of arguments if there's a named assign present.
Bill Wendling56f0fb62017-02-06 22:58:05 -0800121- Prefer to coalesce opening brackets if it's not at the beginning of a
122 function call.
Bill Wendling313c65a2017-02-17 01:56:45 -0800123- Prefer not to squish all of the elements in a function call over to the
124 right-hand side. Split the arguments instead.
Bill Wendling257c1b02017-02-20 15:32:29 -0800125- We need to split a dictionary value if the first element is a comment anyway,
126 so don't force the split here. It's forced elsewhere.
CaselITd69801d2017-02-21 13:45:13 +0100127- Ensure tabs are used for continued indentation when USE_TABS is True.
Bill Wendlinga9529662017-02-06 21:47:39 -0800128
Bill Wendling873039e2017-02-05 20:24:46 -0800129## [0.16.0] 2017-02-05
Bill Wendling0e9b3212017-01-31 14:41:00 -0800130### Added
131- The `EACH_DICT_ENTRY_ON_SEPARATE_LINE` knob indicates that each dictionary
132 entry should be in separate lines if the full dictionary isn't able to fit on
133 a single line.
134- The `SPLIT_BEFORE_DICT_SET_GENERATOR` knob splits before the `for` part of a
135 dictionary/set generator.
Bill Wendling9f497522017-02-04 04:39:47 -0800136- The `BLANK_LINE_BEFORE_CLASS_DOCSTRING` knob adds a blank line before a
137 class's docstring.
Bill Wendling8d321362017-02-05 18:29:26 -0800138- The `ALLOW_MULTILINE_DICTIONARY_KEYS` knob allows dictionary keys to span
139 more than one line.
Bill Wendling94962e52017-02-04 04:07:19 -0800140### Fixed
141- Split before all entries in a dict/set or list maker when comma-terminated,
142 even if there's only one entry.
Adrian Tejn Kernbfee67d2017-02-05 08:36:02 +0100143- Will now try to set O_BINARY mode on stdout under Windows and Python 2.
144- Avoid unneeded newline transformation when writing formatted code to
145 output on (affects only Python 2)
Bill Wendling0e9b3212017-01-31 14:41:00 -0800146
Bill Wendling3d470dd2017-01-29 19:45:13 -0800147## [0.15.2] 2017-01-29
Bill Wendlingbf631182017-01-24 15:34:35 -0800148### Fixed
149- Don't perform a global split when a named assign is part of a function call
150 which itself is an argument to a function call. I.e., don't cause 'a' to
151 split here:
152
153 func(a, b, c, d(x, y, z=42))
Bill Wendlingb64e7022017-01-25 09:44:41 -0800154- Allow splitting inside a subscript if it's a logical or bitwise operating.
155 This should keep the subscript mostly contiguous otherwise.
Bill Wendlingbf631182017-01-24 15:34:35 -0800156
Bill Wendling5d7b3612017-01-21 23:43:35 -0800157## [0.15.1] 2017-01-21
Bill Wendling672ece02017-01-14 16:35:48 -0800158### Fixed
159- Don't insert a space between a type hint and the '=' sign.
Bill Wendlingb57e71c2017-01-14 16:51:35 -0800160- The '@' operator can be used in Python 3 for matrix multiplication. Give the
161 '@' in the decorator a DECORATOR subtype to distinguish it.
Bill Wendlingfd30b912017-01-15 16:45:24 -0800162- Encourage the formatter to split at the beginning of an argument list instead
163 of in the middle. Especially if the middle is an empty parameter list. This
164 adjusts the affinity of binary and comparison operators. In particular, the
165 "not in" and other such operators don't want to have a split after it (or
166 before it) if at all possible.
Bill Wendling672ece02017-01-14 16:35:48 -0800167
Bill Wendling61061f62017-01-12 20:58:55 -0800168## [0.15.0] 2017-01-12
169### Added
170- Keep type annotations intact as much as possible. Don't try to split the over
171 mutliple lines.
Bill Wendlingb50a6b22016-11-27 17:06:58 -0800172### Fixed
173- When determining if each element in a dictionary can fit on a single line, we
174 are skipping dictionary entries. However, we need to ignore comments in our
175 calculations and implicitly concatenated strings, which are already placed on
176 separate lines.
Bill Wendling596300d2016-11-28 13:08:57 -0800177- Allow text before a "pylint" comment.
Bill Wendlingeb979f32016-11-28 13:16:04 -0800178- Also allow text before a "yapf: (disable|enable)" comment.
Bill Wendlingb50a6b22016-11-27 17:06:58 -0800179
Bill Wendling544a2812016-11-21 15:29:19 -0800180## [0.14.0] 2016-11-21
Bill Wendling61061f62017-01-12 20:58:55 -0800181### Added
Diogo de Campos2f246c02016-10-06 14:04:38 +0200182- formatting can be run in parallel using the "-p" / "--parallel" flags.
Bill Wendling6041f222016-11-02 01:07:39 -0700183### Fixed
184- "not in" and "is not" should be subtyped as binary operators.
Bill Wendlingccea10e2016-11-08 16:26:21 -0800185- A non-Node dictionary value may have a comment before it. In those cases, we
186 want to avoid encompassing only the comment in pseudo parens. So we include
187 the actual value as well.
Bill Wendlingf7286532016-11-16 17:52:50 -0800188- Adjust calculation so that pseudo-parentheses don't count towards the total
189 line length.
Bill Wendling508694b2016-11-20 23:52:52 -0800190- Don't count a dictionary entry as not fitting on a single line in a
191 dictionary.
Bill Wendling47c3e4f2016-11-21 15:25:09 -0800192- Don't count pseudo-parentheses in the length of the line.
Bill Wendling6041f222016-11-02 01:07:39 -0700193
Bill Wendling35d6b7c2016-10-22 01:18:51 -0700194## [0.13.2] 2016-10-22
195### Fixed
196- REGRESSION: A comment may have a prefix with newlines in it. When calculating
197 the prefix indent, we cannot take the newlines into account. Otherwise, the
198 comment will be misplaced causing the code to fail.
199
Bill Wendlingf3e09652016-10-17 14:26:41 -0700200## [0.13.1] 2016-10-17
201### Fixed
202- Correct emitting a diff that was accidentally removed.
203
Bill Wendling31f82132016-10-16 22:54:01 -0700204## [0.13.0] 2016-10-16
Bill Wendlingcec6b192016-10-16 00:30:02 -0500205### Added
206- Added support to retain the original line endings of the source code.
207
Bill Wendlinga5a52e22016-10-11 13:40:38 -0700208### Fixed
209- Functions or classes with comments before them were reformatting the comments
210 even if the code was supposed to be ignored by the formatter. We now don't
211 adjust the whitespace before a function's comment if the comment is a
212 "disabled" line. We also don't count "# yapf: {disable|enable}" as a disabled
213 line, which seems logical.
Bill Wendlinge6c93572016-10-11 20:26:23 -0700214- It's not really more readable to split before a dictionary value if it's part
215 of a dictionary comprehension.
Bill Wendling556f9152016-10-13 01:27:38 -0700216- Enforce two blank lines after a function or class definition, even before a
Bill Wendling7cc4d182016-10-13 11:26:26 -0700217 comment. (But not between a decorator and a comment.) This is related to PEP8
218 error E305.
Bill Wendling0d372eb2016-10-14 00:36:21 -0700219- Remove O(n^2) algorithm from the line disabling logic.
Bill Wendlinga5a52e22016-10-11 13:40:38 -0700220
Bill Wendlingc2620f92016-10-09 20:40:15 -0700221## [0.12.2] 2016-10-09
Bill Wendling293cb6c2016-10-02 16:46:11 -0700222### Fixed
223- If `style.SetGlobalStyle(<create pre-defined style>)` was called and then
224 `yapf_api.FormatCode` was called, the style set by the first call would be
225 lost, because it would return the style created by `DEFAULT_STYLE_FACTORY`,
226 which is set to PEP8 by default. Fix this by making the first call set which
227 factory we call as the "default" style.
Bill Wendling85b5a632016-10-03 20:30:43 -0700228- Don't force a split before non-function call arguments.
Bill Wendling261c79a2016-10-03 20:58:08 -0700229- A dictionary being used as an argument to a function call and which can exist
230 on a single line shouldn't be split.
Bill Wendling35edcbd2016-10-03 22:33:34 -0700231- Don't rely upon the original line break to determine if we should split
Bill Wendlingc18abac2016-10-03 22:49:52 -0700232 before the elements in a container. Especially split if there's a comment in
233 the container.
Bill Wendling690132a2016-10-04 22:55:47 -0700234- Don't add spaces between star and args in a lambda expression.
Bill Wendlingeef8fbd2016-10-05 00:34:25 -0700235- If a nested data structure terminates in a comma, then split before the first
236 element, but only if there's more than one element in the list.
Bill Wendling293cb6c2016-10-02 16:46:11 -0700237
238## [0.12.1] 2016-10-02
Bill Wendling1960ffc2016-10-01 23:57:05 -0700239### Changed
240- Dictionary values will be placed on the same line as the key if *all* of the
241 elements in the dictionary can be placed on one line. Otherwise, the
242 dictionary values will be placed on the next line.
243
Bill Wendlinge0412442016-09-28 02:19:31 -0700244### Fixed
245- Prefer to split before a terminating r-paren in an argument list if the line
246 would otherwise go over the column limit.
Bill Wendling21836ef2016-09-28 19:13:16 -0700247- Split before the first key in a dictionary if the dictionary cannot fit on a
248 single line.
Bill Wendling61997072016-09-30 00:45:59 -0700249- Don't count "pylint" comments when determining if the line goes over the
250 column limit.
Bill Wendling0e703572016-10-01 23:02:32 -0700251- Don't count the argument list of a lambda as a named assign in a function
252 call.
Bill Wendlinge0412442016-09-28 02:19:31 -0700253
Bill Wendling1b919632016-09-25 16:03:04 -0700254## [0.12.0] 2016-09-25
Bill Wendling90eab552016-08-19 23:47:23 -0700255### Added
256- Support formatting of typed names. Typed names are formatted a similar way to
257 how named arguments are formatted, except that there's a space after the
258 colon.
Alexander Lenz5fda36a2016-08-26 17:27:57 +0200259- Add a knob, 'SPACES_AROUND_DEFAULT_OR_NAMED_ASSIGN', to allow adding spaces
260 around the assign operator on default or named assigns.
Bill Wendling90eab552016-08-19 23:47:23 -0700261
Bill Wendling7c7f6032016-08-31 10:46:33 -0700262## Changed
263- Turn "verification" off by default for external APIs.
Bill Wendlingf0dd0a42016-09-25 15:54:02 -0700264- If a function call in an argument list won't fit on the current line but will
265 fit on a line by itself, then split before the call so that it won't be split
266 up unnecessarily.
Bill Wendling7c7f6032016-08-31 10:46:33 -0700267
Bill Wendlinga6fb6f72016-09-17 14:39:26 -0700268## Fixed
269- Don't add space after power operator if the next operator's a unary operator.
270
Bill Wendling79ee44a2016-08-17 00:33:02 -0700271## [0.11.1] 2016-08-17
Bill Wendling7b87b0a2016-08-17 00:01:56 -0700272### Changed
273- Issue #228: Return exit code 0 on success, regardless of whether files were
274 changed. (Previously, 0 meant success with no files
275 modified, and 2 meant success with at least one file modified.)
276
Bill Wendlingf4de4c62016-07-21 00:08:29 -0700277### Fixed
278- Enforce splitting each element in a dictionary if comma terminated.
Bill Wendlingb8d20bd2016-08-05 23:44:23 -0700279- It's okay to split in the middle of a dotted name if the whole expression is
280 going to go over the column limit.
Bill Wendling15edda22016-08-15 17:04:26 -0700281- Asynchronous functions were going missing if they were preceded by a comment
282 (a what? exactly). The asynchronous function processing wasn't taking the
283 comment into account and thus skipping the whole function.
Bill Wendling7b87b0a2016-08-17 00:01:56 -0700284- The splitting of arguments when comma terminated had a conflict. The split
285 penalty of the closing bracket was set to the maximum, but it shouldn't be if
286 the closing bracket is preceded by a comma.
Reece Hart039c0b52016-08-11 13:46:15 -0700287
Bill Wendling1d8638e2016-07-17 00:06:01 -0700288## [0.11.0] 2016-07-17
Ben Plotnick7e088292016-06-09 18:29:56 -0700289### Added
290- The COALESCE_BRACKETS knob prevents splitting consecutive brackets when
291 DEDENT_CLOSING_BRACKETS is set.
Bill Wendling61e80c02016-07-14 16:50:10 -0700292- Don't count "pylint" directives as exceeding the column limit.
Ben Plotnick7e088292016-06-09 18:29:56 -0700293
Bill Wendling33636712016-07-16 02:49:28 -0700294### Changed
295- We split all of the arguments to a function call if there's a named argument.
Bill Wendling2df29282016-07-16 17:23:41 -0700296 In this case, we want to split after the opening bracket too. This makes
Bill Wendling33636712016-07-16 02:49:28 -0700297 things look a bit better.
298
Bill Wendling4761b182016-07-03 00:11:14 -0700299### Fixed
300- When retaining format of a multiline string with Chromium style, make sure
301 that the multiline string doesn't mess up where the following comma ends up.
Bill Wendling821a36f2016-07-13 23:02:16 -0700302- Correct for when 'lib2to3' smooshes comments together into the same DEDENT
303 node.
Bill Wendling4761b182016-07-03 00:11:14 -0700304
Bill Wendling7521d4b2016-06-14 01:35:38 -0700305## [0.10.0] 2016-06-14
Draconye582d632016-06-05 11:48:26 +0200306### Added
307- Add a knob, 'USE_TABS', to allow using tabs for indentation.
Bill Wendling184c2de2016-06-13 03:21:04 -0700308
Bill Wendlingb0285ba2016-05-31 16:10:59 -0700309### Changed
310- Performance enhancements.
311
Draconye582d632016-06-05 11:48:26 +0200312### Fixed
Bill Wendlingd02b5922016-06-03 23:48:19 -0700313- Don't split an import list if it's not surrounded by parentheses.
314
Bill Wendling90f361f2016-05-29 16:13:10 -0700315## [0.9.0] 2016-05-29
Bill Wendlinga6988c32016-05-22 18:47:11 -0700316### Added
Bill Wendling1e161592016-05-23 16:34:03 -0700317- Added a knob (SPLIT_PENALTY_BEFORE_IF_EXPR) to adjust the split penalty
318 before an if expression. This allows the user to place a list comprehension
319 all on one line.
320- Added a knob (SPLIT_BEFORE_FIRST_ARGUMENT) that encourages splitting before
321 the first element of a list of arguments or parameters if they are going to
322 be split anyway.
Bill Wendling86e51782016-05-24 00:47:44 -0700323- Added a knob (SPLIT_ARGUMENTS_WHEN_COMMA_TERMINATED) splits arguments to a
324 function if the list is terminated by a comma.
Bill Wendlinga6988c32016-05-22 18:47:11 -0700325
Bill Wendling7edb3842016-05-21 15:07:54 -0700326### Fixed
327- Don't split before a first element list argument as we would before a first
328 element function call.
Bill Wendlinge8a85692016-05-21 23:57:20 -0700329- Don't penalize when we must split a line.
Bill Wendling283f4ea2016-05-23 16:19:15 -0700330- Allow splitting before the single argument in a function call.
Bill Wendling7edb3842016-05-21 15:07:54 -0700331
Bill Wendlingd2a585d2016-05-21 00:41:24 -0700332## [0.8.2] 2016-05-21
Bill Wendling72cd2342016-05-19 01:28:58 -0700333### Fixed
334- Prefer not to split after the opening of a subscript.
Bill Wendling1e179bb2016-05-19 01:51:34 -0700335- Don't add space before the 'await' keyword if it's preceded by an opening
336 paren.
Bill Wendling4b6cead2016-05-19 11:33:38 -0700337- When we're setting the split penalty for a continuous list, we don't want to
338 mistake a comment at the end of that list as part of the list.
Bill Wendlingda6ab272016-05-19 21:45:34 -0700339- When calculating blank lines, don't assume the last seen object was a class
340 or function when we're in a class or function.
Bill Wendlingf61861d2016-05-21 00:36:27 -0700341- Don't count the closing scope when determining if the current scope is the
342 last scope on the line.
Bill Wendling72cd2342016-05-19 01:28:58 -0700343
Bill Wendlingde2c5b22016-05-18 21:10:29 -0700344## [0.8.1] 2016-05-18
Bill Wendling8f1d1402016-05-14 19:22:48 -0700345### Fixed
346- 'SPLIT_BEFORE_LOGICAL_OPERATOR' wasn't working correctly. The penalty was
347 being set incorrectly when it was part of a larger construct.
Bill Wendling99cbd562016-05-15 18:41:12 -0700348- Don't separate a keyword, like "await", from a left paren.
Bill Wendling311c0872016-05-18 01:51:12 -0700349- Don't rely upon the original tokens' line number to determine if we should
350 perform splitting in Facebook mode. The line number isn't the line number of
351 the reformatted token, but the line number where it was in the original code.
352 Instead, we need to carefully determine if the line is liabel to be split and
353 act accordingly.
Bill Wendling8f1d1402016-05-14 19:22:48 -0700354
Bill Wendlingfe7a4ac2016-05-10 23:51:57 -0700355## [0.8.0] 2016-05-10
Bill Wendling9dc79082016-05-10 00:23:53 -0700356### Added
Bill Wendling43eaa752016-05-12 01:25:20 -0700357- Add a knob, 'SPACES_AROUND_POWER_OPERATOR', to allow adding spaces around the
358 power operator.
Bill Wendling9dc79082016-05-10 00:23:53 -0700359
Bill Wendlingf015a3c2016-04-21 20:14:24 -0700360### Fixed
361- There shouldn't be a space between a decorator and an intervening comment.
Bill Wendling3e15d002016-04-28 00:16:32 -0700362- If we split before a bitwise operator, then we assume that the programmer
363 knows what they're doing, more or less, and so we enforce a split before said
364 operator if one exists in the original program.
Bill Wendlingadf1d442016-05-10 01:03:50 -0700365- Strengthen the bond between a keyword and value argument.
Bill Wendling93c42d92016-05-10 23:35:57 -0700366- Don't add a blank line after a multiline string.
Bill Wendlingcae1edd2016-05-10 23:49:19 -0700367- If the "for" part of a list comprehension can exist on the starting line
368 without going over the column limit, then let it remain there.
Bill Wendlingf015a3c2016-04-21 20:14:24 -0700369
Bill Wendling8d36eb82016-04-21 02:33:36 -0700370## [0.7.1] 2016-04-21
Bill Wendling4dc472d2016-04-10 03:03:55 -0700371### Fixed
372- Don't rewrite the file if there are no changes.
Bill Wendlingac00a252016-04-12 05:31:03 -0700373- Ensure the proper number of blank lines before an async function.
Bill Wendlingc4a49652016-04-13 13:42:43 -0700374- Split after a bitwise operator when in PEP 8 mode.
Bill Wendling423759f2016-04-14 21:14:20 -0700375- Retain the splitting within a dictionary data literal between the key and
376 value.
Bill Wendling9882f3d2016-04-21 02:29:35 -0700377- Try to keep short function calls all on one line even if they're part of a
378 larger series of tokens. This stops us from splitting too much.
Bill Wendling4dc472d2016-04-10 03:03:55 -0700379
Bill Wendlingdefe5f32016-04-09 22:29:51 -0700380## [0.7.0] 2016-04-09
Bill Wendling2e588512016-03-13 01:02:47 -0800381### Added
Bill Wendling5758e4d2016-03-19 03:38:48 -0700382- Support for Python 3.5.
383- Add 'ALLOW_MULTILINE_LAMBDAS' which allows lambdas to be formatted onto
384 multiple lines.
Bill Wendling2e588512016-03-13 01:02:47 -0800385
386### Fixed
387- Lessen penalty for splitting before a dictionary keyword.
Bill Wendling90a2aa52016-03-20 02:25:13 -0700388- Formatting of trailing comments on disabled formatting lines.
Bill Wendling2064d882016-04-09 22:21:15 -0700389- Disable / enable formatting at end of multi-line comment.
Bill Wendling2e588512016-03-13 01:02:47 -0800390
Bill Wendling0bca2aa2016-03-06 20:44:14 -0800391## [0.6.3] 2016-03-06
392### Changed
393- Documentation updated.
394
Bill Wendling95e47b92015-11-04 22:58:30 -0800395### Fixed
396- Fix spacing of multiline comments when formatting is disabled.
397
Bill Wendling9ffd8152015-11-01 17:49:25 -0800398## [0.6.2] 2015-11-01
Bill Wendling6e8ca7b2015-10-25 01:16:43 -0700399### Changed
400- Look at the 'setup.cfg' file to see if it contains style information for
401 YAPF.
Bill Wendling169790e2015-10-25 03:13:13 -0700402- Look at the '~/.config/yapf/style' file to see if it contains global style
403 information for YAPF.
Bill Wendling6e8ca7b2015-10-25 01:16:43 -0700404
Bill Wendling57ffbbb2015-10-25 00:20:14 -0700405### Fixed
406- Make lists that can fit on one line more likely to stay together.
Bill Wendling5091fa62015-10-28 01:51:53 -0700407- Correct formatting of '*args' and '**kwargs' when there are default values in
408 the argument list.
Bill Wendling57ffbbb2015-10-25 00:20:14 -0700409
Bill Wendling348b2f32015-10-24 03:20:10 -0700410## [0.6.1] 2015-10-24
Bill Wendling3a3cb6d2015-10-20 13:40:27 -0700411### Fixed
412- Make sure to align comments in data literals correctly. Also make sure we
413 don't count a "#." in a string as an i18n comment.
Bill Wendlinga6b57a62015-10-20 13:57:52 -0700414- Retain proper vertical spacing before comments in a data literal.
Bill Wendling843e48c2015-10-20 16:53:08 -0700415- Make sure that continuations from a compound statement are distinguished from
416 the succeeding line.
Bill Wendling81e37b62015-10-21 13:18:29 -0700417- Ignore preceding comments when calculating what is a "dictonary maker".
Bill Wendlinga5585722015-10-21 15:32:22 -0700418- Add a small penalty for splitting before a closing bracket.
Bill Wendlingdbcf3422015-10-21 22:11:15 -0700419- Ensure that a space is enforced after we remove a pseudo-paren that's between
420 two names, keywords, numbers, etc.
Bill Wendlingf8856722015-10-21 23:53:29 -0700421- Increase the penalty for splitting after a pseudo-paren. This could lead to
422 less readable code in some circumstances.
Bill Wendling3a3cb6d2015-10-20 13:40:27 -0700423
Bill Wendling7ef492b2015-10-18 14:43:06 -0700424## [0.6.0] 2015-10-18
Bill Wendlinga5cef8e2015-10-15 21:42:03 -0700425### Added
426- Add knob to indent the dictionary value if there is a split before it.
427
Bill Wendlingcec66962015-10-17 04:08:23 -0700428### Changed
429- No longer check that a file is a "Python" file unless the '--recursive' flag
430 is specified.
431- No longer allow the user to specify a directory unless the '--recursive' flag
432 is specified.
433
Bill Wendlingc87690c2015-10-11 16:45:21 -0700434### Fixed
435- When determining if we should split a dictionary's value to a new line, use
436 the longest entry instead of the total dictionary's length. This allows the
437 formatter to reformat the dictionary in a more consistent manner.
Bill Wendling0946c0f2015-10-12 00:42:30 -0700438- Improve how list comprehensions are formatted. Make splitting dependent upon
439 whether the "comp_for" or "comp_if" goes over the column limit.
Bill Wendling43bdc7b2015-10-12 14:25:30 -0700440- Don't over indent if expression hanging indents if we expect to dedent the
441 closing bracket.
Bill Wendlingc1052c62015-10-15 03:12:28 -0700442- Improve splitting heuristic when the first argument to a function call is
443 itself a function call with arguments. In cases like this, the remaining
444 arguments to the function call would look badly aligned, even though they are
445 techincally correct (the best kind of correct!).
Bill Wendlingb1037b52015-10-15 22:38:19 -0700446- Improve splitting heuristic more so that if the first argument to a function
447 call is a data literal that will go over the column limit, then we want to
448 split before it.
Bill Wendling8d8f5122015-10-16 11:46:23 -0700449- Remove spaces around '**' operator.
Bill Wendlingf8325e62015-10-16 15:38:54 -0700450- Retain formatting of comments in the middle of an expression.
Bill Wendling454cef62015-10-18 03:49:03 -0700451- Don't add a newline to an empty file.
Bill Wendling7ef492b2015-10-18 14:43:06 -0700452- Over indent a function's parameter list if it's not distinguished from the
453 body of the function.
Bill Wendlingc87690c2015-10-11 16:45:21 -0700454
Bill Wendling2aff7fc2015-10-11 14:08:10 -0700455## [0.5.0] 2015-10-11
Bill Wendlingd03c99f2015-10-08 21:06:07 -0700456### Added
457- Add option to exclude files/directories from formatting.
Bill Wendling5c608732015-10-10 23:39:16 -0700458- Add a knob to control whether import names are split after the first '('.
Bill Wendlingd03c99f2015-10-08 21:06:07 -0700459
Bill Wendlinga7e3f502015-10-08 00:23:40 -0700460### Fixed
461- Indent the continuation of an if-then statement when it's not distinguished
462 from the body of the if-then.
Bill Wendling1ce18c72015-10-10 23:12:16 -0700463- Allow for sensible splitting of array indices where appropriate.
Bill Wendlingbe974d82015-10-11 01:04:00 -0700464- Prefer to not split before the ending bracket of an atom. This produces
465 better code in most cases.
Bill Wendlingbbd148c2015-10-11 01:45:24 -0700466- Corrected how horizontal spaces were presevered in a disabled region.
Bill Wendlinga7e3f502015-10-08 00:23:40 -0700467
Bill Wendling967c3b22015-10-07 22:20:18 -0700468## [0.4.0] 2015-10-07
Ɓukasz Langa94089872015-09-22 16:02:26 -0700469### Added
470- Support for dedenting closing brackets, "facebook" style.
471
Bill Wendling25c8e602015-10-04 20:48:35 -0700472### Fixed
473- Formatting of tokens after a multiline string didn't retain their horizontal
474 spacing.
475
Bill Wendling06865ab2015-09-30 01:25:47 -0700476## [0.3.1] 2015-09-30
477### Fixed
478- Format closing scope bracket correctly when indentation size changes.
479
Bill Wendlinga690a622015-09-20 12:38:50 -0700480## [0.3.0] 2015-09-20
481### Added
482- Return a 2 if the source changed, 1 on error, and 0 for no change.
483
484### Fixed
485- Make sure we format if the "lines" specified are in the middle of a
486 statement.
487
Bill Wendling9adfa0c2015-09-13 05:37:30 -0700488## [0.2.9] - 2015-09-13
489### Fixed
490- Formatting of multiple files. It was halting after formatting the first file.
491
Bill Wendlingdcafd5f2015-09-12 15:26:03 -0700492## [0.2.8] - 2015-09-12
493### Added
494- Return a non-zero exit code if the source was changed.
495- Add bitwise operator splitting penalty and prefer to split before bitwise
496 operators.
497
498### Fixed
499- Retain vertical spacing between disabled and enabled lines.
500- Split only at start of named assign.
501- Retain comment position when formatting is disabled.
502- Honor splitting before or after logical ops.