Resolves #6 - PROGN Special Function (Form)
This commit is contained in:
parent
5129f6c17b
commit
50a3f3be67
@ -1,19 +1,18 @@
|
||||
(defun decrement (n) (- n 1))
|
||||
|
||||
(defun percent (n percent)
|
||||
(cond
|
||||
((> percent 0) (/ (+ (* n percent) 50) 100))
|
||||
(T (/ (- (* n percent) 50) 100))
|
||||
(if (> percent 0)
|
||||
(/ (+ (* n percent) 50) 100)
|
||||
(/ (- (* n percent) 50) 100)
|
||||
)
|
||||
)
|
||||
|
||||
(defun compound-interest (principal rate years)
|
||||
(cond
|
||||
((= years 0) principal)
|
||||
(T (compound-interest (+ principal (percent principal rate))
|
||||
rate
|
||||
(decrement years)
|
||||
)
|
||||
(if (= years 0)
|
||||
principal
|
||||
(compound-interest (+ principal (percent principal rate))
|
||||
rate
|
||||
(decrement years)
|
||||
)
|
||||
)
|
||||
)
|
||||
|
@ -1,11 +1,11 @@
|
||||
(let ((*first-payday-day* 6)
|
||||
(*leap-year* 0)
|
||||
(*days-in-year* 365)
|
||||
(*two-weeks* 14))
|
||||
(let ((first-payday-day 6)
|
||||
(leap-year 0)
|
||||
(days-in-year 365)
|
||||
(two-weeks 14))
|
||||
|
||||
(+ 1
|
||||
(/ (- (+ *days-in-year*
|
||||
*leap-year*)
|
||||
*first-payday-day*)
|
||||
*two-weeks*))
|
||||
(/ (- (+ days-in-year
|
||||
leap-year)
|
||||
first-payday-day)
|
||||
two-weeks))
|
||||
)
|
||||
|
@ -1,3 +1,9 @@
|
||||
(defun problem (n) (cond ((< n 1) nil) (T (cons n (problem (- n 1))))))
|
||||
(defun problem (n)
|
||||
(if (< n 1) nil
|
||||
(cons n (problem (- n 1)))
|
||||
)
|
||||
)
|
||||
|
||||
(setf y (problem 20))
|
||||
(setf x (problem 20000))
|
||||
|
||||
|
@ -1,13 +1,15 @@
|
||||
(defun run-unit-test (unit-test)
|
||||
(cond
|
||||
((funcall unit-test) (print (cons T unit-test)) T)
|
||||
(T (print (cons 'F unit-test)) NIL)
|
||||
(if (funcall unit-test)
|
||||
(progn (print (cons t unit-test)) t)
|
||||
(progn (print (cons 'F unit-test)) nil)
|
||||
)
|
||||
)
|
||||
|
||||
(defun run-test-suite (test-suite)
|
||||
(cond
|
||||
(test-suite (cons (run-unit-test (car test-suite)) (run-test-suite (cdr test-suite))))
|
||||
(if test-suite
|
||||
(cons (run-unit-test (car test-suite))
|
||||
(run-test-suite (cdr test-suite))
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
@ -16,8 +18,8 @@
|
||||
)
|
||||
|
||||
(defun assert= (expected actual)
|
||||
(cond
|
||||
((= expected actual) T)
|
||||
(T (print (list expected 'is 'not actual)) nil)
|
||||
(if (= expected actual)
|
||||
t
|
||||
(progn (print (list expected 'is 'not actual)) nil)
|
||||
)
|
||||
)
|
||||
|
33
src/function/builtin/special/PROGN.java
Normal file
33
src/function/builtin/special/PROGN.java
Normal file
@ -0,0 +1,33 @@
|
||||
package function.builtin.special;
|
||||
|
||||
import static function.builtin.EVAL.eval;
|
||||
|
||||
import function.*;
|
||||
import sexpression.*;
|
||||
|
||||
@FunctionNames({ "PROGN" })
|
||||
public class PROGN extends LispSpecialFunction {
|
||||
|
||||
private ArgumentValidator argumentValidator;
|
||||
|
||||
public PROGN() {
|
||||
this.argumentValidator = new ArgumentValidator("PROGN");
|
||||
}
|
||||
|
||||
public SExpression call(Cons argumentList) {
|
||||
argumentValidator.validate(argumentList);
|
||||
|
||||
return callTailRecursive(argumentList, Nil.getInstance());
|
||||
}
|
||||
|
||||
private SExpression callTailRecursive(Cons argumentList, SExpression lastValue) {
|
||||
SExpression currentValue = eval(argumentList.getFirst());
|
||||
Cons remainingValues = (Cons) argumentList.getRest();
|
||||
|
||||
if (argumentList.isNull())
|
||||
return lastValue;
|
||||
|
||||
return callTailRecursive(remainingValues, currentValue);
|
||||
}
|
||||
|
||||
}
|
@ -66,6 +66,7 @@ public class FunctionTable {
|
||||
allBuiltIns.add(OR.class);
|
||||
allBuiltIns.add(PLUS.class);
|
||||
allBuiltIns.add(PRINT.class);
|
||||
allBuiltIns.add(PROGN.class);
|
||||
allBuiltIns.add(QUOTE.class);
|
||||
allBuiltIns.add(REST.class);
|
||||
allBuiltIns.add(SET.class);
|
||||
|
35
test/function/builtin/special/PROGNTester.java
Normal file
35
test/function/builtin/special/PROGNTester.java
Normal file
@ -0,0 +1,35 @@
|
||||
package function.builtin.special;
|
||||
|
||||
import static testutil.TestUtilities.*;
|
||||
import static testutil.TypeAssertions.assertNil;
|
||||
|
||||
import org.junit.Test;
|
||||
|
||||
public class PROGNTester {
|
||||
|
||||
@Test
|
||||
public void prognWithNoArguments() {
|
||||
assertNil(evaluateString("(progn)"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void prognWithOneArgument() {
|
||||
assertSExpressionsMatch(parseString("1"), evaluateString("(progn 1)"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void prognWithSeveralArguments() {
|
||||
assertSExpressionsMatch(parseString("5"), evaluateString("(progn 1 2 3 4 5)"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void prognEvaluatesArgument() {
|
||||
assertSExpressionsMatch(parseString("1"), evaluateString("(progn (car '(1 2 3)))"));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void prognWithDifferentArgumentTypes() {
|
||||
assertSExpressionsMatch(parseString("pear"), evaluateString("(progn t nil '(1 2) 'pear)"));
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user