dlambda was converted for multiple method classes
Added several unit tests, including a failing one for CASE Added an acceptance test for dlambda
This commit is contained in:
parent
64e18fe076
commit
ba203d34b9
@ -22,3 +22,74 @@ Test
|
||||
| check | evaluate | (funcall my-counter :dec) | 2 |
|
||||
| check | evaluate | (funcall my-counter :dec) | 1 |
|
||||
| check | evaluate | (funcall my-counter :dec) | 0 |
|
||||
|
||||
|
||||
| script | lisp interpreter fixture |
|
||||
| # | dlambda |
|
||||
| show | evaluate |!-
|
||||
|
||||
(defun map (fn ls)
|
||||
(if (null ls)
|
||||
()
|
||||
(cons (funcall fn (first ls))
|
||||
(map fn (rest ls))
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
(define-macro dlambda (&rest methods)
|
||||
(cons
|
||||
(quote lambda)
|
||||
(cons
|
||||
(quote (&rest arguments))
|
||||
(list
|
||||
(cons
|
||||
(quote case)
|
||||
(cons
|
||||
(quote (first arguments))
|
||||
(map
|
||||
(lambda (method)
|
||||
(cons
|
||||
(first method)
|
||||
(list
|
||||
(cons
|
||||
(quote apply)
|
||||
(cons
|
||||
(cons
|
||||
(quote lambda)
|
||||
(rest method)
|
||||
)
|
||||
(list (quote (rest arguments)))
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
methods
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
(defun apple-counter ()
|
||||
(let ((apple-count 0))
|
||||
(eval
|
||||
(dlambda
|
||||
(:inc () (setf apple-count (+ apple-count 1)))
|
||||
(:dec () (setf apple-count (- apple-count 1)))
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
-!|
|
||||
| show | evaluate | (setf a (apple-counter)) |
|
||||
| check | evaluate | (funcall a :inc) | 1 |
|
||||
| check | evaluate | (funcall a :inc) | 2 |
|
||||
| check | evaluate | (funcall a :inc) | 3 |
|
||||
| check | evaluate | (funcall a :dec) | 2 |
|
||||
| check | evaluate | (funcall a :dec) | 1 |
|
||||
| check | evaluate | (funcall a :dec) | 0 |
|
||||
| show | evaluate | (funcall a :inc 1) |
|
||||
|
@ -1,4 +1,4 @@
|
||||
|LispInterpreter.MultipleMethodClosure||11:04:53 Wed, Mar 01, 2017|
|
||||
|LispInterpreter.MultipleMethodClosure||16:02:22 Wed, Mar 01, 2017|
|
||||
|LispInterpreter.SetUp||11:04:36 Wed, Mar 01, 2017|
|
||||
|LispInterpreter.LexicalClosures||12:10:13 Mon, Feb 27, 2017|
|
||||
|LispInterpreter.TestClosure||11:24:27 Mon, Feb 27, 2017|
|
||||
|
46
lisp/dlambda.lisp
Normal file
46
lisp/dlambda.lisp
Normal file
@ -0,0 +1,46 @@
|
||||
(defun map (fn ls)
|
||||
(if (null ls)
|
||||
()
|
||||
(cons (funcall fn (first ls))
|
||||
(map fn (rest ls))
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
(define-macro dlambda (&rest methods)
|
||||
(cons
|
||||
(quote lambda)
|
||||
(cons
|
||||
(quote (&rest arguments))
|
||||
(list
|
||||
(cons
|
||||
(quote case)
|
||||
(cons
|
||||
(quote (first arguments))
|
||||
(map
|
||||
(lambda (method)
|
||||
(cons
|
||||
(first method)
|
||||
(list
|
||||
(cons
|
||||
(quote apply)
|
||||
(cons
|
||||
(cons
|
||||
(quote lambda)
|
||||
(rest method)
|
||||
)
|
||||
(list (quote (rest arguments)))
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
methods
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
|
@ -116,6 +116,20 @@ public class CASETester {
|
||||
assertSExpressionsMatch(parseString("orange"), evaluateString(input));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void caseWithEmptyList() {
|
||||
String input = "(case () ((()) 'orange))";
|
||||
|
||||
assertSExpressionsMatch(parseString("orange"), evaluateString(input));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void caseWithList() {
|
||||
String input = "(case '(5 4 3) (((1 2) (5 4 3)) 'orange))";
|
||||
|
||||
assertSExpressionsMatch(parseString("orange"), evaluateString(input));
|
||||
}
|
||||
|
||||
@Test
|
||||
public void caseWithDefaultClause() {
|
||||
String input = "(case nil (() 'banana) (t 'orange))";
|
||||
@ -185,8 +199,13 @@ public class CASETester {
|
||||
}
|
||||
|
||||
@Test(expected = BadArgumentTypeException.class)
|
||||
public void caseWithNilClause() {
|
||||
public void caseWithEmptyClause() {
|
||||
evaluateString("(case :a ())");
|
||||
}
|
||||
|
||||
@Test(expected = BadArgumentTypeException.class)
|
||||
public void caseWithNilClause() {
|
||||
evaluateString("(case :a nil)");
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -72,10 +72,15 @@ public class CONDTester {
|
||||
}
|
||||
|
||||
@Test(expected = BadArgumentTypeException.class)
|
||||
public void condWithNilArgument_ThrowsException() {
|
||||
public void condWithEmptyListArgument_ThrowsException() {
|
||||
evaluateString("(cond ())");
|
||||
}
|
||||
|
||||
@Test(expected = BadArgumentTypeException.class)
|
||||
public void condWithNilArgument_ThrowsException() {
|
||||
evaluateString("(cond nil)");
|
||||
}
|
||||
|
||||
@Test(expected = BadArgumentTypeException.class)
|
||||
public void condWithNonListArgument_ThrowsException() {
|
||||
evaluateString("(cond o)");
|
||||
|
Loading…
Reference in New Issue
Block a user