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

62 lines
1.6 KiB
Java
Raw Normal View History

2016-12-19 13:05:53 -05:00
package function.builtin;
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
import function.*;
import sexpression.*;
2016-12-07 16:38:26 -05:00
public class COND extends LispFunction {
2016-12-24 13:16:03 -05:00
private ArgumentValidator argumentValidator;
public COND() {
this.argumentValidator = new ArgumentValidator("COND");
this.argumentValidator.setEveryArgumentExpectedType(Cons.class);
this.argumentValidator.doNotAcceptNil();
2016-12-24 13:16:03 -05:00
}
public SExpression call(Cons argumentList) {
argumentValidator.validate(argumentList);
return callTailRecursive(argumentList);
}
private SExpression callTailRecursive(Cons argumentList) {
if (argumentList.nullp())
return Nil.getInstance();
2016-12-07 16:38:26 -05:00
Cons clause = (Cons) argumentList.getCar();
2016-12-24 13:16:03 -05:00
Cons remainingClauses = (Cons) argumentList.getCdr();
SExpression test = EVAL.eval(clause.getCar());
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
if (isTestSuccessful(test))
return evaluateResult(clause, test);
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
return callTailRecursive(remainingClauses);
}
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
private boolean isTestSuccessful(SExpression test) {
return test != Nil.getInstance();
2016-12-24 13:16:03 -05:00
}
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
private SExpression evaluateResult(Cons clause, SExpression test) {
SExpression lastResultValue = test;
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
for (SExpression result = clause.getCdr(); result.consp(); result = advanceCons(result))
lastResultValue = EVAL.eval(getCar(result));
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
return lastResultValue;
}
private SExpression advanceCons(SExpression knownCons) {
return ((Cons) knownCons).getCdr();
}
2016-12-07 16:38:26 -05:00
2016-12-24 13:16:03 -05:00
private SExpression getCar(SExpression knownCons) {
return ((Cons) knownCons).getCar();
2016-12-07 16:38:26 -05:00
}
public boolean evaluateArguments() {
return false;
}
}