From 10be2ea85d081bc5b2b0529b76d104d749707394 Mon Sep 17 00:00:00 2001 From: Neal Norwitz Date: Fri, 3 Mar 2006 20:29:11 +0000 Subject: [PATCH] SF bug 1442442: LIST_APPEND optimization got lost in the AST merge. Add it back. --- Lib/compiler/pyassem.py | 1 + Lib/test/test_dis.py | 36 +++++++++++++++++------------------- Python/compile.c | 7 ++++--- 3 files changed, 22 insertions(+), 22 deletions(-) diff --git a/Lib/compiler/pyassem.py b/Lib/compiler/pyassem.py index 5932ffe6d0f..b59661f4e15 100644 --- a/Lib/compiler/pyassem.py +++ b/Lib/compiler/pyassem.py @@ -744,6 +744,7 @@ def findDepth(self, insts, debug=0): effect = { 'POP_TOP': -1, 'DUP_TOP': 1, + 'LIST_APPEND': -2, 'SLICE+1': -1, 'SLICE+2': -1, 'SLICE+3': -2, diff --git a/Lib/test/test_dis.py b/Lib/test/test_dis.py index d8d53cd3b2f..081941dafbe 100644 --- a/Lib/test/test_dis.py +++ b/Lib/test/test_dis.py @@ -54,31 +54,29 @@ def bug1333982(x=[]): dis_bug1333982 = """\ %-4d 0 LOAD_CONST 1 (0) - 3 JUMP_IF_TRUE 47 (to 53) + 3 JUMP_IF_TRUE 41 (to 47) 6 POP_TOP 7 LOAD_GLOBAL 0 (AssertionError) 10 BUILD_LIST 0 13 DUP_TOP - 14 LOAD_ATTR 1 (append) - 17 STORE_FAST 1 (_[1]) - 20 LOAD_FAST 0 (x) - 23 GET_ITER - >> 24 FOR_ITER 16 (to 43) - 27 STORE_FAST 2 (s) - 30 LOAD_FAST 1 (_[1]) - 33 LOAD_FAST 2 (s) - 36 CALL_FUNCTION 1 - 39 POP_TOP - 40 JUMP_ABSOLUTE 24 - >> 43 DELETE_FAST 1 (_[1]) + 14 STORE_FAST 1 (_[1]) + 17 LOAD_FAST 0 (x) + 20 GET_ITER + >> 21 FOR_ITER 13 (to 37) + 24 STORE_FAST 2 (s) + 27 LOAD_FAST 1 (_[1]) + 30 LOAD_FAST 2 (s) + 33 LIST_APPEND + 34 JUMP_ABSOLUTE 21 + >> 37 DELETE_FAST 1 (_[1]) - %-4d 46 LOAD_CONST 2 (1) - 49 BINARY_ADD - 50 RAISE_VARARGS 2 - >> 53 POP_TOP + %-4d 40 LOAD_CONST 2 (1) + 43 BINARY_ADD + 44 RAISE_VARARGS 2 + >> 47 POP_TOP - %-4d 54 LOAD_CONST 0 (None) - 57 RETURN_VALUE + %-4d 48 LOAD_CONST 0 (None) + 51 RETURN_VALUE """%(bug1333982.func_code.co_firstlineno + 1, bug1333982.func_code.co_firstlineno + 2, bug1333982.func_code.co_firstlineno + 3) diff --git a/Python/compile.c b/Python/compile.c index 7abc11777dc..c07b6d346da 100644 --- a/Python/compile.c +++ b/Python/compile.c @@ -1297,6 +1297,9 @@ opcode_stack_effect(int opcode, int oparg) case UNARY_INVERT: return 0; + case LIST_APPEND: + return -2; + case BINARY_POWER: case BINARY_MULTIPLY: case BINARY_DIVIDE: @@ -3149,8 +3152,7 @@ compiler_listcomp_generator(struct compiler *c, PyObject *tmpname, if (!compiler_nameop(c, tmpname, Load)) return 0; VISIT(c, expr, elt); - ADDOP_I(c, CALL_FUNCTION, 1); - ADDOP(c, POP_TOP); + ADDOP(c, LIST_APPEND); compiler_use_next_block(c, skip); } @@ -3189,7 +3191,6 @@ compiler_listcomp(struct compiler *c, expr_ty e) return 0; ADDOP_I(c, BUILD_LIST, 0); ADDOP(c, DUP_TOP); - ADDOP_O(c, LOAD_ATTR, append, names); if (compiler_nameop(c, tmp, Store)) rc = compiler_listcomp_generator(c, tmp, generators, 0, e->v.ListComp.elt);