Commit f8194eae authored by Tom Niget's avatar Tom Niget

Fix literal code emission for containers when empty

parent c162e3ec
...@@ -183,14 +183,22 @@ class ExpressionVisitor(NodeVisitor): ...@@ -183,14 +183,22 @@ class ExpressionVisitor(NodeVisitor):
yield node.attr yield node.attr
def visit_List(self, node: ast.List) -> Iterable[str]: def visit_List(self, node: ast.List) -> Iterable[str]:
if node.elts:
yield "PyList{" yield "PyList{"
yield from join(", ", map(self.reset().visit, node.elts)) yield from join(", ", map(self.reset().visit, node.elts))
yield "}" yield "}"
else:
yield from self.visit(node.type)
yield "{}"
def visit_Set(self, node: ast.Set) -> Iterable[str]: def visit_Set(self, node: ast.Set) -> Iterable[str]:
if node.elts:
yield "PySet{" yield "PySet{"
yield from join(", ", map(self.reset().visit, node.elts)) yield from join(", ", map(self.reset().visit, node.elts))
yield "}" yield "}"
else:
yield from self.visit(node.type)
yield "{}"
def visit_Dict(self, node: ast.Dict) -> Iterable[str]: def visit_Dict(self, node: ast.Dict) -> Iterable[str]:
def visit_item(key, value): def visit_item(key, value):
...@@ -200,9 +208,13 @@ class ExpressionVisitor(NodeVisitor): ...@@ -200,9 +208,13 @@ class ExpressionVisitor(NodeVisitor):
yield from self.reset().visit(value) yield from self.reset().visit(value)
yield "}" yield "}"
if node.keys:
yield "PyDict{" yield "PyDict{"
yield from join(", ", map(visit_item, node.keys, node.values)) yield from join(", ", map(visit_item, node.keys, node.values))
yield "}" yield "}"
else:
yield from self.visit(node.type)
yield "{}"
def visit_Subscript(self, node: ast.Subscript) -> Iterable[str]: def visit_Subscript(self, node: ast.Subscript) -> Iterable[str]:
yield from self.prec("[]").visit(node.value) yield from self.prec("[]").visit(node.value)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment