Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings
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 8 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 2 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 2 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 4 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 2 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 40 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
Morty Proxy This is a proxified and sanitized view of the page, visit original site.