]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-123048: Fix missing source location in pattern matching code (#123167)
authorIrit Katriel <1055913+iritkatriel@users.noreply.github.com>
Tue, 20 Aug 2024 10:39:41 +0000 (11:39 +0100)
committerGitHub <noreply@github.com>
Tue, 20 Aug 2024 10:39:41 +0000 (11:39 +0100)
Lib/test/test_patma.py
Misc/NEWS.d/next/Core and Builtins/2024-08-20-11-09-16.gh-issue-123048.2TISpv.rst [new file with mode: 0644]
Python/compile.c

index 1bdab125dc6ef08037f5a1f5e8303418d28a391e..8325b83a5932b91e5f6f66f879de3bbc59426ffe 100644 (file)
@@ -1,6 +1,7 @@
 import array
 import collections
 import dataclasses
+import dis
 import enum
 import inspect
 import sys
@@ -3377,6 +3378,24 @@ class TestValueErrors(unittest.TestCase):
         self.assertIs(y, None)
         self.assertIs(z, None)
 
+class TestSourceLocations(unittest.TestCase):
+    def test_jump_threading(self):
+        # See gh-123048
+        def f():
+            x = 0
+            v = 1
+            match v:
+                case 1:
+                    if x < 0:
+                        x = 1
+                case 2:
+                    if x < 0:
+                        x = 1
+            x += 1
+
+        for inst in dis.get_instructions(f):
+            if inst.opcode in dis.hasjump:
+                self.assertIsNotNone(inst.positions.lineno, "jump without location")
 
 class TestTracing(unittest.TestCase):
 
diff --git a/Misc/NEWS.d/next/Core and Builtins/2024-08-20-11-09-16.gh-issue-123048.2TISpv.rst b/Misc/NEWS.d/next/Core and Builtins/2024-08-20-11-09-16.gh-issue-123048.2TISpv.rst
new file mode 100644 (file)
index 0000000..f0b756f
--- /dev/null
@@ -0,0 +1,2 @@
+Fix a bug where pattern matching code could emit a :opcode:`JUMP_FORWARD`
+with no source location.
index 0a338b169872d614feb30ccfff9b20734a28f5d9..c369202d53b38468a6d7844d2e591f1a6aa40d97 100644 (file)
@@ -7301,7 +7301,7 @@ codegen_match_inner(struct compiler *c, stmt_ty s, pattern_context *pc)
             ADDOP(c, LOC(m->pattern), POP_TOP);
         }
         VISIT_SEQ(c, stmt, m->body);
-        ADDOP_JUMP(c, NO_LOCATION, JUMP_NO_INTERRUPT, end);
+        ADDOP_JUMP(c, NO_LOCATION, JUMP, end);
         // If the pattern fails to match, we want the line number of the
         // cleanup to be associated with the failed pattern, not the last line
         // of the body