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.*;
|
2016-12-15 15:33:48 -05:00
|
|
|
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);
|
2016-12-25 12:49:18 -05:00
|
|
|
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())
|
2016-12-29 13:32:45 -05:00
|
|
|
return Nil.getInstance();
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2016-12-25 12:49:18 -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) {
|
2016-12-29 13:32:45 -05:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|