Fix AST generation of a naked return
This commit is contained in:
parent
7b87d42221
commit
316220b742
7
NEWS.rst
7
NEWS.rst
@ -1,5 +1,12 @@
|
|||||||
.. default-role:: code
|
.. default-role:: code
|
||||||
|
|
||||||
|
Unreleased
|
||||||
|
==============================
|
||||||
|
|
||||||
|
Bug Fixes
|
||||||
|
------------------------------
|
||||||
|
* Fix `(return)` so it works correctly to exit a Python 2 generator
|
||||||
|
|
||||||
0.14.0
|
0.14.0
|
||||||
==============================
|
==============================
|
||||||
|
|
||||||
|
@ -2040,7 +2040,9 @@ class HyASTCompiler(object):
|
|||||||
@checkargs(max=1)
|
@checkargs(max=1)
|
||||||
def compile_return(self, expr):
|
def compile_return(self, expr):
|
||||||
ret = Result()
|
ret = Result()
|
||||||
if len(expr) > 1:
|
if len(expr) == 1:
|
||||||
|
return asty.Return(expr, value=None)
|
||||||
|
|
||||||
ret += self.compile(expr[1])
|
ret += self.compile(expr[1])
|
||||||
return ret + asty.Return(expr, value=ret.force_expr)
|
return ret + asty.Return(expr, value=ret.force_expr)
|
||||||
|
|
||||||
|
@ -8,7 +8,7 @@ from __future__ import unicode_literals
|
|||||||
from hy import HyString
|
from hy import HyString
|
||||||
from hy.models import HyObject
|
from hy.models import HyObject
|
||||||
from hy.compiler import hy_compile
|
from hy.compiler import hy_compile
|
||||||
from hy.importer import import_buffer_to_hst
|
from hy.importer import hy_eval, import_buffer_to_hst
|
||||||
from hy.errors import HyCompileError, HyTypeError
|
from hy.errors import HyCompileError, HyTypeError
|
||||||
from hy.lex.exceptions import LexException
|
from hy.lex.exceptions import LexException
|
||||||
from hy._compat import PY3
|
from hy._compat import PY3
|
||||||
@ -30,6 +30,10 @@ def can_compile(expr):
|
|||||||
return hy_compile(import_buffer_to_hst(expr), "__main__")
|
return hy_compile(import_buffer_to_hst(expr), "__main__")
|
||||||
|
|
||||||
|
|
||||||
|
def can_eval(expr):
|
||||||
|
return hy_eval(import_buffer_to_hst(expr))
|
||||||
|
|
||||||
|
|
||||||
def cant_compile(expr):
|
def cant_compile(expr):
|
||||||
try:
|
try:
|
||||||
hy_compile(import_buffer_to_hst(expr), "__main__")
|
hy_compile(import_buffer_to_hst(expr), "__main__")
|
||||||
@ -664,3 +668,8 @@ def test_ast_good_yield_from():
|
|||||||
def test_ast_bad_yield_from():
|
def test_ast_bad_yield_from():
|
||||||
"Make sure AST can't compile invalid yield-from"
|
"Make sure AST can't compile invalid yield-from"
|
||||||
cant_compile("(yield-from)")
|
cant_compile("(yield-from)")
|
||||||
|
|
||||||
|
|
||||||
|
def test_eval_generator_with_return():
|
||||||
|
"""Ensure generators with a return statement works."""
|
||||||
|
can_eval("(fn [] (yield 1) (yield 2) (return))")
|
||||||
|
Loading…
Reference in New Issue
Block a user