Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
chenpangpang
transformers
Commits
57579238
Unverified
Commit
57579238
authored
Jun 26, 2023
by
Sylvain Gugger
Committed by
GitHub
Jun 26, 2023
Browse files
Add support for for loops in python interpreter (#24429)
Add support for for loops
parent
c2aa5e17
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
23 additions
and
0 deletions
+23
-0
src/transformers/tools/agents.py
src/transformers/tools/agents.py
+1
-0
src/transformers/tools/python_interpreter.py
src/transformers/tools/python_interpreter.py
+15
-0
tests/tools/test_python_interpreter.py
tests/tools/test_python_interpreter.py
+7
-0
No files found.
src/transformers/tools/agents.py
View file @
57579238
...
...
@@ -48,6 +48,7 @@ _tools_are_initialized = False
BASE_PYTHON_TOOLS
=
{
"print"
:
print
,
"range"
:
range
,
"float"
:
float
,
"int"
:
int
,
"bool"
:
bool
,
...
...
src/transformers/tools/python_interpreter.py
View file @
57579238
...
...
@@ -110,6 +110,9 @@ def evaluate_ast(expression: ast.AST, state: Dict[str, Any], tools: Dict[str, Ca
elif
isinstance
(
expression
,
ast
.
Expr
):
# Expression -> evaluate the content
return
evaluate_ast
(
expression
.
value
,
state
,
tools
)
elif
isinstance
(
expression
,
ast
.
For
):
# For loop -> execute the loop
return
evaluate_for
(
expression
,
state
,
tools
)
elif
isinstance
(
expression
,
ast
.
FormattedValue
):
# Formatted value (part of f-string) -> evaluate the content and return
return
evaluate_ast
(
expression
.
value
,
state
,
tools
)
...
...
@@ -236,3 +239,15 @@ def evaluate_if(if_statement, state, tools):
if
line_result
is
not
None
:
result
=
line_result
return
result
def
evaluate_for
(
for_loop
,
state
,
tools
):
result
=
None
iterator
=
evaluate_ast
(
for_loop
.
iter
,
state
,
tools
)
for
counter
in
iterator
:
state
[
for_loop
.
target
.
id
]
=
counter
for
expression
in
for_loop
.
body
:
line_result
=
evaluate_ast
(
expression
,
state
,
tools
)
if
line_result
is
not
None
:
result
=
line_result
return
result
tests/tools/test_python_interpreter.py
View file @
57579238
...
...
@@ -122,3 +122,10 @@ class PythonInterpreterTester(unittest.TestCase):
result
=
evaluate
(
code
,
{
"add_two"
:
add_two
},
state
=
state
)
assert
result
==
5
self
.
assertDictEqual
(
state
,
{
"x"
:
3
,
"test_dict"
:
{
"x"
:
3
,
"y"
:
5
}})
def
test_evaluate_for
(
self
):
code
=
"x = 0
\n
for i in range(3):
\n
x = i"
state
=
{}
result
=
evaluate
(
code
,
{
"range"
:
range
},
state
=
state
)
assert
result
==
2
self
.
assertDictEqual
(
state
,
{
"x"
:
2
,
"i"
:
2
})
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment