]> granicus.if.org Git - python/commitdiff
Teach the peepholer to fold unary operations on constants.
authorRaymond Hettinger <python@rcn.com>
Sun, 20 Feb 2005 12:46:54 +0000 (12:46 +0000)
committerRaymond Hettinger <python@rcn.com>
Sun, 20 Feb 2005 12:46:54 +0000 (12:46 +0000)
Afterwards, -0.5 loads in a single step and no longer requires a runtime
UNARY_NEGATIVE operation.

Lib/test/test_peepholer.py

index 34bd99f2a402cca3c52a63b8796240f6a495d216..4385a84c1fbf255f4c21d36f50e6acabf6c81f1d 100644 (file)
@@ -133,6 +133,25 @@ class TestTranforms(unittest.TestCase):
         asm = dis_single('a="x"*1000')
         self.assert_('(1000)' in asm)
 
+    def test_folding_of_unaryops_on_constants(self):
+        for line, elem in (
+            ('`1`', "('1')"),                       # unary convert
+            ('-0.5', '(-0.5)'),                     # unary negative
+            ('~-2', '(1)'),                         # unary invert
+        ):
+            asm = dis_single(line)
+            self.assert_(elem in asm, asm)
+            self.assert_('UNARY_' not in asm)
+
+        # Verify that unfoldables are skipped
+        for line, elem in (
+            ('-"abc"', "('abc')"),                  # unary negative
+            ('~"abc"', "('abc')"),                  # unary invert
+        ):
+            asm = dis_single(line)
+            self.assert_(elem in asm, asm)
+            self.assert_('UNARY_' in asm)
+
     def test_elim_extra_return(self):
         # RETURN LOAD_CONST None RETURN  -->  RETURN
         def f(x):