Added 'take' and 'drop' functions (as AST elements)

This commit is contained in:
John Jacobsen 2013-04-21 15:41:20 -05:00
parent 6f7f402c19
commit fef571855b
3 changed files with 77 additions and 0 deletions

View File

@ -673,6 +673,48 @@ class HyASTCompiler(object):
step=None), step=None),
ctx=ast.Load()) ctx=ast.Load())
@builds("take")
@checkargs(2)
def compile_take_expression(self, expr):
expr.pop(0)
n = self.compile(expr.pop(0))
seq = self.compile(expr.pop(0))
zero = ast.Num(n=0,
lineno=expr.start_column,
col_offset=expr.start_column)
return ast.Subscript(
lineno=expr.start_line,
col_offset=expr.start_column,
value=seq,
slice=ast.Slice(lower=zero,
upper=n,
step=None),
ctx=ast.Load())
@builds("drop")
@checkargs(2)
def compile_drop_expression(self, expr):
expr.pop(0)
n = self.compile(expr.pop(0))
seq = self.compile(expr.pop(0))
zero = ast.Num(n=0,
lineno=expr.start_line,
col_offset=expr.start_column)
upper = ast.UnaryOp(op=ast.USub(),
operand=n,
lineno=expr.start_line,
col_offset=expr.start_column)
if upper.operand.n == 0:
return seq
return ast.Subscript(
lineno=expr.start_line,
col_offset=expr.start_column,
value=seq,
slice=ast.Slice(lower=zero,
upper=upper,
step=None),
ctx=ast.Load())
@builds("assoc") @builds("assoc")
@checkargs(3) @checkargs(3)
def compile_assoc_expression(self, expr): def compile_assoc_expression(self, expr):

View File

@ -237,6 +237,27 @@ def test_ast_bad_slice():
cant_compile("(slice 1 2 3 4)") cant_compile("(slice 1 2 3 4)")
def test_ast_good_take():
"Make sure AST can compile valid 'take'"
hy_compile(tokenize("(take 1 [2 3])"))
def test_ast_bad_take():
"Make sure AST chokes on bad 'take'"
cant_compile("(take)")
cant_compile("(take 2)")
def test_ast_good_drop():
"Make sure AST can compile valid 'drop'"
hy_compile(tokenize("(drop 1 [2 3])"))
def test_ast_bad_drop():
"Make sure AST chokes on bad 'drop'"
cant_compile("(drop)")
cant_compile("(drop 2)")
def test_ast_good_assoc(): def test_ast_good_assoc():
"Make sure AST can compile valid assoc" "Make sure AST can compile valid assoc"
hy_compile(tokenize("(assoc x y z)")) hy_compile(tokenize("(assoc x y z)"))

View File

@ -376,6 +376,20 @@
(assert (= (slice [1 2 3 4 5]) [1 2 3 4 5]))) (assert (= (slice [1 2 3 4 5]) [1 2 3 4 5])))
(defn test-take []
"NATIVE: test take"
(assert (= (take 0 [2 3]) []))
(assert (= (take 1 [2 3]) [2]))
(assert (= (take 2 [2 3]) [2 3])))
(defn test-drop []
"NATIVE: test drop"
(assert (= (drop 0 [2 3]) [2 3]))
(assert (= (drop 1 [2 3]) [2]))
(assert (= (drop 2 [2 3]) [])))
(defn test-rest [] (defn test-rest []
"NATIVE: test rest" "NATIVE: test rest"
(assert (= (rest [1 2 3 4 5]) [2 3 4 5]))) (assert (= (rest [1 2 3 4 5]) [2 3 4 5])))