Alias except' to catch' and raise' to throw'

Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Julien Danjou 2013-04-07 18:24:01 +02:00
parent 2fd56e8fa1
commit bdd07e1251
3 changed files with 43 additions and 7 deletions

View File

@ -162,6 +162,7 @@ class HyASTCompiler(object):
return [self.compile(x) for x in expr[1:]]
@builds("throw")
@builds("raise")
@checkargs(min=1)
def compile_throw_expression(self, expr):
expr.pop(0)
@ -194,6 +195,7 @@ class HyASTCompiler(object):
orelse=[])
@builds("catch")
@builds("except")
def compile_catch_expression(self, expr):
expr.pop(0) # catch

View File

@ -104,6 +104,16 @@ def test_ast_bad_throw():
cant_compile("(throw)")
def test_ast_good_raise():
"Make sure AST can compile valid raise"
hy_compile(tokenize("(raise 1)"))
def test_ast_bad_raise():
"Make sure AST can't compile invalid raise"
cant_compile("(raise)")
def test_ast_good_try():
"Make sure AST can compile valid try"
hy_compile(tokenize("(try 1)"))
@ -132,6 +142,24 @@ def test_ast_bad_catch():
cant_compile("(catch [x [FooBar] BarBar]])")
def test_ast_good_except():
"Make sure AST can compile valid except"
hy_compile(tokenize("(except)"))
hy_compile(tokenize("(except [])"))
hy_compile(tokenize("(except [Foobar])"))
hy_compile(tokenize("(except [[]])"))
hy_compile(tokenize("(except [x FooBar])"))
hy_compile(tokenize("(except [x [FooBar BarFoo]])"))
hy_compile(tokenize("(except [x [FooBar BarFoo]])"))
def test_ast_bad_except():
"Make sure AST can't compile invalid except"
cant_compile("(except 1)")
cant_compile("(except [1 3])")
cant_compile("(except [x [FooBar] BarBar]])")
def test_ast_good_assert():
"Make sure AST can compile valid assert"
hy_compile(tokenize("(assert 1)"))

View File

@ -163,23 +163,29 @@
(defn test-exceptions []
"NATIVE: test Exceptions"
(try
(throw (KeyError))
(raise (KeyError))
(catch [[IOError]] (assert false))
(catch [e [KeyError]] (assert e)))
(try
(throw (KeyError))
(except [[IOError]] (assert false))
(catch [e [KeyError]] (assert e)))
(try
(get [1] 3)
(catch [IndexError] (assert true))
(catch [IndexError] (pass)))
(except [IndexError] (pass)))
(try
(print foobar42ofthebaz)
(catch [IndexError] (assert false))
(catch [NameError] (pass)))
(except [NameError] (pass)))
(try
(get [1] 3)
(catch [e IndexError] (assert (isinstance e IndexError))))
(except [e IndexError] (assert (isinstance e IndexError))))
(try
(get [1] 3)
@ -187,7 +193,7 @@
(try
(print foobar42ofthebaz)
(catch [e [IndexError NameError]] (assert (isinstance e NameError))))
(except [e [IndexError NameError]] (assert (isinstance e NameError))))
(try
(print foobar42)
@ -203,11 +209,11 @@
(try
(print foobar42ofthebaz)
(catch []))
(except []))
(try
(print foobar42ofthebaz)
(catch [] (pass)))
(except [] (pass)))
(try
(print foobar42ofthebaz)