You've already forked python-uncompyle6
mirror of
https://github.com/rocky/python-uncompyle6.git
synced 2025-08-04 09:22:40 +08:00
More Python 3.0 custom "if" statment handling.
This commit is contained in:
Binary file not shown.
@@ -7,3 +7,14 @@ def main(args, f):
|
|||||||
func(f, sys.stdout.buffer)
|
func(f, sys.stdout.buffer)
|
||||||
else:
|
else:
|
||||||
func(sys.stdin.buffer, sys.stdout.buffer)
|
func(sys.stdin.buffer, sys.stdout.buffer)
|
||||||
|
|
||||||
|
# From Python 3.0 _markupbase.py.
|
||||||
|
#
|
||||||
|
# The Problem was in the way "if"s are generated in 3.0 which is sort
|
||||||
|
# of like a more optimized Python 2.6, with reduced extraneous jumps,
|
||||||
|
# but still 2.6-ish and not 2.7- or 3.1-ish.
|
||||||
|
def parse_marked_section(fn, i, rawdata, report=1):
|
||||||
|
if report:
|
||||||
|
j = 1
|
||||||
|
fn(rawdata[i: j])
|
||||||
|
return 10
|
||||||
|
@@ -91,6 +91,9 @@ class Python30Parser(Python31Parser):
|
|||||||
except_suite ::= c_stmts POP_EXCEPT jump_except POP_TOP
|
except_suite ::= c_stmts POP_EXCEPT jump_except POP_TOP
|
||||||
except_suite_finalize ::= SETUP_FINALLY c_stmts_opt except_var_finalize END_FINALLY
|
except_suite_finalize ::= SETUP_FINALLY c_stmts_opt except_var_finalize END_FINALLY
|
||||||
_jump COME_FROM POP_TOP
|
_jump COME_FROM POP_TOP
|
||||||
|
|
||||||
|
_ifstmts_jump ::= c_stmts_opt JUMP_FORWARD COME_FROM POP_TOP
|
||||||
|
|
||||||
jump_except ::= JUMP_FORWARD COME_FROM POP_TOP
|
jump_except ::= JUMP_FORWARD COME_FROM POP_TOP
|
||||||
jump_except ::= JUMP_ABSOLUTE COME_FROM POP_TOP
|
jump_except ::= JUMP_ABSOLUTE COME_FROM POP_TOP
|
||||||
or ::= expr jmp_false expr jmp_true expr
|
or ::= expr jmp_false expr jmp_true expr
|
||||||
@@ -103,6 +106,20 @@ class Python30Parser(Python31Parser):
|
|||||||
|
|
||||||
jmp_true ::= JUMP_IF_TRUE POP_TOP
|
jmp_true ::= JUMP_IF_TRUE POP_TOP
|
||||||
jmp_false ::= JUMP_IF_FALSE _come_froms POP_TOP
|
jmp_false ::= JUMP_IF_FALSE _come_froms POP_TOP
|
||||||
|
jmp_false_then ::= JUMP_IF_FALSE POP_TOP
|
||||||
|
|
||||||
|
# We don't have hacky THEN detection, so we do it
|
||||||
|
# in the grammar below which is also somewhat hacky.
|
||||||
|
|
||||||
|
stmt ::= ifstmt30
|
||||||
|
ifstmt30 ::= testexpr_then _ifstmts_jump30
|
||||||
|
|
||||||
|
testexpr_then ::= testfalse_then
|
||||||
|
testfalse_then ::= expr jmp_false_then
|
||||||
|
call_stmt ::= expr COME_FROM
|
||||||
|
_ifstmts_jump30 ::= c_stmts POP_TOP
|
||||||
|
|
||||||
|
################################################################################
|
||||||
|
|
||||||
for_block ::= l_stmts_opt _come_froms POP_TOP JUMP_BACK
|
for_block ::= l_stmts_opt _come_froms POP_TOP JUMP_BACK
|
||||||
|
|
||||||
|
@@ -181,6 +181,12 @@ def customize_for_version3(self, version):
|
|||||||
# the iteration variable. These rules we can ignore
|
# the iteration variable. These rules we can ignore
|
||||||
# since we pick up the iteration variable some other way and
|
# since we pick up the iteration variable some other way and
|
||||||
# we definitely don't include in the source _[dd].
|
# we definitely don't include in the source _[dd].
|
||||||
|
TABLE_DIRECT.update({
|
||||||
|
'ifstmt30': ( '%|if %c:\n%+%c%-',
|
||||||
|
(0, "testexpr_then"),
|
||||||
|
(1, "_ifstmts_jump30") ),
|
||||||
|
})
|
||||||
|
|
||||||
def n_comp_iter(node):
|
def n_comp_iter(node):
|
||||||
if node[0] == "expr":
|
if node[0] == "expr":
|
||||||
n = node[0][0]
|
n = node[0][0]
|
||||||
|
Reference in New Issue
Block a user