diff --git a/test/Makefile b/test/Makefile index 682f92b5..7ec94df9 100644 --- a/test/Makefile +++ b/test/Makefile @@ -23,7 +23,7 @@ check: check-2.6 check-2.7: check-bytecode-2 check-bytecode-3 check-2.7-ok #: Run working tests from Python 3.1 -check-3.2: check-bytecode +check-3.1: check-bytecode $(PYTHON) test_pythonlib.py --bytecode-3.1 --verify $(COMPILE) #: Run working tests from Python 3.2 @@ -91,6 +91,10 @@ check-bytecode-2.6: check-bytecode-2.7: $(PYTHON) test_pythonlib.py --bytecode-2.7 +#: Check deparsing Python 3.1 +check-bytecode-3.1: + $(PYTHON) test_pythonlib.py --bytecode-3.1 + #: Check deparsing Python 3.2 check-bytecode-3.2: $(PYTHON) test_pythonlib.py --bytecode-3.2 diff --git a/test/bytecode_3.1/31_while_loops.pyc b/test/bytecode_3.1/31_while_loops.pyc new file mode 100644 index 00000000..0beac765 Binary files /dev/null and b/test/bytecode_3.1/31_while_loops.pyc differ diff --git a/test/test_pyenvlib.py b/test/test_pyenvlib.py index 712a3de8..c36e6c9e 100755 --- a/test/test_pyenvlib.py +++ b/test/test_pyenvlib.py @@ -31,7 +31,8 @@ TEST_VERSIONS=('2.3.7', '2.4.6', '2.5.6', '2.6.9', 'pypy-2.4.0', 'pypy-2.6.1', 'pypy-5.0.1', 'pypy-5.3.1', '2.7.10', '2.7.11', '2.7.12', - '3.2.6', '3.3.5', '3.3.6', '3.4.2', '3.5.1') + '3.1.5', '3.2.6', '3.3.5', '3.3.6', + '3.4.2', '3.5.1') target_base = '/tmp/py-dis/' lib_prefix = os.path.join(os.environ['HOME'], '.pyenv/versions') diff --git a/test/test_pythonlib.py b/test/test_pythonlib.py index 3cda1f36..0ca68842 100755 --- a/test/test_pythonlib.py +++ b/test/test_pythonlib.py @@ -79,7 +79,8 @@ for vers in (2.7, 3.4, 3.5, 3.6): pass for vers in (2.2, 2.3, 2.4, 2.5, 2.6, 2.7, - 3.2, 3.3, 3.4, 3.5, 3.6, 'pypy3.2', 'pypy2.7'): + 3.1, 3.2, 3.3, + 3.4, 3.5, 3.6, 'pypy3.2', 'pypy2.7'): bytecode = "bytecode_%s" % vers key = "bytecode-%s" % vers test_options[key] = (bytecode, PYC, bytecode, vers) diff --git a/uncompyle6/scanners/scanner31.py b/uncompyle6/scanners/scanner31.py new file mode 100644 index 00000000..dc0b3900 --- /dev/null +++ b/uncompyle6/scanners/scanner31.py @@ -0,0 +1,34 @@ +# Copyright (c) 2015-2016 by Rocky Bernstein +""" +Python 3.2 bytecode scanner/deparser + +This sets up opcodes Python's 3.2 and calls a generalized +scanner routine for Python 3. +""" + +from __future__ import print_function + +# bytecode verification, verify(), uses JUMP_OPs from here +from xdis.opcodes import opcode_32 as opc +JUMP_OPs = map(lambda op: opc.opname[op], opc.hasjrel + opc.hasjabs) + +from uncompyle6.scanners.scanner3 import Scanner3 +class Scanner31(Scanner3): + + def __init__(self, show_asm=None, is_pypy=False): + Scanner3.__init__(self, 3.1, show_asm, is_pypy) + return + pass + +if __name__ == "__main__": + from uncompyle6 import PYTHON_VERSION + if PYTHON_VERSION == 3.1: + import inspect + co = inspect.currentframe().f_code + tokens, customize = Scanner32().ingest(co) + for t in tokens: + print(t) + pass + else: + print("Need to be Python 3.1 to demo; I am %s." % + PYTHON_VERSION) diff --git a/uncompyle6/verify.py b/uncompyle6/verify.py index 7e113de0..0a98f4ae 100755 --- a/uncompyle6/verify.py +++ b/uncompyle6/verify.py @@ -201,6 +201,13 @@ def cmp_code_objects(version, is_pypy, code_obj1, code_obj2, else: import uncompyle6.scanners.scanner27 as scan scanner = scan.Scanner27() + elif version == 3.1: + if is_pypy: + import uncompyle6.scanners.pypy31 as scan + scanner = scan.ScannerPyPy31() + else: + import uncompyle6.scanners.scanner32 as scan + scanner = scan.Scanner32() elif version == 3.2: if is_pypy: import uncompyle6.scanners.pypy32 as scan