From: Brandt Bucher Date: Sat, 29 Jun 2019 16:35:16 +0000 (-0700) Subject: Force parentheses between unary op and binary power. (#909) X-Git-Url: https://git.madduck.net/etc/vim.git/commitdiff_plain/b073c9a4e956f0e350394b7b164cac25801256d7?ds=sidebyside Force parentheses between unary op and binary power. (#909) --- diff --git a/black.py b/black.py index 97393e1..779e9d0 100644 --- a/black.py +++ b/black.py @@ -1643,6 +1643,19 @@ class LineGenerator(Visitor[Line]): node.children[2].value = "" yield from super().visit_default(node) + def visit_factor(self, node: Node) -> Iterator[Line]: + """Force parentheses between a unary op and a binary power: + + -2 ** 8 -> -(2 ** 8) + """ + child = node.children[1] + if child.type == syms.power and len(child.children) == 3: + lpar = Leaf(token.LPAR, "(") + rpar = Leaf(token.RPAR, ")") + index = child.remove() or 0 + node.insert_child(index, Node(syms.atom, [lpar, child, rpar])) + yield from self.visit_default(node) + def visit_INDENT(self, node: Node) -> Iterator[Line]: """Increase indentation level, maybe yield a line.""" # In blib2to3 INDENT never holds comments. diff --git a/tests/data/expression.diff b/tests/data/expression.diff index 9e01f3f..c3ee14d 100644 --- a/tests/data/expression.diff +++ b/tests/data/expression.diff @@ -11,13 +11,15 @@ True False 1 -@@ -29,62 +29,83 @@ +@@ -29,63 +29,84 @@ ~great +value -1 ~int and not v1 ^ 123 + v2 | True (~int) and (not ((v1 ^ (123 + v2)) | True)) +-+really ** -confusing ** ~operator ** -precedence -flags & ~ select.EPOLLIN and waiters.write_task is not None +++(really ** -(confusing ** ~(operator ** -precedence))) +flags & ~select.EPOLLIN and waiters.write_task is not None lambda arg: None lambda a=True: a @@ -116,7 +118,7 @@ call(**self.screen_kwargs) call(b, **self.screen_kwargs) lukasz.langa.pl -@@ -93,23 +114,25 @@ +@@ -94,23 +115,25 @@ 1.0 .real ....__class__ list[str] @@ -147,7 +149,7 @@ slice[0:1:2] slice[:] slice[:-1] -@@ -133,113 +156,171 @@ +@@ -134,113 +157,171 @@ numpy[-(c + 1) :, d] numpy[:, l[-2]] numpy[:, ::-1] diff --git a/tests/data/expression.py b/tests/data/expression.py index a2fc589..912f76d 100644 --- a/tests/data/expression.py +++ b/tests/data/expression.py @@ -31,6 +31,7 @@ not great -1 ~int and not v1 ^ 123 + v2 | True (~int) and (not ((v1 ^ (123 + v2)) | True)) ++really ** -confusing ** ~operator ** -precedence flags & ~ select.EPOLLIN and waiters.write_task is not None lambda arg: None lambda a=True: a @@ -280,6 +281,7 @@ not great -1 ~int and not v1 ^ 123 + v2 | True (~int) and (not ((v1 ^ (123 + v2)) | True)) ++(really ** -(confusing ** ~(operator ** -precedence))) flags & ~select.EPOLLIN and waiters.write_task is not None lambda arg: None lambda a=True: a