Merge pull request #615 from rwtolbert/rwtolbert/bugfix/fix_return_in_try_with_yield
Fix #607, remove return from try when there is a generator inside
This commit is contained in:
commit
1cfcbff7df
@ -1,10 +1,10 @@
|
|||||||
# -*- encoding: utf-8 -*-
|
# -*- encoding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# Copyright (c) 2013 Paul Tagliamonte <paultag@debian.org>
|
# Copyright (c) 2013, 2014 Paul Tagliamonte <paultag@debian.org>
|
||||||
# Copyright (c) 2013 Julien Danjou <julien@danjou.info>
|
# Copyright (c) 2013 Julien Danjou <julien@danjou.info>
|
||||||
# Copyright (c) 2013 Nicolas Dandrimont <nicolas.dandrimont@crans.org>
|
# Copyright (c) 2013 Nicolas Dandrimont <nicolas.dandrimont@crans.org>
|
||||||
# Copyright (c) 2013 James King <james@agentultra.com>
|
# Copyright (c) 2013 James King <james@agentultra.com>
|
||||||
# Copyright (c) 2013 Bob Tolbert <bob@tolbert.org>
|
# Copyright (c) 2013, 2014 Bob Tolbert <bob@tolbert.org>
|
||||||
#
|
#
|
||||||
# Permission is hereby granted, free of charge, to any person obtaining a
|
# Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
# copy of this software and associated documentation files (the "Software"),
|
# copy of this software and associated documentation files (the "Software"),
|
||||||
@ -704,7 +704,8 @@ class HyASTCompiler(object):
|
|||||||
lineno=expr.start_line,
|
lineno=expr.start_line,
|
||||||
col_offset=expr.start_column)
|
col_offset=expr.start_column)
|
||||||
|
|
||||||
returnable = Result(expr=expr_name, temp_variables=[expr_name, name])
|
returnable = Result(expr=expr_name, temp_variables=[expr_name, name],
|
||||||
|
contains_yield=body.contains_yield)
|
||||||
|
|
||||||
body += ast.Assign(targets=[name],
|
body += ast.Assign(targets=[name],
|
||||||
value=body.force_expr,
|
value=body.force_expr,
|
||||||
@ -996,6 +997,9 @@ class HyASTCompiler(object):
|
|||||||
@checkargs(max=1)
|
@checkargs(max=1)
|
||||||
def compile_yield_expression(self, expr):
|
def compile_yield_expression(self, expr):
|
||||||
expr.pop(0)
|
expr.pop(0)
|
||||||
|
if PY33:
|
||||||
|
ret = Result(contains_yield=False)
|
||||||
|
else:
|
||||||
ret = Result(contains_yield=True)
|
ret = Result(contains_yield=True)
|
||||||
|
|
||||||
value = None
|
value = None
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
[sys :as systest])
|
[sys :as systest])
|
||||||
(import sys)
|
(import sys)
|
||||||
|
|
||||||
|
(import [hy._compat [PY33 PY34]])
|
||||||
|
|
||||||
(defn test-sys-argv []
|
(defn test-sys-argv []
|
||||||
"NATIVE: test sys.argv"
|
"NATIVE: test sys.argv"
|
||||||
@ -448,6 +449,29 @@
|
|||||||
(for [y (gen)] (setv ret (+ ret y)))
|
(for [y (gen)] (setv ret (+ ret y)))
|
||||||
(assert (= ret 10)))
|
(assert (= ret 10)))
|
||||||
|
|
||||||
|
(defn test-yield-with-return []
|
||||||
|
"NATIVE: test yield with return"
|
||||||
|
(defn gen [] (yield 3) "goodbye")
|
||||||
|
(if PY33
|
||||||
|
(do (setv gg (gen))
|
||||||
|
(assert (= 3 (next gg)))
|
||||||
|
(try (next gg)
|
||||||
|
(except [e StopIteration] (assert (hasattr e "value"))
|
||||||
|
(assert (= (getattr e "value") "goodbye")))))
|
||||||
|
(do (setv gg (gen))
|
||||||
|
(assert (= 3 (next gg)))
|
||||||
|
(try (next gg)
|
||||||
|
(except [e StopIteration] (assert (not (hasattr e "value"))))))))
|
||||||
|
|
||||||
|
|
||||||
|
(defn test-yield-in-try []
|
||||||
|
"NATIVE: test yield in try"
|
||||||
|
(defn gen []
|
||||||
|
(let [[x 1]]
|
||||||
|
(try (yield x)
|
||||||
|
(finally (print x)))))
|
||||||
|
(setv output (list (gen)))
|
||||||
|
(assert (= [1] output)))
|
||||||
|
|
||||||
(defn test-first []
|
(defn test-first []
|
||||||
"NATIVE: test firsty things"
|
"NATIVE: test firsty things"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user