]> granicus.if.org Git - python/commitdiff
ast.literal_eval can properly evaluate complex numbers now. This fixes issue4907.
authorArmin Ronacher <armin.ronacher@active-4.com>
Tue, 13 Jan 2009 11:52:23 +0000 (11:52 +0000)
committerArmin Ronacher <armin.ronacher@active-4.com>
Tue, 13 Jan 2009 11:52:23 +0000 (11:52 +0000)
Lib/ast.py
Lib/test/test_ast.py

index 6d92eddddc288b0c6c72540c875feb3ec8ba7000..d778a859ad79d237026bcfbd2762f9e4019b6dd1 100644 (file)
@@ -64,6 +64,18 @@ def literal_eval(node_or_string):
         elif isinstance(node, Name):
             if node.id in _safe_names:
                 return _safe_names[node.id]
+        elif isinstance(node, BinOp) and \
+             isinstance(node.op, (Add, Sub)) and \
+             isinstance(node.right, Num) and \
+             isinstance(node.right.n, complex) and \
+             isinstance(node.left, Num) and \
+             isinstance(node.left.n, (int, long, float)):
+            left = node.left.n
+            right = node.right.n
+            if isinstance(node.op, Add):
+                return left + right
+            else:
+                return left - right
         raise ValueError('malformed string')
     return _convert(node_or_string)
 
index 00a5aae5936d31be86f3fbaa90e3459e42fc406c..994e10be7d88d1958bc78aabe0b0424121860d03 100644 (file)
@@ -271,6 +271,17 @@ class ASTHelpers_Test(unittest.TestCase):
         self.assertEqual(ast.literal_eval('(True, False, None)'), (True, False, None))
         self.assertRaises(ValueError, ast.literal_eval, 'foo()')
 
+    def test_literal_eval_issue4907(self):
+        self.assertEqual(ast.literal_eval('2j'), 2j)
+        self.assertEqual(ast.literal_eval('10 + 2j'), 10 + 2j)
+        self.assertEqual(ast.literal_eval('1.5 - 2j'), 1.5 - 2j)
+        try:
+            ast.literal_eval('2 + (3 + 4j)')
+        except ValueError:
+            pass
+        else:
+            self.fail('expected value error')
+
 
 def test_main():
     test_support.run_unittest(AST_Tests, ASTHelpers_Test)