Skip to content

Commit fd36ad2

Browse files
committed
Enable dis Bytecode iteration
1 parent 2a0aaff commit fd36ad2

2 files changed

Lines changed: 53 additions & 4 deletions

File tree

Lines changed: 48 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
# Copyright (c) 2026, 2026, Oracle and/or its affiliates. All rights reserved.
2+
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3+
#
4+
# The Universal Permissive License (UPL), Version 1.0
5+
#
6+
# Subject to the condition set forth below, permission is hereby granted to any
7+
# person obtaining a copy of this software, associated documentation and/or
8+
# data (collectively the "Software"), free of charge and under any and all
9+
# copyright rights in the Software, and any and all patent rights owned or
10+
# freely licensable by each licensor hereunder covering either (i) the
11+
# unmodified Software as contributed to or provided by such licensor, or (ii)
12+
# the Larger Works (as defined below), to deal in both
13+
#
14+
# (a) the Software, and
15+
#
16+
# (b) any piece of software and/or hardware listed in the lrgrwrks.txt file if
17+
# one is included with the Software each a "Larger Work" to which the Software
18+
# is contributed by such licensors),
19+
#
20+
# without restriction, including without limitation the rights to copy, create
21+
# derivative works of, display, perform, and distribute the Software and make,
22+
# use, sell, offer for sale, import, export, have made, and have sold the
23+
# Software and the Larger Work(s), and to sublicense the foregoing rights on
24+
# either these or other terms.
25+
#
26+
# This license is subject to the following condition:
27+
#
28+
# The above copyright notice and either this complete permission notice or at a
29+
# minimum a reference to the UPL must be included in all copies or substantial
30+
# portions of the Software.
31+
#
32+
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
33+
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
34+
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
35+
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
36+
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
37+
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
38+
# SOFTWARE.
39+
import dis
40+
41+
42+
def bytecode_target(value):
43+
return value + 1
44+
45+
46+
def test_bytecode_iteration_does_not_fail():
47+
for _ in dis.Bytecode(bytecode_target):
48+
pass

graalpython/lib-python/3/dis.py

Lines changed: 5 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -734,8 +734,6 @@ class Bytecode:
734734
Iterating over this yields the bytecode operations as Instruction instances.
735735
"""
736736
def __init__(self, x, *, first_line=None, current_offset=None, show_caches=False, adaptive=False):
737-
# GraalPy change
738-
raise NotImplementedError("'dis' module is not supported on GraalPy")
739737
self.codeobj = co = _get_code_object(x)
740738
if first_line is None:
741739
self.first_line = co.co_firstlineno
@@ -746,14 +744,15 @@ def __init__(self, x, *, first_line=None, current_offset=None, show_caches=False
746744
self._linestarts = dict(findlinestarts(co))
747745
self._original_object = x
748746
self.current_offset = current_offset
749-
self.exception_entries = _parse_exception_table(co)
747+
# GraalPy change:
748+
self.exception_entries = []
750749
self.show_caches = show_caches
751750
self.adaptive = adaptive
752751

753752
def __iter__(self):
754753
co = self.codeobj
755754
return _get_instructions_bytes(_get_code_array(co, self.adaptive),
756-
co._varname_from_oparg,
755+
None, # GraalPy change: replaced co._varname_from_oparg
757756
co.co_names, co.co_consts,
758757
self._linestarts,
759758
line_offset=self._line_offset,
@@ -780,6 +779,8 @@ def info(self):
780779

781780
def dis(self):
782781
"""Return a formatted view of the bytecode operations."""
782+
# GraalPy change:
783+
raise NotImplementedError("'dis' module is not supported on GraalPy")
783784
co = self.codeobj
784785
if self.current_offset is not None:
785786
offset = self.current_offset

0 commit comments

Comments
 (0)