Merge pull request #719 from unmerged/nonlocal-keyword
Added `nonlocal`. `global` takes multiple args.
This commit is contained in:
commit
950c1bd41b
@ -1061,13 +1061,42 @@ class HyASTCompiler(object):
|
||||
return ret
|
||||
|
||||
@builds("global")
|
||||
@checkargs(1)
|
||||
@checkargs(min=1)
|
||||
def compile_global_expression(self, expr):
|
||||
expr.pop(0) # global
|
||||
e = expr.pop(0)
|
||||
return ast.Global(names=[ast_str(e)],
|
||||
lineno=e.start_line,
|
||||
col_offset=e.start_column)
|
||||
names = []
|
||||
while len(expr) > 0:
|
||||
identifier = expr.pop(0)
|
||||
name = ast_str(identifier)
|
||||
names.append(name)
|
||||
if not isinstance(identifier, HySymbol):
|
||||
raise HyTypeError(identifier, "(global) arguments must "
|
||||
" be Symbols")
|
||||
|
||||
return ast.Global(names=names,
|
||||
lineno=expr.start_line,
|
||||
col_offset=expr.start_column)
|
||||
|
||||
@builds("nonlocal")
|
||||
@checkargs(min=1)
|
||||
def compile_nonlocal_expression(self, expr):
|
||||
if not PY3:
|
||||
raise HyCompileError(
|
||||
"nonlocal only supported in python 3!")
|
||||
|
||||
expr.pop(0) # nonlocal
|
||||
names = []
|
||||
while len(expr) > 0:
|
||||
identifier = expr.pop(0)
|
||||
name = ast_str(identifier)
|
||||
names.append(name)
|
||||
if not isinstance(identifier, HySymbol):
|
||||
raise HyTypeError(identifier, "(nonlocal) arguments must "
|
||||
"be Symbols.")
|
||||
|
||||
return ast.Nonlocal(names=names,
|
||||
lineno=expr.start_line,
|
||||
col_offset=expr.start_column)
|
||||
|
||||
@builds("yield")
|
||||
@checkargs(max=1)
|
||||
|
@ -218,12 +218,25 @@ def test_ast_bad_assert():
|
||||
def test_ast_good_global():
|
||||
"Make sure AST can compile valid global"
|
||||
can_compile("(global a)")
|
||||
can_compile("(global foo bar)")
|
||||
|
||||
|
||||
def test_ast_bad_global():
|
||||
"Make sure AST can't compile invalid global"
|
||||
cant_compile("(global)")
|
||||
cant_compile("(global foo bar)")
|
||||
cant_compile("(global (foo))")
|
||||
|
||||
|
||||
if PY3:
|
||||
def test_ast_good_nonlocal():
|
||||
"Make sure AST can compile valid nonlocal"
|
||||
can_compile("(nonlocal a)")
|
||||
can_compile("(nonlocal foo bar)")
|
||||
|
||||
def test_ast_bad_nonlocal():
|
||||
"Make sure AST can't compile invalid nonlocal"
|
||||
cant_compile("(nonlocal)")
|
||||
cant_compile("(nonlocal (foo))")
|
||||
|
||||
|
||||
def test_ast_good_defclass():
|
||||
|
Loading…
Reference in New Issue
Block a user