diff options
| author | Serhiy Storchaka <storchaka@gmail.com> | 2016-05-24 09:15:14 +0300 | 
|---|---|---|
| committer | Serhiy Storchaka <storchaka@gmail.com> | 2016-05-24 09:15:14 +0300 | 
| commit | b0f80b0312a99ca46323efc0e4d09b567553ed46 (patch) | |
| tree | 323c414ce867d58fe60e127b4275e9931855a72f /Lib/dis.py | |
| parent | c35f491a06bb55cba097ddcd9fcbc9452ec21fb1 (diff) | |
| download | cpython-git-b0f80b0312a99ca46323efc0e4d09b567553ed46.tar.gz | |
Issue #26647: Python interpreter now uses 16-bit wordcode instead of bytecode.
Patch by Demur Rumed.
Diffstat (limited to 'Lib/dis.py')
| -rw-r--r-- | Lib/dis.py | 35 | 
1 files changed, 13 insertions, 22 deletions
| diff --git a/Lib/dis.py b/Lib/dis.py index 7b86557c77..59886f1e37 100644 --- a/Lib/dis.py +++ b/Lib/dis.py @@ -285,7 +285,6 @@ def _get_instructions_bytes(code, varnames=None, names=None, constants=None,      """      labels = findlabels(code)      starts_line = None -    free = None      for offset, op, arg in _unpack_opargs(code):          if linestarts is not None:              starts_line = linestarts.get(offset, None) @@ -296,7 +295,7 @@ def _get_instructions_bytes(code, varnames=None, names=None, constants=None,          argrepr = ''          if arg is not None:              #  Set argval to the dereferenced value of the argument when -            #  availabe, and argrepr to the string representation of argval. +            #  available, and argrepr to the string representation of argval.              #    _disassemble_bytes needs the string repr of the              #    raw name index for LOAD_GLOBAL, LOAD_CONST, etc.              argval = arg @@ -305,7 +304,7 @@ def _get_instructions_bytes(code, varnames=None, names=None, constants=None,              elif op in hasname:                  argval, argrepr = _get_name_info(arg, names)              elif op in hasjrel: -                argval = offset + 3 + arg +                argval = offset + 2 + arg                  argrepr = "to " + repr(argval)              elif op in haslocal:                  argval, argrepr = _get_name_info(arg, varnames) @@ -352,23 +351,15 @@ def _disassemble_str(source, *, file=None):  disco = disassemble                     # XXX For backwards compatibility  def _unpack_opargs(code): -    # enumerate() is not an option, since we sometimes process -    # multiple elements on a single pass through the loop      extended_arg = 0 -    n = len(code) -    i = 0 -    while i < n: +    for i in range(0, len(code), 2):          op = code[i] -        offset = i -        i = i+1 -        arg = None          if op >= HAVE_ARGUMENT: -            arg = code[i] + code[i+1]*256 + extended_arg -            extended_arg = 0 -            i = i+2 -            if op == EXTENDED_ARG: -                extended_arg = arg*65536 -        yield (offset, op, arg) +            arg = code[i+1] | extended_arg +            extended_arg = (arg << 8) if op == EXTENDED_ARG else 0 +        else: +            arg = None +        yield (i, op, arg)  def findlabels(code):      """Detect all offsets in a byte code which are jump targets. @@ -379,14 +370,14 @@ def findlabels(code):      labels = []      for offset, op, arg in _unpack_opargs(code):          if arg is not None: -            label = -1              if op in hasjrel: -                label = offset + 3 + arg +                label = offset + 2 + arg              elif op in hasjabs:                  label = arg -            if label >= 0: -                if label not in labels: -                    labels.append(label) +            else: +                continue +            if label not in labels: +                labels.append(label)      return labels  def findlinestarts(code): | 
