Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 6 additions & 2 deletions Lib/test/test_dis.py
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,8 @@ def bug708901():
2 LOAD_CONST 1 (1)

%3d 4 LOAD_CONST 2 (10)
6 CALL_FUNCTION 2

%3d 6 CALL_FUNCTION 2
8 GET_ITER
>> 10 FOR_ITER 4 (to 16)
12 STORE_FAST 0 (res)
Expand All @@ -134,6 +135,7 @@ def bug708901():
18 RETURN_VALUE
""" % (bug708901.__code__.co_firstlineno + 1,
bug708901.__code__.co_firstlineno + 2,
bug708901.__code__.co_firstlineno + 1,
bug708901.__code__.co_firstlineno + 3)


Expand All @@ -154,7 +156,8 @@ def bug1333982(x=[]):
16 CALL_FUNCTION 1

%3d 18 LOAD_CONST 4 (1)
20 BINARY_ADD

%3d 20 BINARY_ADD
22 CALL_FUNCTION 1
24 RAISE_VARARGS 1

Expand All @@ -164,6 +167,7 @@ def bug1333982(x=[]):
__file__,
bug1333982.__code__.co_firstlineno + 1,
bug1333982.__code__.co_firstlineno + 2,
bug1333982.__code__.co_firstlineno + 1,
bug1333982.__code__.co_firstlineno + 3)

_BIG_LINENO_FORMAT = """\
Expand Down
2 changes: 1 addition & 1 deletion Lib/test/test_doctest.py
Original file line number Diff line number Diff line change
Expand Up @@ -2718,7 +2718,7 @@ def test_unicode(): """
Exception raised:
Traceback (most recent call last):
File ...
compileflags, 1), test.globs)
exec(compile(example.source, filename, "single",
File "<doctest foo-bär@baz[0]>", line 1, in <module>
raise Exception('clé')
Exception: clé
Expand Down
2 changes: 1 addition & 1 deletion Lib/test/test_faulthandler.py
Original file line number Diff line number Diff line change
Expand Up @@ -400,7 +400,7 @@ def funcA():
if filename:
lineno = 9
elif fd is not None:
lineno = 12
lineno = 11
else:
lineno = 14
expected = [
Expand Down
4 changes: 2 additions & 2 deletions Lib/test/test_traceback.py
Original file line number Diff line number Diff line change
Expand Up @@ -933,11 +933,11 @@ def some_inner(k, v):
s = some_inner(3, 4)
self.assertEqual(
[' File "%s", line %d, in some_inner\n'
' traceback.walk_stack(None), capture_locals=True, limit=1)\n'
' return traceback.StackSummary.extract(\n'
' a = 1\n'
' b = 2\n'
' k = 3\n'
' v = 4\n' % (__file__, some_inner.__code__.co_firstlineno + 4)
' v = 4\n' % (__file__, some_inner.__code__.co_firstlineno + 3)
], s.format())

class TestTracebackException(unittest.TestCase):
Expand Down
2 changes: 1 addition & 1 deletion Lib/test/test_tracemalloc.py
Original file line number Diff line number Diff line change
Expand Up @@ -936,7 +936,7 @@ def get_traceback(self):
return None

def track(self, release_gil=False, nframe=1):
frames = get_frames(nframe, 2)
frames = get_frames(nframe, 1)
_testcapi.tracemalloc_track(self.domain, self.ptr, self.size,
release_gil)
return frames
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
Tracebacks show now correct line number for subexpressions in multiline
expressions. Tracebacks show now the line number of the first line for
multiline expressions instead of the line number of the last subexpression.
40 changes: 26 additions & 14 deletions Python/compile.c
Original file line number Diff line number Diff line change
Expand Up @@ -4089,10 +4089,6 @@ compiler_comprehension(struct compiler *c, expr_ty e, int type,
is_async_generator = c->u->u_ste->ste_coroutine;

if (is_async_generator && !is_async_function && type != COMP_GENEXP) {
if (e->lineno > c->u->u_lineno) {
c->u->u_lineno = e->lineno;
c->u->u_lineno_set = 0;
}
compiler_error(c, "asynchronous comprehension outside of "
"an asynchronous function");
goto error_in_scope;
Expand Down Expand Up @@ -4430,17 +4426,8 @@ compiler_with(struct compiler *c, stmt_ty s, int pos)
}

static int
compiler_visit_expr(struct compiler *c, expr_ty e)
compiler_visit_expr1(struct compiler *c, expr_ty e)
{
/* If expr e has a different line number than the last expr/stmt,
set a new line number for the next instruction.
*/
if (e->lineno > c->u->u_lineno) {
c->u->u_lineno = e->lineno;
c->u->u_lineno_set = 0;
}
/* Updating the column offset is always harmless. */
c->u->u_col_offset = e->col_offset;
switch (e->kind) {
case BoolOp_kind:
return compiler_boolop(c, e);
Expand Down Expand Up @@ -4609,6 +4596,31 @@ compiler_visit_expr(struct compiler *c, expr_ty e)
return 1;
}

static int
compiler_visit_expr(struct compiler *c, expr_ty e)
{
/* If expr e has a different line number than the last expr/stmt,
set a new line number for the next instruction.
*/
int old_lineno = c->u->u_lineno;
int old_col_offset = c->u->u_col_offset;
if (e->lineno != c->u->u_lineno) {
c->u->u_lineno = e->lineno;
c->u->u_lineno_set = 0;
}
/* Updating the column offset is always harmless. */
c->u->u_col_offset = e->col_offset;

int res = compiler_visit_expr1(c, e);

if (old_lineno != c->u->u_lineno) {
c->u->u_lineno = old_lineno;
c->u->u_lineno_set = 0;
}
c->u->u_col_offset = old_col_offset;
return res;
}

static int
compiler_augassign(struct compiler *c, stmt_ty s)
{
Expand Down
Loading