blob: 4693f039ee6b35017f40e273e6f2a133f4df5377 [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 Wendling49225492018-07-01 23:02:35 -07005## [0.23.0] UNRELEASED
6### Added
7- `DISABLE_ENDING_COMMA_HEURISTIC` is a new knob to disable the heuristic which
8 splits a list onto separate lines if the list is comma-terminated.
Bill Wendling19dbc7a2018-05-21 14:29:10 -07009### Fixed
10- There's no need to increase N_TOKENS. In fact, it causes other things which
11 use lib2to3 to fail if called from YAPF.
Bill Wendlinga1001b12018-07-01 22:25:30 -070012- Change the exception message instead of creating a new one that's just a
13 clone.
Bill Wendling19dbc7a2018-05-21 14:29:10 -070014
Bill Wendlingd52ae2a2018-05-15 22:24:24 -070015## [0.22.0] 2018-05-15
Dan Porter61d88092018-03-22 12:52:16 +000016### Added
17- The `BLANK_LINE_BEFORE_MODULE_DOCSTRING` knob adds a blank line before a
18 module's docstring.
cardenb83a62ad2018-05-14 22:54:12 -070019- The `SPLIT_ALL_COMMA_SEPARATED_VALUES` knob causes all lists, tuples, dicts
20 function defs, etc... to split on all values, instead of maximizing the
21 number of elements on each line, when not able to fit on a single line.
Bill Wendling3bab5842018-03-26 22:26:06 -070022### Changed
23- Improve the heuristic we use to determine when to split at the start of a
24 function call. First check whether or not all elements can fit in the space
25 without wrapping. If not, then we split.
Bill Wendling2b0b2ca2018-03-26 22:56:55 -070026- Check all of the elements of a tuple. Similarly to how arguments are
27 analyzed. This allows tuples to be split more rationally.
Bill Wendling8f8c5f52018-03-27 13:43:11 -070028- Adjust splitting penalties around arithmetic operators so that the code can
29 flow more freely. The code must flow!
Bill Wendling4ddb2fe2018-03-27 15:31:54 -070030- Try to meld an argument list's closing parenthesis to the last argument.
Bill Wendlingd5df2082018-03-26 23:25:45 -070031### Fixed
32- Attempt to determine if long lambdas are allowed. This can be done on a
33 case-by-case basis with a "pylint" disable comment.
Bill Wendling3d9e9982018-03-27 00:15:30 -070034- A comment before a decorator isn't part of the decorator's line.
Bill Wendlingd059cc42018-03-30 20:45:14 -070035- Only force a new wrapped line after a comment in a decorator when it's the
36 first token in the decorator.
Dan Porter61d88092018-03-22 12:52:16 +000037
Bill Wendling06a23402018-03-18 20:42:05 -070038## [0.21.0] 2018-03-18
Patryk Zawadzki6d79f132018-02-13 16:31:25 +010039### Added
40- Introduce a new option of formatting multiline literals. Add
41 `SPLIT_BEFORE_CLOSING_BRACKET` knob to control whether closing bracket should
42 get their own line.
Yinyin La56072f2018-03-05 02:04:34 +080043- Added `CONTINUATION_ALIGN_STYLE` knob to choose continuation alignment style
44 when `USE_TABS` is enabled.
Markus Gerstel52ca45a2018-02-14 17:07:35 +000045- Add 'BLANK_LINES_AROUND_TOP_LEVEL_DEFINITION' knob to control the number
46 of blank lines between top-level function and class definitions.
Bill Wendling338c1c42018-03-14 23:59:49 -070047### Fixed
48- Don't split ellipses.
Patryk Zawadzki6d79f132018-02-13 16:31:25 +010049
Bill Wendling6e83cf32018-02-12 13:22:47 -080050## [0.20.2] 2018-02-12
Bill Wendling9e3dc4e2018-01-24 11:19:24 -080051### Changed
52- Improve the speed at which files are excluded by ignoring them earlier.
Bill Wendling6ae096b2018-01-25 22:22:31 -080053- Allow dictionaries to stay on a single line if they only have one entry
Bill Wendlingd3775492018-01-14 17:43:10 -080054### Fixed
55- Use tabs when constructing a continuation line when `USE_TABS` is enabled.
Bill Wendling7c316cc2018-01-24 12:35:26 -080056- A dictionary entry may not end in a colon, but may be an "unpacking"
57 operation: `**foo`. Take that into accound and don't split after the
58 unpacking operator.
Bill Wendlingd3775492018-01-14 17:43:10 -080059
Bill Wendling06c973f2018-01-13 22:04:00 -080060## [0.20.1] 2018-01-13
Bill Wendlinga0de11a2017-12-17 23:58:02 -080061### Fixed
62- Don't treat 'None' as a keyword if calling a function on it, like '__ne__()'.
Petter Strandmark4d2bee02018-01-10 21:42:37 +010063- use_tabs=True always uses a single tab per indentation level; spaces are
64 used for aligning vertically after that.
Bill Wendling06c973f2018-01-13 22:04:00 -080065- Relax the split of a paren at the end of an if statement. With
delirious-lettuceb795f6d2018-01-16 20:38:46 -070066 `dedent_closing_brackets` option requires that it be able to split there.
Bill Wendlinga0de11a2017-12-17 23:58:02 -080067
Bill Wendling0b8364e2017-11-14 23:45:50 -080068## [0.20.0] 2017-11-14
Matthew Suozzof0211052017-11-01 17:52:28 -040069### Added
70- Improve splitting of comprehensions and generators. Add
71 `SPLIT_PENALTY_COMPREHENSION` knob to control preference for keeping
72 comprehensions on a single line and `SPLIT_COMPLEX_COMPREHENSION` to enable
73 splitting each clause of complex comprehensions onto its own line.
Bill Wendling8c07cc12017-10-16 00:37:58 -070074### Changed
75- Take into account a named function argument when determining if we should
76 split before the first argument in a function call.
Bill Wendling1dc75ac2017-10-16 02:45:46 -070077- Split before the first argument in a function call if the arguments contain a
78 dictionary that doesn't fit on a single line.
Bill Wendlingb1c7ca82017-10-21 00:02:49 -070079- Improve splitting of elements in a tuple. We want to split if there's a
80 function call in the tuple that doesn't fit on the line.
Bill Wendling7bfc0a92017-10-16 03:22:19 -070081### Fixed
82- Enforce spaces between ellipses and keywords.
Bill Wendlingbd9d9552017-10-16 22:45:17 -070083- When calculating the split penalty for a "trailer", process the child nodes
84 afterwards because their penalties may change. For example if a list
85 comprehension is an argument.
Bill Wendlingd404b702017-10-16 23:16:14 -070086- Don't enforce a split before a comment after the opening of a container if it
87 doesn't it on the current line. We try hard not to move such comments around.
Bill Wendlingca46e862017-10-24 00:46:11 -070088- Use a TextIOWrapper when reading from stdin in Python3. This is necessary for
89 some encodings, like cp936, used on Windows.
Matthew Suozzo2112ad22017-10-29 18:23:03 -040090- Remove the penalty for a split before the first argument in a function call
91 where the only argument is a generator expression.
Bill Wendling8c07cc12017-10-16 00:37:58 -070092
Bill Wendling4d9b9052017-10-14 15:02:31 -070093## [0.19.0] 2017-10-14
Bill Wendling9680f732017-10-09 01:11:38 -070094### Added
95- Added `SPLIT_BEFORE_EXPRESSION_AFTER_OPENING_PAREN` that enforces a split
96 after the opening paren of an expression that's surrounded by parens.
Bill Wendling5f83cfb2017-10-08 01:12:27 -070097### Changed
98- Split before the ending bracket of a comma-terminated tuple / argument list
99 if it's not a single element tuple / arg list.
Bill Wendlingba55eb12017-09-19 14:30:02 -0700100### Fixed
101- Prefer to split after a comma in an argument list rather than in the middle
102 of an argument.
Bill Wendling61f93c32017-10-01 00:35:30 -0700103- A non-multiline string may have newlines if it contains continuation markers
104 itself. Don't add a newline after the string when retaining the vertical
105 space.
Bill Wendling9df211b2017-10-01 01:12:22 -0700106- Take into account the "async" keyword when determining if we must split
107 before the first argument.
Bill Wendling74911872017-10-04 02:59:30 -0700108- Increase affinity for "atom" arguments in function calls. This helps prevent
109 lists from being separated when they don't need to be.
Bill Wendlingb00e4f62017-10-07 03:22:12 -0700110- Don't place a dictionary argument on its own line if it's the last argument
111 in the function call where that function is part of a builder-style call.
Bill Wendlinga531f212017-10-12 15:58:29 -0700112- Append the "var arg" type to a star in a star_expr.
Bill Wendlingba55eb12017-09-19 14:30:02 -0700113
Bill Wendling7ef7e142017-09-18 16:59:48 -0700114## [0.18.0] 2017-09-18
Bill Wendling8a3b71f2017-08-26 02:34:03 -0700115### Added
116- Option `ALLOW_SPLIT_BEFORE_DICT_VALUE` allows a split before a value. If
117 False, then it won't be split even if it goes over the column limit.
Bill Wendling855860e2017-08-24 21:31:33 -0700118### Changed
119- Use spaces around the '=' in a typed name argument to align with 3.6 syntax.
Bill Wendling8012f592017-08-21 01:23:18 -0700120### Fixed
121- Allow semicolons if the line is disabled.
Bouwe Andelaf6dba622017-08-21 21:33:23 +0200122- Fix issue where subsequent comments at decreasing levels of indentation
123 were improperly aligned and/or caused output with invalid syntax.
Bill Wendling562e04c2017-08-23 02:32:11 -0700124- Fix issue where specifying a line range removed a needed line before a
125 comment.
Bill Wendling6e7f5a82017-08-24 20:15:08 -0700126- Fix spacing between unary operators if one is 'not'.
Bill Wendling578854b2017-08-24 22:26:59 -0700127- Indent the dictionary value correctly if there's a multi-line key.
Bill Wendling8ee1b532017-09-06 13:58:32 -0700128- Don't remove needed spacing before a comment in a dict when in "chromium"
129 style.
Bill Wendling6412ce72017-09-18 16:18:48 -0700130- Increase indent for continuation line with same indent as next logical line
131 with 'async with' statement.
Bill Wendling8012f592017-08-21 01:23:18 -0700132
Bill Wendling5f737202017-08-20 22:03:12 -0700133## [0.17.0] 2017-08-20
Jiri Kuncarf14bd172017-07-21 09:45:31 +0200134### Added
135- Option `NO_SPACES_AROUND_SELECTED_BINARY_OPERATORS` prevents adding spaces
136 around selected binary operators, in accordance with the current style guide.
Kevin Coxc565e832017-07-21 13:50:47 +0100137### Changed
138- Adjust blank lines on formatting boundaries when using the `--lines` option.
Bill Wendling71d9b2e2017-08-01 13:38:54 -0700139- Return 1 if a diff changed the code. This is in line with how GNU diff acts.
Max Vorobev3b903112017-08-26 14:43:48 +0300140- Add `-vv` flag to print out file names as they are processed
Richard Wallacad4ce2017-08-04 15:08:40 +0100141### Fixed
142- Corrected how `DEDENT_CLOSING_BRACKETS` and `COALESCE_BRACKETS` interacted.
Bill Wendlingb0de56d2017-08-12 15:21:12 -0700143- Fix return value to return a boolean.
Anton Yuzhaninovdb85e872017-07-19 22:45:45 -0400144- Correct vim plugin not to clobber edited code if yapf returns an error.
Justin Huang767edac2017-08-12 17:36:41 -0700145- Ensured comma-terminated tuples with multiple elements are split onto separate lines.
Kevin Coxc565e832017-07-21 13:50:47 +0100146
Bill Wendling4aa43d82017-07-13 00:45:39 -0700147## [0.16.3] 2017-07-13
Bill Wendling81a6d842017-07-12 23:58:17 -0700148### Changed
delirious-lettuceb795f6d2018-01-16 20:38:46 -0700149- Add filename information to a ParseError exception.
Bill Wendling77ca21d2017-03-28 00:41:18 -0700150### Fixed
Bill Wendling4aa43d82017-07-13 00:45:39 -0700151- A token that ends in a continuation marker may have more than one newline in
152 it, thus changing its "lineno" value. This can happen if multiple
153 continuation markers are used with no intervening tokens. Adjust the line
154 number to account for the lines covered by those markers.
155- Make sure to split after a comment even for "pseudo" parentheses.
156
157## [0.16.2] 2017-05-19
158### Fixed
Bill Wendling77ca21d2017-03-28 00:41:18 -0700159- Treat expansion operators ('*', '**') in a similar way to function calls to
160 avoid splitting directly after the opening parenthesis.
161- Increase the penalty for splitting after the start of a tuple.
Bill Wendlinge67e3532017-03-31 00:43:00 -0700162- Increase penalty for excess characters.
Bill Wendling16becc52017-04-02 19:52:49 -0700163- Check that we have enough children before trying to access them all.
Bill Wendlingda3697c2017-04-13 00:32:09 -0700164- Remove trailing whitespaces from comments.
Bill Wendlinga36bb6d2017-04-16 18:51:53 -0700165- Split before a function call in a list if the full list isn't able to fit on
166 a single line.
Bill Wendling1cfcbd12017-04-17 19:38:28 -0700167- Trying not to split around the '=' of a named assign.
Bill Wendling81a6d842017-07-12 23:58:17 -0700168- Changed split before the first argument behavior to ignore compound
169 statements like if and while, but not function declarations.
170- Changed coalesce brackets not to line split before closing bracket.
Bill Wendling77ca21d2017-03-28 00:41:18 -0700171
Bill Wendling5ca31092017-03-22 11:41:07 -0700172## [0.16.1] 2017-03-22
Bill Wendling5a1e3312017-02-14 18:40:43 -0800173### Changed
174- Improved performance of cloning the format decision state object. This
175 improved the time in one *large* case from 273.485s to 234.652s.
Bill Wendlingc2f520c2017-02-15 22:03:18 -0800176- Relax the requirement that a named argument needs to be on one line. Going
177 over the column limit is more of an issue to pylint than putting named args
178 on multiple lines.
Bill Wendling79b82ef2017-02-17 00:24:51 -0800179- Don't make splitting penalty decisions based on the original formatting. This
180 can and does lead to non-stable formatting, where yapf will reformat the same
181 code in different ways.
Bill Wendlinga9529662017-02-06 21:47:39 -0800182### Fixed
183- Ensure splitting of arguments if there's a named assign present.
Bill Wendling56f0fb62017-02-06 22:58:05 -0800184- Prefer to coalesce opening brackets if it's not at the beginning of a
185 function call.
Bill Wendling313c65a2017-02-17 01:56:45 -0800186- Prefer not to squish all of the elements in a function call over to the
187 right-hand side. Split the arguments instead.
Bill Wendling257c1b02017-02-20 15:32:29 -0800188- We need to split a dictionary value if the first element is a comment anyway,
189 so don't force the split here. It's forced elsewhere.
CaselITd69801d2017-02-21 13:45:13 +0100190- Ensure tabs are used for continued indentation when USE_TABS is True.
Bill Wendlinga9529662017-02-06 21:47:39 -0800191
Bill Wendling873039e2017-02-05 20:24:46 -0800192## [0.16.0] 2017-02-05
Bill Wendling0e9b3212017-01-31 14:41:00 -0800193### Added
194- The `EACH_DICT_ENTRY_ON_SEPARATE_LINE` knob indicates that each dictionary
195 entry should be in separate lines if the full dictionary isn't able to fit on
196 a single line.
197- The `SPLIT_BEFORE_DICT_SET_GENERATOR` knob splits before the `for` part of a
198 dictionary/set generator.
Bill Wendling9f497522017-02-04 04:39:47 -0800199- The `BLANK_LINE_BEFORE_CLASS_DOCSTRING` knob adds a blank line before a
200 class's docstring.
Bill Wendling8d321362017-02-05 18:29:26 -0800201- The `ALLOW_MULTILINE_DICTIONARY_KEYS` knob allows dictionary keys to span
202 more than one line.
Bill Wendling94962e52017-02-04 04:07:19 -0800203### Fixed
204- Split before all entries in a dict/set or list maker when comma-terminated,
205 even if there's only one entry.
Adrian Tejn Kernbfee67d2017-02-05 08:36:02 +0100206- Will now try to set O_BINARY mode on stdout under Windows and Python 2.
207- Avoid unneeded newline transformation when writing formatted code to
208 output on (affects only Python 2)
Bill Wendling0e9b3212017-01-31 14:41:00 -0800209
Bill Wendling3d470dd2017-01-29 19:45:13 -0800210## [0.15.2] 2017-01-29
Bill Wendlingbf631182017-01-24 15:34:35 -0800211### Fixed
212- Don't perform a global split when a named assign is part of a function call
213 which itself is an argument to a function call. I.e., don't cause 'a' to
214 split here:
215
216 func(a, b, c, d(x, y, z=42))
Bill Wendlingb64e7022017-01-25 09:44:41 -0800217- Allow splitting inside a subscript if it's a logical or bitwise operating.
218 This should keep the subscript mostly contiguous otherwise.
Bill Wendlingbf631182017-01-24 15:34:35 -0800219
Bill Wendling5d7b3612017-01-21 23:43:35 -0800220## [0.15.1] 2017-01-21
Bill Wendling672ece02017-01-14 16:35:48 -0800221### Fixed
222- Don't insert a space between a type hint and the '=' sign.
Bill Wendlingb57e71c2017-01-14 16:51:35 -0800223- The '@' operator can be used in Python 3 for matrix multiplication. Give the
224 '@' in the decorator a DECORATOR subtype to distinguish it.
Bill Wendlingfd30b912017-01-15 16:45:24 -0800225- Encourage the formatter to split at the beginning of an argument list instead
226 of in the middle. Especially if the middle is an empty parameter list. This
227 adjusts the affinity of binary and comparison operators. In particular, the
228 "not in" and other such operators don't want to have a split after it (or
229 before it) if at all possible.
Bill Wendling672ece02017-01-14 16:35:48 -0800230
Bill Wendling61061f62017-01-12 20:58:55 -0800231## [0.15.0] 2017-01-12
232### Added
233- Keep type annotations intact as much as possible. Don't try to split the over
delirious-lettuceb795f6d2018-01-16 20:38:46 -0700234 multiple lines.
Bill Wendlingb50a6b22016-11-27 17:06:58 -0800235### Fixed
236- When determining if each element in a dictionary can fit on a single line, we
237 are skipping dictionary entries. However, we need to ignore comments in our
238 calculations and implicitly concatenated strings, which are already placed on
239 separate lines.
Bill Wendling596300d2016-11-28 13:08:57 -0800240- Allow text before a "pylint" comment.
Bill Wendlingeb979f32016-11-28 13:16:04 -0800241- Also allow text before a "yapf: (disable|enable)" comment.
Bill Wendlingb50a6b22016-11-27 17:06:58 -0800242
Bill Wendling544a2812016-11-21 15:29:19 -0800243## [0.14.0] 2016-11-21
Bill Wendling61061f62017-01-12 20:58:55 -0800244### Added
Diogo de Campos2f246c02016-10-06 14:04:38 +0200245- formatting can be run in parallel using the "-p" / "--parallel" flags.
Bill Wendling6041f222016-11-02 01:07:39 -0700246### Fixed
247- "not in" and "is not" should be subtyped as binary operators.
Bill Wendlingccea10e2016-11-08 16:26:21 -0800248- A non-Node dictionary value may have a comment before it. In those cases, we
249 want to avoid encompassing only the comment in pseudo parens. So we include
250 the actual value as well.
Bill Wendlingf7286532016-11-16 17:52:50 -0800251- Adjust calculation so that pseudo-parentheses don't count towards the total
252 line length.
Bill Wendling508694b2016-11-20 23:52:52 -0800253- Don't count a dictionary entry as not fitting on a single line in a
254 dictionary.
Bill Wendling47c3e4f2016-11-21 15:25:09 -0800255- Don't count pseudo-parentheses in the length of the line.
Bill Wendling6041f222016-11-02 01:07:39 -0700256
Bill Wendling35d6b7c2016-10-22 01:18:51 -0700257## [0.13.2] 2016-10-22
258### Fixed
259- REGRESSION: A comment may have a prefix with newlines in it. When calculating
260 the prefix indent, we cannot take the newlines into account. Otherwise, the
261 comment will be misplaced causing the code to fail.
262
Bill Wendlingf3e09652016-10-17 14:26:41 -0700263## [0.13.1] 2016-10-17
264### Fixed
265- Correct emitting a diff that was accidentally removed.
266
Bill Wendling31f82132016-10-16 22:54:01 -0700267## [0.13.0] 2016-10-16
Bill Wendlingcec6b192016-10-16 00:30:02 -0500268### Added
269- Added support to retain the original line endings of the source code.
270
Bill Wendlinga5a52e22016-10-11 13:40:38 -0700271### Fixed
272- Functions or classes with comments before them were reformatting the comments
273 even if the code was supposed to be ignored by the formatter. We now don't
274 adjust the whitespace before a function's comment if the comment is a
275 "disabled" line. We also don't count "# yapf: {disable|enable}" as a disabled
276 line, which seems logical.
Bill Wendlinge6c93572016-10-11 20:26:23 -0700277- It's not really more readable to split before a dictionary value if it's part
278 of a dictionary comprehension.
Bill Wendling556f9152016-10-13 01:27:38 -0700279- Enforce two blank lines after a function or class definition, even before a
Bill Wendling7cc4d182016-10-13 11:26:26 -0700280 comment. (But not between a decorator and a comment.) This is related to PEP8
281 error E305.
Bill Wendling0d372eb2016-10-14 00:36:21 -0700282- Remove O(n^2) algorithm from the line disabling logic.
Bill Wendlinga5a52e22016-10-11 13:40:38 -0700283
Bill Wendlingc2620f92016-10-09 20:40:15 -0700284## [0.12.2] 2016-10-09
Bill Wendling293cb6c2016-10-02 16:46:11 -0700285### Fixed
286- If `style.SetGlobalStyle(<create pre-defined style>)` was called and then
287 `yapf_api.FormatCode` was called, the style set by the first call would be
288 lost, because it would return the style created by `DEFAULT_STYLE_FACTORY`,
289 which is set to PEP8 by default. Fix this by making the first call set which
290 factory we call as the "default" style.
Bill Wendling85b5a632016-10-03 20:30:43 -0700291- Don't force a split before non-function call arguments.
Bill Wendling261c79a2016-10-03 20:58:08 -0700292- A dictionary being used as an argument to a function call and which can exist
293 on a single line shouldn't be split.
Bill Wendling35edcbd2016-10-03 22:33:34 -0700294- Don't rely upon the original line break to determine if we should split
Bill Wendlingc18abac2016-10-03 22:49:52 -0700295 before the elements in a container. Especially split if there's a comment in
296 the container.
Bill Wendling690132a2016-10-04 22:55:47 -0700297- Don't add spaces between star and args in a lambda expression.
Bill Wendlingeef8fbd2016-10-05 00:34:25 -0700298- If a nested data structure terminates in a comma, then split before the first
299 element, but only if there's more than one element in the list.
Bill Wendling293cb6c2016-10-02 16:46:11 -0700300
301## [0.12.1] 2016-10-02
Bill Wendling1960ffc2016-10-01 23:57:05 -0700302### Changed
303- Dictionary values will be placed on the same line as the key if *all* of the
304 elements in the dictionary can be placed on one line. Otherwise, the
305 dictionary values will be placed on the next line.
306
Bill Wendlinge0412442016-09-28 02:19:31 -0700307### Fixed
308- Prefer to split before a terminating r-paren in an argument list if the line
309 would otherwise go over the column limit.
Bill Wendling21836ef2016-09-28 19:13:16 -0700310- Split before the first key in a dictionary if the dictionary cannot fit on a
311 single line.
Bill Wendling61997072016-09-30 00:45:59 -0700312- Don't count "pylint" comments when determining if the line goes over the
313 column limit.
Bill Wendling0e703572016-10-01 23:02:32 -0700314- Don't count the argument list of a lambda as a named assign in a function
315 call.
Bill Wendlinge0412442016-09-28 02:19:31 -0700316
Bill Wendling1b919632016-09-25 16:03:04 -0700317## [0.12.0] 2016-09-25
Bill Wendling90eab552016-08-19 23:47:23 -0700318### Added
319- Support formatting of typed names. Typed names are formatted a similar way to
320 how named arguments are formatted, except that there's a space after the
321 colon.
Alexander Lenz5fda36a2016-08-26 17:27:57 +0200322- Add a knob, 'SPACES_AROUND_DEFAULT_OR_NAMED_ASSIGN', to allow adding spaces
323 around the assign operator on default or named assigns.
Bill Wendling90eab552016-08-19 23:47:23 -0700324
Bill Wendling7c7f6032016-08-31 10:46:33 -0700325## Changed
326- Turn "verification" off by default for external APIs.
Bill Wendlingf0dd0a42016-09-25 15:54:02 -0700327- If a function call in an argument list won't fit on the current line but will
328 fit on a line by itself, then split before the call so that it won't be split
329 up unnecessarily.
Bill Wendling7c7f6032016-08-31 10:46:33 -0700330
Bill Wendlinga6fb6f72016-09-17 14:39:26 -0700331## Fixed
332- Don't add space after power operator if the next operator's a unary operator.
333
Bill Wendling79ee44a2016-08-17 00:33:02 -0700334## [0.11.1] 2016-08-17
Bill Wendling7b87b0a2016-08-17 00:01:56 -0700335### Changed
336- Issue #228: Return exit code 0 on success, regardless of whether files were
337 changed. (Previously, 0 meant success with no files
338 modified, and 2 meant success with at least one file modified.)
339
Bill Wendlingf4de4c62016-07-21 00:08:29 -0700340### Fixed
341- Enforce splitting each element in a dictionary if comma terminated.
Bill Wendlingb8d20bd2016-08-05 23:44:23 -0700342- It's okay to split in the middle of a dotted name if the whole expression is
343 going to go over the column limit.
Bill Wendling15edda22016-08-15 17:04:26 -0700344- Asynchronous functions were going missing if they were preceded by a comment
345 (a what? exactly). The asynchronous function processing wasn't taking the
346 comment into account and thus skipping the whole function.
Bill Wendling7b87b0a2016-08-17 00:01:56 -0700347- The splitting of arguments when comma terminated had a conflict. The split
348 penalty of the closing bracket was set to the maximum, but it shouldn't be if
349 the closing bracket is preceded by a comma.
Reece Hart039c0b52016-08-11 13:46:15 -0700350
Bill Wendling1d8638e2016-07-17 00:06:01 -0700351## [0.11.0] 2016-07-17
Ben Plotnick7e088292016-06-09 18:29:56 -0700352### Added
353- The COALESCE_BRACKETS knob prevents splitting consecutive brackets when
354 DEDENT_CLOSING_BRACKETS is set.
Bill Wendling61e80c02016-07-14 16:50:10 -0700355- Don't count "pylint" directives as exceeding the column limit.
Ben Plotnick7e088292016-06-09 18:29:56 -0700356
Bill Wendling33636712016-07-16 02:49:28 -0700357### Changed
358- We split all of the arguments to a function call if there's a named argument.
Bill Wendling2df29282016-07-16 17:23:41 -0700359 In this case, we want to split after the opening bracket too. This makes
Bill Wendling33636712016-07-16 02:49:28 -0700360 things look a bit better.
361
Bill Wendling4761b182016-07-03 00:11:14 -0700362### Fixed
363- When retaining format of a multiline string with Chromium style, make sure
364 that the multiline string doesn't mess up where the following comma ends up.
Bill Wendling821a36f2016-07-13 23:02:16 -0700365- Correct for when 'lib2to3' smooshes comments together into the same DEDENT
366 node.
Bill Wendling4761b182016-07-03 00:11:14 -0700367
Bill Wendling7521d4b2016-06-14 01:35:38 -0700368## [0.10.0] 2016-06-14
Draconye582d632016-06-05 11:48:26 +0200369### Added
370- Add a knob, 'USE_TABS', to allow using tabs for indentation.
Bill Wendling184c2de2016-06-13 03:21:04 -0700371
Bill Wendlingb0285ba2016-05-31 16:10:59 -0700372### Changed
373- Performance enhancements.
374
Draconye582d632016-06-05 11:48:26 +0200375### Fixed
Bill Wendlingd02b5922016-06-03 23:48:19 -0700376- Don't split an import list if it's not surrounded by parentheses.
377
Bill Wendling90f361f2016-05-29 16:13:10 -0700378## [0.9.0] 2016-05-29
Bill Wendlinga6988c32016-05-22 18:47:11 -0700379### Added
Bill Wendling1e161592016-05-23 16:34:03 -0700380- Added a knob (SPLIT_PENALTY_BEFORE_IF_EXPR) to adjust the split penalty
381 before an if expression. This allows the user to place a list comprehension
382 all on one line.
383- Added a knob (SPLIT_BEFORE_FIRST_ARGUMENT) that encourages splitting before
384 the first element of a list of arguments or parameters if they are going to
385 be split anyway.
Bill Wendling86e51782016-05-24 00:47:44 -0700386- Added a knob (SPLIT_ARGUMENTS_WHEN_COMMA_TERMINATED) splits arguments to a
387 function if the list is terminated by a comma.
Bill Wendlinga6988c32016-05-22 18:47:11 -0700388
Bill Wendling7edb3842016-05-21 15:07:54 -0700389### Fixed
390- Don't split before a first element list argument as we would before a first
391 element function call.
Bill Wendlinge8a85692016-05-21 23:57:20 -0700392- Don't penalize when we must split a line.
Bill Wendling283f4ea2016-05-23 16:19:15 -0700393- Allow splitting before the single argument in a function call.
Bill Wendling7edb3842016-05-21 15:07:54 -0700394
Bill Wendlingd2a585d2016-05-21 00:41:24 -0700395## [0.8.2] 2016-05-21
Bill Wendling72cd2342016-05-19 01:28:58 -0700396### Fixed
397- Prefer not to split after the opening of a subscript.
Bill Wendling1e179bb2016-05-19 01:51:34 -0700398- Don't add space before the 'await' keyword if it's preceded by an opening
399 paren.
Bill Wendling4b6cead2016-05-19 11:33:38 -0700400- When we're setting the split penalty for a continuous list, we don't want to
401 mistake a comment at the end of that list as part of the list.
Bill Wendlingda6ab272016-05-19 21:45:34 -0700402- When calculating blank lines, don't assume the last seen object was a class
403 or function when we're in a class or function.
Bill Wendlingf61861d2016-05-21 00:36:27 -0700404- Don't count the closing scope when determining if the current scope is the
405 last scope on the line.
Bill Wendling72cd2342016-05-19 01:28:58 -0700406
Bill Wendlingde2c5b22016-05-18 21:10:29 -0700407## [0.8.1] 2016-05-18
Bill Wendling8f1d1402016-05-14 19:22:48 -0700408### Fixed
409- 'SPLIT_BEFORE_LOGICAL_OPERATOR' wasn't working correctly. The penalty was
410 being set incorrectly when it was part of a larger construct.
Bill Wendling99cbd562016-05-15 18:41:12 -0700411- Don't separate a keyword, like "await", from a left paren.
Bill Wendling311c0872016-05-18 01:51:12 -0700412- Don't rely upon the original tokens' line number to determine if we should
413 perform splitting in Facebook mode. The line number isn't the line number of
414 the reformatted token, but the line number where it was in the original code.
415 Instead, we need to carefully determine if the line is liabel to be split and
416 act accordingly.
Bill Wendling8f1d1402016-05-14 19:22:48 -0700417
Bill Wendlingfe7a4ac2016-05-10 23:51:57 -0700418## [0.8.0] 2016-05-10
Bill Wendling9dc79082016-05-10 00:23:53 -0700419### Added
Bill Wendling43eaa752016-05-12 01:25:20 -0700420- Add a knob, 'SPACES_AROUND_POWER_OPERATOR', to allow adding spaces around the
421 power operator.
Bill Wendling9dc79082016-05-10 00:23:53 -0700422
Bill Wendlingf015a3c2016-04-21 20:14:24 -0700423### Fixed
424- There shouldn't be a space between a decorator and an intervening comment.
Bill Wendling3e15d002016-04-28 00:16:32 -0700425- If we split before a bitwise operator, then we assume that the programmer
426 knows what they're doing, more or less, and so we enforce a split before said
427 operator if one exists in the original program.
Bill Wendlingadf1d442016-05-10 01:03:50 -0700428- Strengthen the bond between a keyword and value argument.
Bill Wendling93c42d92016-05-10 23:35:57 -0700429- Don't add a blank line after a multiline string.
Bill Wendlingcae1edd2016-05-10 23:49:19 -0700430- If the "for" part of a list comprehension can exist on the starting line
431 without going over the column limit, then let it remain there.
Bill Wendlingf015a3c2016-04-21 20:14:24 -0700432
Bill Wendling8d36eb82016-04-21 02:33:36 -0700433## [0.7.1] 2016-04-21
Bill Wendling4dc472d2016-04-10 03:03:55 -0700434### Fixed
435- Don't rewrite the file if there are no changes.
Bill Wendlingac00a252016-04-12 05:31:03 -0700436- Ensure the proper number of blank lines before an async function.
Bill Wendlingc4a49652016-04-13 13:42:43 -0700437- Split after a bitwise operator when in PEP 8 mode.
Bill Wendling423759f2016-04-14 21:14:20 -0700438- Retain the splitting within a dictionary data literal between the key and
439 value.
Bill Wendling9882f3d2016-04-21 02:29:35 -0700440- Try to keep short function calls all on one line even if they're part of a
441 larger series of tokens. This stops us from splitting too much.
Bill Wendling4dc472d2016-04-10 03:03:55 -0700442
Bill Wendlingdefe5f32016-04-09 22:29:51 -0700443## [0.7.0] 2016-04-09
Bill Wendling2e588512016-03-13 01:02:47 -0800444### Added
Bill Wendling5758e4d2016-03-19 03:38:48 -0700445- Support for Python 3.5.
446- Add 'ALLOW_MULTILINE_LAMBDAS' which allows lambdas to be formatted onto
447 multiple lines.
Bill Wendling2e588512016-03-13 01:02:47 -0800448
449### Fixed
450- Lessen penalty for splitting before a dictionary keyword.
Bill Wendling90a2aa52016-03-20 02:25:13 -0700451- Formatting of trailing comments on disabled formatting lines.
Bill Wendling2064d882016-04-09 22:21:15 -0700452- Disable / enable formatting at end of multi-line comment.
Bill Wendling2e588512016-03-13 01:02:47 -0800453
Bill Wendling0bca2aa2016-03-06 20:44:14 -0800454## [0.6.3] 2016-03-06
455### Changed
456- Documentation updated.
457
Bill Wendling95e47b92015-11-04 22:58:30 -0800458### Fixed
459- Fix spacing of multiline comments when formatting is disabled.
460
Bill Wendling9ffd8152015-11-01 17:49:25 -0800461## [0.6.2] 2015-11-01
Bill Wendling6e8ca7b2015-10-25 01:16:43 -0700462### Changed
463- Look at the 'setup.cfg' file to see if it contains style information for
464 YAPF.
Bill Wendling169790e2015-10-25 03:13:13 -0700465- Look at the '~/.config/yapf/style' file to see if it contains global style
466 information for YAPF.
Bill Wendling6e8ca7b2015-10-25 01:16:43 -0700467
Bill Wendling57ffbbb2015-10-25 00:20:14 -0700468### Fixed
469- Make lists that can fit on one line more likely to stay together.
Bill Wendling5091fa62015-10-28 01:51:53 -0700470- Correct formatting of '*args' and '**kwargs' when there are default values in
471 the argument list.
Bill Wendling57ffbbb2015-10-25 00:20:14 -0700472
Bill Wendling348b2f32015-10-24 03:20:10 -0700473## [0.6.1] 2015-10-24
Bill Wendling3a3cb6d2015-10-20 13:40:27 -0700474### Fixed
475- Make sure to align comments in data literals correctly. Also make sure we
476 don't count a "#." in a string as an i18n comment.
Bill Wendlinga6b57a62015-10-20 13:57:52 -0700477- Retain proper vertical spacing before comments in a data literal.
Bill Wendling843e48c2015-10-20 16:53:08 -0700478- Make sure that continuations from a compound statement are distinguished from
479 the succeeding line.
Bill Wendling81e37b62015-10-21 13:18:29 -0700480- Ignore preceding comments when calculating what is a "dictonary maker".
Bill Wendlinga5585722015-10-21 15:32:22 -0700481- Add a small penalty for splitting before a closing bracket.
Bill Wendlingdbcf3422015-10-21 22:11:15 -0700482- Ensure that a space is enforced after we remove a pseudo-paren that's between
483 two names, keywords, numbers, etc.
Bill Wendlingf8856722015-10-21 23:53:29 -0700484- Increase the penalty for splitting after a pseudo-paren. This could lead to
485 less readable code in some circumstances.
Bill Wendling3a3cb6d2015-10-20 13:40:27 -0700486
Bill Wendling7ef492b2015-10-18 14:43:06 -0700487## [0.6.0] 2015-10-18
Bill Wendlinga5cef8e2015-10-15 21:42:03 -0700488### Added
489- Add knob to indent the dictionary value if there is a split before it.
490
Bill Wendlingcec66962015-10-17 04:08:23 -0700491### Changed
492- No longer check that a file is a "Python" file unless the '--recursive' flag
493 is specified.
494- No longer allow the user to specify a directory unless the '--recursive' flag
495 is specified.
496
Bill Wendlingc87690c2015-10-11 16:45:21 -0700497### Fixed
498- When determining if we should split a dictionary's value to a new line, use
499 the longest entry instead of the total dictionary's length. This allows the
500 formatter to reformat the dictionary in a more consistent manner.
Bill Wendling0946c0f2015-10-12 00:42:30 -0700501- Improve how list comprehensions are formatted. Make splitting dependent upon
502 whether the "comp_for" or "comp_if" goes over the column limit.
Bill Wendling43bdc7b2015-10-12 14:25:30 -0700503- Don't over indent if expression hanging indents if we expect to dedent the
504 closing bracket.
Bill Wendlingc1052c62015-10-15 03:12:28 -0700505- Improve splitting heuristic when the first argument to a function call is
506 itself a function call with arguments. In cases like this, the remaining
507 arguments to the function call would look badly aligned, even though they are
508 techincally correct (the best kind of correct!).
Bill Wendlingb1037b52015-10-15 22:38:19 -0700509- Improve splitting heuristic more so that if the first argument to a function
510 call is a data literal that will go over the column limit, then we want to
511 split before it.
Bill Wendling8d8f5122015-10-16 11:46:23 -0700512- Remove spaces around '**' operator.
Bill Wendlingf8325e62015-10-16 15:38:54 -0700513- Retain formatting of comments in the middle of an expression.
Bill Wendling454cef62015-10-18 03:49:03 -0700514- Don't add a newline to an empty file.
Bill Wendling7ef492b2015-10-18 14:43:06 -0700515- Over indent a function's parameter list if it's not distinguished from the
516 body of the function.
Bill Wendlingc87690c2015-10-11 16:45:21 -0700517
Bill Wendling2aff7fc2015-10-11 14:08:10 -0700518## [0.5.0] 2015-10-11
Bill Wendlingd03c99f2015-10-08 21:06:07 -0700519### Added
520- Add option to exclude files/directories from formatting.
Bill Wendling5c608732015-10-10 23:39:16 -0700521- Add a knob to control whether import names are split after the first '('.
Bill Wendlingd03c99f2015-10-08 21:06:07 -0700522
Bill Wendlinga7e3f502015-10-08 00:23:40 -0700523### Fixed
524- Indent the continuation of an if-then statement when it's not distinguished
525 from the body of the if-then.
Bill Wendling1ce18c72015-10-10 23:12:16 -0700526- Allow for sensible splitting of array indices where appropriate.
Bill Wendlingbe974d82015-10-11 01:04:00 -0700527- Prefer to not split before the ending bracket of an atom. This produces
528 better code in most cases.
Bill Wendlingbbd148c2015-10-11 01:45:24 -0700529- Corrected how horizontal spaces were presevered in a disabled region.
Bill Wendlinga7e3f502015-10-08 00:23:40 -0700530
Bill Wendling967c3b22015-10-07 22:20:18 -0700531## [0.4.0] 2015-10-07
Ɓukasz Langa94089872015-09-22 16:02:26 -0700532### Added
533- Support for dedenting closing brackets, "facebook" style.
534
Bill Wendling25c8e602015-10-04 20:48:35 -0700535### Fixed
536- Formatting of tokens after a multiline string didn't retain their horizontal
537 spacing.
538
Bill Wendling06865ab2015-09-30 01:25:47 -0700539## [0.3.1] 2015-09-30
540### Fixed
541- Format closing scope bracket correctly when indentation size changes.
542
Bill Wendlinga690a622015-09-20 12:38:50 -0700543## [0.3.0] 2015-09-20
544### Added
545- Return a 2 if the source changed, 1 on error, and 0 for no change.
546
547### Fixed
548- Make sure we format if the "lines" specified are in the middle of a
549 statement.
550
Bill Wendling9adfa0c2015-09-13 05:37:30 -0700551## [0.2.9] - 2015-09-13
552### Fixed
553- Formatting of multiple files. It was halting after formatting the first file.
554
Bill Wendlingdcafd5f2015-09-12 15:26:03 -0700555## [0.2.8] - 2015-09-12
556### Added
557- Return a non-zero exit code if the source was changed.
558- Add bitwise operator splitting penalty and prefer to split before bitwise
559 operators.
560
561### Fixed
562- Retain vertical spacing between disabled and enabled lines.
563- Split only at start of named assign.
564- Retain comment position when formatting is disabled.
565- Honor splitting before or after logical ops.