From e56131b60e6c2e63bcb6ecc2a6b7964d74ab847d Mon Sep 17 00:00:00 2001 From: Raymond Hettinger Date: Tue, 18 Nov 2008 00:07:10 +0000 Subject: [PATCH] Issue 2260: Small peephole optimization -- eliminate unnecessary POP_TOP /JUMP_FORWARD 1 pairs. --- Python/peephole.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/Python/peephole.c b/Python/peephole.c index b9b26fc0a7..d31c89b86e 100644 --- a/Python/peephole.c +++ b/Python/peephole.c @@ -430,6 +430,16 @@ PyCode_Optimize(PyObject *code, PyObject* consts, PyObject *names, cumlc = 0; break; + /* Replace POP_TOP JUMP_FORWARD 1 POP_TOP + with NOP NOP NOP NOP POP_TOP. */ + case POP_TOP: + if (UNCONDITIONAL_JUMP(codestr[i+1]) && + GETJUMPTGT(codestr, i+1) == i+5 && + codestr[i+4] == POP_TOP && + ISBASICBLOCK(blocks,i,4)) + memset(codestr+i, NOP, 4); + break; + /* Try to fold tuples of constants (includes a case for lists which are only used for "in" and "not in" tests). Skip over BUILD_SEQN 1 UNPACK_SEQN 1. -- 2.40.0