diff options
| author | Takeshi KOMIYA <i.tkomiya@gmail.com> | 2020-10-04 22:41:44 +0900 | 
|---|---|---|
| committer | Takeshi KOMIYA <i.tkomiya@gmail.com> | 2020-10-04 22:41:44 +0900 | 
| commit | 598b85da75bc533004d68b95a5056016dc16df1c (patch) | |
| tree | e08eae0ea5f098257f01081e4c792bcfeb92eba6 /sphinx/pycode/ast.py | |
| parent | 11633f2e53bf01f6844256558444991836815690 (diff) | |
| parent | 38bb3774643d779b708970f941f2b16d1ab81b89 (diff) | |
| download | sphinx-git-598b85da75bc533004d68b95a5056016dc16df1c.tar.gz | |
Merge branch '3.x' into master
Diffstat (limited to 'sphinx/pycode/ast.py')
| -rw-r--r-- | sphinx/pycode/ast.py | 18 | 
1 files changed, 16 insertions, 2 deletions
| diff --git a/sphinx/pycode/ast.py b/sphinx/pycode/ast.py index 9734cb476..5d95b2abb 100644 --- a/sphinx/pycode/ast.py +++ b/sphinx/pycode/ast.py @@ -183,14 +183,28 @@ class _UnparseVisitor(ast.NodeVisitor):          return "{" + ", ".join(self.visit(e) for e in node.elts) + "}"      def visit_Subscript(self, node: ast.Subscript) -> str: -        return "%s[%s]" % (self.visit(node.value), self.visit(node.slice)) +        def is_simple_tuple(value: ast.AST) -> bool: +            return ( +                isinstance(value, ast.Tuple) and +                bool(value.elts) and +                not any(isinstance(elt, ast.Starred) for elt in value.elts) +            ) + +        if is_simple_tuple(node.slice): +            elts = ", ".join(self.visit(e) for e in node.slice.elts)  # type: ignore +            return "%s[%s]" % (self.visit(node.value), elts) +        elif isinstance(node.slice, ast.Index) and is_simple_tuple(node.slice.value): +            elts = ", ".join(self.visit(e) for e in node.slice.value.elts)  # type: ignore +            return "%s[%s]" % (self.visit(node.value), elts) +        else: +            return "%s[%s]" % (self.visit(node.value), self.visit(node.slice))      def visit_UnaryOp(self, node: ast.UnaryOp) -> str:          return "%s %s" % (self.visit(node.op), self.visit(node.operand))      def visit_Tuple(self, node: ast.Tuple) -> str:          if node.elts: -            return ", ".join(self.visit(e) for e in node.elts) +            return "(" + ", ".join(self.visit(e) for e in node.elts) + ")"          else:              return "()" | 
