From 2c1b0f75cc2463eaab19c33cdb7a18f4eb783bae Mon Sep 17 00:00:00 2001 From: hauntsaninja Date: Thu, 28 Dec 2023 00:53:48 -0600 Subject: [PATCH 1/3] Allow empty lines at beginnings of more blocks Fixes #4043, fixes #619 These include nested functions and methods. I think the nested function case quite clearly improves readability. I think the method case improves consistency, adherence to PEP 8 and resolves a point of contention. --- src/black/lines.py | 5 ++++- tests/data/cases/class_blank_parentheses.py | 1 + .../cases/preview_allow_empty_first_line.py | 21 ++++++++++++++++++- tests/data/cases/preview_form_feeds.py | 7 ++++--- 4 files changed, 29 insertions(+), 5 deletions(-) diff --git a/src/black/lines.py b/src/black/lines.py index 8d02267a85b..4d4f47a44e8 100644 --- a/src/black/lines.py +++ b/src/black/lines.py @@ -745,7 +745,10 @@ def _maybe_empty_lines_for_class_or_def( # noqa: C901 if self.previous_line.depth < current_line.depth and ( self.previous_line.is_class or self.previous_line.is_def ): - return 0, 0 + if self.mode.is_pyi or not Preview.allow_empty_first_line_in_block: + return 0, 0 + else: + return 1 if user_had_newline else 0, 0 comment_to_add_newlines: Optional[LinesBlock] = None if ( diff --git a/tests/data/cases/class_blank_parentheses.py b/tests/data/cases/class_blank_parentheses.py index 1a5721a2889..3c460d9bd79 100644 --- a/tests/data/cases/class_blank_parentheses.py +++ b/tests/data/cases/class_blank_parentheses.py @@ -39,6 +39,7 @@ def test_func(self): class ClassWithEmptyFunc(object): + def func_with_blank_parentheses(): return 5 diff --git a/tests/data/cases/preview_allow_empty_first_line.py b/tests/data/cases/preview_allow_empty_first_line.py index 3e14fa15250..5ece2700bdb 100644 --- a/tests/data/cases/preview_allow_empty_first_line.py +++ b/tests/data/cases/preview_allow_empty_first_line.py @@ -22,7 +22,7 @@ def foo(): Long comment here """ a = 123 - + if z: for _ in range(100): @@ -62,6 +62,15 @@ def method(self): pass + +def top_level( + a: int, + b: str, +) -> Whatever[Generic, Something]: + + def nested(x: int) -> int: + pass + # output def foo(): @@ -123,6 +132,16 @@ def quux(): class Cls: + def method(self): pass + + +def top_level( + a: int, + b: str, +) -> Whatever[Generic, Something]: + + def nested(x: int) -> int: + pass diff --git a/tests/data/cases/preview_form_feeds.py b/tests/data/cases/preview_form_feeds.py index c236f177a95..08ba21fc22d 100644 --- a/tests/data/cases/preview_form_feeds.py +++ b/tests/data/cases/preview_form_feeds.py @@ -37,7 +37,7 @@ # # - + # \ @@ -72,7 +72,7 @@ pass pass - + pass @@ -95,7 +95,7 @@ class Baz: def __init__(self): pass - + def something(self): pass @@ -203,6 +203,7 @@ def bar(a=1, b: bool = False): class Baz: + def __init__(self): pass From 8d0de984103e111445e401c9b7e351e7d7c10d54 Mon Sep 17 00:00:00 2001 From: hauntsaninja Date: Thu, 28 Dec 2023 01:01:01 -0600 Subject: [PATCH 2/3] changelog --- CHANGES.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGES.md b/CHANGES.md index a6587cc5ceb..fca88612afe 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -17,6 +17,8 @@ - Format module docstrings the same as class and function docstrings (#4095) - Fix bug where spaces were not added around parenthesized walruses in subscripts, unlike other binary operators (#4109) +- Address a missing case in the change to allow empty lines at the beginning of all + blocks, except immediately before a docstring (#4130) ### Configuration From a34d109adb05dfe5ab05cca1357e8edccff9f5c7 Mon Sep 17 00:00:00 2001 From: hauntsaninja Date: Thu, 28 Dec 2023 01:05:09 -0600 Subject: [PATCH 3/3] restore trailing whitespace --- tests/data/cases/preview_allow_empty_first_line.py | 2 +- tests/data/cases/preview_form_feeds.py | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/tests/data/cases/preview_allow_empty_first_line.py b/tests/data/cases/preview_allow_empty_first_line.py index 5ece2700bdb..daf78344ad7 100644 --- a/tests/data/cases/preview_allow_empty_first_line.py +++ b/tests/data/cases/preview_allow_empty_first_line.py @@ -22,7 +22,7 @@ def foo(): Long comment here """ a = 123 - + if z: for _ in range(100): diff --git a/tests/data/cases/preview_form_feeds.py b/tests/data/cases/preview_form_feeds.py index 08ba21fc22d..dc3bd6cfe2e 100644 --- a/tests/data/cases/preview_form_feeds.py +++ b/tests/data/cases/preview_form_feeds.py @@ -37,7 +37,7 @@ # # - + # \ @@ -72,7 +72,7 @@ pass pass - + pass @@ -95,7 +95,7 @@ class Baz: def __init__(self): pass - + def something(self): pass