]> granicus.if.org Git - python/commitdiff
bpo-33334: Support NOP and EXTENDED_ARG in dis.stack_effect(). (#6566)
authorSerhiy Storchaka <storchaka@gmail.com>
Wed, 25 Apr 2018 19:04:06 +0000 (22:04 +0300)
committerGitHub <noreply@github.com>
Wed, 25 Apr 2018 19:04:06 +0000 (22:04 +0300)
Added tests to ensure that all defined opcodes are supported.

Lib/test/test__opcode.py
Misc/NEWS.d/next/Library/2018-04-22-20-13-21.bpo-33334.19UMOC.rst [new file with mode: 0644]
Python/compile.c

index 1075decc2704207203bb17737316adff4b770970..2af1ee35bff0abb10febe9c0fe68ecd09a1779d3 100644 (file)
@@ -15,6 +15,21 @@ class OpcodeTests(unittest.TestCase):
         self.assertRaises(ValueError, _opcode.stack_effect, 30000)
         self.assertRaises(ValueError, _opcode.stack_effect, dis.opmap['BUILD_SLICE'])
         self.assertRaises(ValueError, _opcode.stack_effect, dis.opmap['POP_TOP'], 0)
+        # All defined opcodes
+        for name, code in dis.opmap.items():
+            with self.subTest(opname=name):
+                if code < dis.HAVE_ARGUMENT:
+                    _opcode.stack_effect(code)
+                    self.assertRaises(ValueError, _opcode.stack_effect, code, 0)
+                else:
+                    _opcode.stack_effect(code, 0)
+                    self.assertRaises(ValueError, _opcode.stack_effect, code)
+        # All not defined opcodes
+        for code in set(range(256)) - set(dis.opmap.values()):
+            with self.subTest(opcode=code):
+                self.assertRaises(ValueError, _opcode.stack_effect, code)
+                self.assertRaises(ValueError, _opcode.stack_effect, code, 0)
+
 
 if __name__ == "__main__":
     unittest.main()
diff --git a/Misc/NEWS.d/next/Library/2018-04-22-20-13-21.bpo-33334.19UMOC.rst b/Misc/NEWS.d/next/Library/2018-04-22-20-13-21.bpo-33334.19UMOC.rst
new file mode 100644 (file)
index 0000000..1df2740
--- /dev/null
@@ -0,0 +1,2 @@
+:func:`dis.stack_effect` now supports all defined opcodes including NOP and
+EXTENDED_ARG.
index 5f5e65383f9184933234ff4f187f47a9cf8ed01f..cc0988f68e252e3ba7a841884f0b22f761adfadf 100644 (file)
@@ -859,6 +859,10 @@ static int
 stack_effect(int opcode, int oparg, int jump)
 {
     switch (opcode) {
+        case NOP:
+        case EXTENDED_ARG:
+            return 0;
+
         /* Stack manipulation */
         case POP_TOP:
             return -1;