transcendental-lisp/src/function/builtin/LIST.java

35 lines
840 B
Java
Raw Normal View History

2016-12-19 13:05:53 -05:00
package function.builtin;
2016-12-07 16:38:26 -05:00
import function.*;
import sexpression.*;
2016-12-07 16:38:26 -05:00
public class LIST extends LispFunction {
private ArgumentValidator argumentValidator;
public LIST() {
this.argumentValidator = new ArgumentValidator("LIST");
}
2016-12-07 16:38:26 -05:00
public static Cons makeList(SExpression sexpr) {
return new Cons(sexpr, Nil.getInstance());
2016-12-07 16:38:26 -05:00
}
public Cons call(Cons argumentList) {
argumentValidator.validate(argumentList);
return callRecursive(argumentList);
}
private Cons callRecursive(Cons argumentList) {
if (argumentList.nullp())
return Nil.getInstance();
2016-12-07 16:38:26 -05:00
SExpression firstArgument = argumentList.getCar();
Cons remainingArguments = (Cons) argumentList.getCdr();
2016-12-07 16:38:26 -05:00
return new Cons(firstArgument, callRecursive(remainingArguments));
2016-12-07 16:38:26 -05:00
}
}