mirror of
https://github.com/python/cpython.git
synced 2025-11-01 14:11:41 +00:00
Use Tim's suggestion to fix
[ 708901 ] Lineno calculation sometimes broken A one line patch to compile.c and a rather-more-than-one-line patch to test_dis. Hey ho. Possibly a backport candidate -- tho' lnotab is less used in 2.2...
This commit is contained in:
parent
58ee2af48e
commit
26848a34d1
2 changed files with 52 additions and 15 deletions
|
|
@ -14,17 +14,61 @@ def _f(a):
|
||||||
return 1
|
return 1
|
||||||
|
|
||||||
dis_f = """\
|
dis_f = """\
|
||||||
13 0 LOAD_FAST 0 (a)
|
%-4d 0 LOAD_FAST 0 (a)
|
||||||
3 PRINT_ITEM
|
3 PRINT_ITEM
|
||||||
4 PRINT_NEWLINE
|
4 PRINT_NEWLINE
|
||||||
|
|
||||||
14 5 LOAD_CONST 1 (1)
|
%-4d 5 LOAD_CONST 1 (1)
|
||||||
8 RETURN_VALUE
|
8 RETURN_VALUE
|
||||||
9 LOAD_CONST 0 (None)
|
9 LOAD_CONST 0 (None)
|
||||||
12 RETURN_VALUE
|
12 RETURN_VALUE
|
||||||
"""
|
"""%(_f.func_code.co_firstlineno + 1,
|
||||||
|
_f.func_code.co_firstlineno + 2)
|
||||||
|
|
||||||
|
|
||||||
|
def bug708901():
|
||||||
|
for res in range(1,
|
||||||
|
10):
|
||||||
|
pass
|
||||||
|
|
||||||
|
dis_bug708901 = """\
|
||||||
|
%-4d 0 SETUP_LOOP 23 (to 26)
|
||||||
|
3 LOAD_GLOBAL 0 (range)
|
||||||
|
6 LOAD_CONST 1 (1)
|
||||||
|
|
||||||
|
%-4d 9 LOAD_CONST 2 (10)
|
||||||
|
12 CALL_FUNCTION 2
|
||||||
|
15 GET_ITER
|
||||||
|
>> 16 FOR_ITER 6 (to 25)
|
||||||
|
19 STORE_FAST 0 (res)
|
||||||
|
|
||||||
|
%-4d 22 JUMP_ABSOLUTE 16
|
||||||
|
>> 25 POP_BLOCK
|
||||||
|
>> 26 LOAD_CONST 0 (None)
|
||||||
|
29 RETURN_VALUE
|
||||||
|
"""%(bug708901.func_code.co_firstlineno + 1,
|
||||||
|
bug708901.func_code.co_firstlineno + 2,
|
||||||
|
bug708901.func_code.co_firstlineno + 3)
|
||||||
|
|
||||||
class DisTests(unittest.TestCase):
|
class DisTests(unittest.TestCase):
|
||||||
|
def do_disassembly_test(self, func, expected):
|
||||||
|
s = StringIO.StringIO()
|
||||||
|
save_stdout = sys.stdout
|
||||||
|
sys.stdout = s
|
||||||
|
dis.dis(func)
|
||||||
|
sys.stdout = save_stdout
|
||||||
|
got = s.getvalue()
|
||||||
|
# Trim trailing blanks (if any).
|
||||||
|
lines = got.split('\n')
|
||||||
|
lines = [line.rstrip() for line in lines]
|
||||||
|
expected = expected.split("\n")
|
||||||
|
import difflib
|
||||||
|
if expected != lines:
|
||||||
|
self.fail(
|
||||||
|
"events did not match expectation:\n" +
|
||||||
|
"\n".join(difflib.ndiff(expected,
|
||||||
|
lines)))
|
||||||
|
|
||||||
def test_opmap(self):
|
def test_opmap(self):
|
||||||
self.assertEqual(dis.opmap["STOP_CODE"], 0)
|
self.assertEqual(dis.opmap["STOP_CODE"], 0)
|
||||||
self.assertEqual(dis.opmap["LOAD_CONST"] in dis.hasconst, True)
|
self.assertEqual(dis.opmap["LOAD_CONST"] in dis.hasconst, True)
|
||||||
|
|
@ -38,17 +82,10 @@ def test_boundaries(self):
|
||||||
self.assertEqual(dis.opmap["STORE_NAME"], dis.HAVE_ARGUMENT)
|
self.assertEqual(dis.opmap["STORE_NAME"], dis.HAVE_ARGUMENT)
|
||||||
|
|
||||||
def test_dis(self):
|
def test_dis(self):
|
||||||
s = StringIO.StringIO()
|
self.do_disassembly_test(_f, dis_f)
|
||||||
save_stdout = sys.stdout
|
|
||||||
sys.stdout = s
|
def test_bug_708901(self):
|
||||||
dis.dis(_f)
|
self.do_disassembly_test(bug708901, dis_bug708901)
|
||||||
sys.stdout = save_stdout
|
|
||||||
got = s.getvalue()
|
|
||||||
# Trim trailing blanks (if any).
|
|
||||||
lines = got.split('\n')
|
|
||||||
lines = [line.rstrip() for line in lines]
|
|
||||||
got = '\n'.join(lines)
|
|
||||||
self.assertEqual(dis_f, got)
|
|
||||||
|
|
||||||
def test_main():
|
def test_main():
|
||||||
run_unittest(DisTests)
|
run_unittest(DisTests)
|
||||||
|
|
|
||||||
|
|
@ -3366,7 +3366,7 @@ com_for_stmt(struct compiling *c, node *n)
|
||||||
com_node(c, CHILD(n, 3));
|
com_node(c, CHILD(n, 3));
|
||||||
com_addbyte(c, GET_ITER);
|
com_addbyte(c, GET_ITER);
|
||||||
c->c_begin = c->c_nexti;
|
c->c_begin = c->c_nexti;
|
||||||
com_set_lineno(c, n->n_lineno);
|
com_set_lineno(c, c->c_last_line);
|
||||||
com_addfwref(c, FOR_ITER, &anchor);
|
com_addfwref(c, FOR_ITER, &anchor);
|
||||||
com_push(c, 1);
|
com_push(c, 1);
|
||||||
com_assign(c, CHILD(n, 1), OP_ASSIGN, NULL);
|
com_assign(c, CHILD(n, 1), OP_ASSIGN, NULL);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue