Added unit tests and refactored code
This commit is contained in:
parent
3cb9d89616
commit
5cd037fc07
|
@ -8,8 +8,8 @@ public class GREATERP extends LispFunction {
|
||||||
private ArgumentValidator argumentValidator;
|
private ArgumentValidator argumentValidator;
|
||||||
|
|
||||||
public GREATERP() {
|
public GREATERP() {
|
||||||
this.argumentValidator = new ArgumentValidator("GREATERP");
|
this.argumentValidator = new ArgumentValidator(">");
|
||||||
this.argumentValidator.setMinimumNumberOfArguments(2);
|
this.argumentValidator.setMinimumNumberOfArguments(1);
|
||||||
this.argumentValidator.setEveryArgumentExpectedType(LispNumber.class);
|
this.argumentValidator.setEveryArgumentExpectedType(LispNumber.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,49 +1,43 @@
|
||||||
package function.builtin;
|
package function.builtin;
|
||||||
|
|
||||||
import function.LispFunction;
|
import function.*;
|
||||||
import sexpression.*;
|
import sexpression.*;
|
||||||
|
|
||||||
/**
|
|
||||||
* <code>LESSP</code> represents the '<' function in Lisp.
|
|
||||||
*/
|
|
||||||
public class LESSP extends LispFunction {
|
public class LESSP extends LispFunction {
|
||||||
|
|
||||||
public SExpression call(Cons argList) {
|
private ArgumentValidator argumentValidator;
|
||||||
// make sure we have received at least one argument
|
|
||||||
if (argList.nullp()) {
|
|
||||||
Cons originalSExpr = new Cons(new Symbol("<"), argList);
|
|
||||||
|
|
||||||
throw new RuntimeException("too few arguments given to <: " + originalSExpr);
|
public LESSP() {
|
||||||
|
this.argumentValidator = new ArgumentValidator("<");
|
||||||
|
this.argumentValidator.setMinimumNumberOfArguments(1);
|
||||||
|
this.argumentValidator.setEveryArgumentExpectedType(LispNumber.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
SExpression firstArg = argList.getCar();
|
public SExpression call(Cons argumentList) {
|
||||||
Cons argRest = (Cons) argList.getCdr();
|
argumentValidator.validate(argumentList);
|
||||||
|
|
||||||
// make sure that the first argument is a number
|
return callTailRecursive(argumentList);
|
||||||
if (firstArg.numberp()) {
|
}
|
||||||
LispNumber num1 = (LispNumber) firstArg;
|
|
||||||
|
|
||||||
if (argRest.nullp()) {
|
private SExpression callTailRecursive(Cons argumentList) {
|
||||||
|
Cons remainingArguments = (Cons) argumentList.getCdr();
|
||||||
|
|
||||||
|
if (remainingArguments.nullp())
|
||||||
return Symbol.T;
|
return Symbol.T;
|
||||||
}
|
|
||||||
|
|
||||||
SExpression secondArg = argRest.getCar();
|
SExpression firstArgument = argumentList.getCar();
|
||||||
|
SExpression secondArgument = remainingArguments.getCar();
|
||||||
// make sure that the second argument is a number as well
|
LispNumber number1 = (LispNumber) firstArgument;
|
||||||
if (secondArg.numberp()) {
|
LispNumber number2 = (LispNumber) secondArgument;
|
||||||
LispNumber num2 = (LispNumber) secondArg;
|
|
||||||
|
|
||||||
if (num1.getValue().compareTo(num2.getValue()) < 0) {
|
|
||||||
return call(argRest);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (!isFirstLesser(number1, number2))
|
||||||
return Nil.getInstance();
|
return Nil.getInstance();
|
||||||
|
|
||||||
|
return callTailRecursive(remainingArguments);
|
||||||
}
|
}
|
||||||
|
|
||||||
throw new RuntimeException("<: " + secondArg + " is not a number");
|
private boolean isFirstLesser(LispNumber number1, LispNumber number2) {
|
||||||
}
|
return number1.getValue().compareTo(number2.getValue()) < 0;
|
||||||
|
|
||||||
throw new RuntimeException("<: " + firstArg + " is not a number");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,13 @@ import function.ArgumentValidator.*;
|
||||||
|
|
||||||
public class GREATERPTester {
|
public class GREATERPTester {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGreaterpWithOneNumber_ReturnsT() {
|
||||||
|
String input = "(> 1)";
|
||||||
|
|
||||||
|
assertSExpressionsMatch(evaluateString(input), parseString("t"));
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGreaterpWithTwoNumbers_ReturnsNil() {
|
public void testGreaterpWithTwoNumbers_ReturnsNil() {
|
||||||
String input = "(> 1 2)";
|
String input = "(> 1 2)";
|
||||||
|
@ -43,7 +50,7 @@ public class GREATERPTester {
|
||||||
|
|
||||||
@Test(expected = TooFewArgumentsException.class)
|
@Test(expected = TooFewArgumentsException.class)
|
||||||
public void testGreaterpWithTooFewArguments() {
|
public void testGreaterpWithTooFewArguments() {
|
||||||
evaluateString("(> 1)");
|
evaluateString("(>)");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,56 @@
|
||||||
|
package function.builtin;
|
||||||
|
|
||||||
|
import static testutil.TestUtilities.*;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import function.ArgumentValidator.*;
|
||||||
|
|
||||||
|
public class LESSPTester {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLesspWithOneNumber_ReturnsT() {
|
||||||
|
String input = "(< 1)";
|
||||||
|
|
||||||
|
assertSExpressionsMatch(evaluateString(input), parseString("t"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLesspWithTwoNumbers_ReturnsNil() {
|
||||||
|
String input = "(< 2 1)";
|
||||||
|
|
||||||
|
assertSExpressionsMatch(evaluateString(input), parseString("nil"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLesspWithTwoNumbers_ReturnsT() {
|
||||||
|
String input = "(< 2 3)";
|
||||||
|
|
||||||
|
assertSExpressionsMatch(evaluateString(input), parseString("t"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLesspWithManyNumbers_ReturnsNil() {
|
||||||
|
String input = "(< 4 3 2 5 1)";
|
||||||
|
|
||||||
|
assertSExpressionsMatch(evaluateString(input), parseString("nil"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testLesspWithManyNumbers_ReturnsT() {
|
||||||
|
String input = "(< 0 1 2 3 4)";
|
||||||
|
|
||||||
|
assertSExpressionsMatch(evaluateString(input), parseString("t"));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = BadArgumentTypeException.class)
|
||||||
|
public void testLesspWithNonNumbers() {
|
||||||
|
evaluateString("(< '(1) '(2))");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = TooFewArgumentsException.class)
|
||||||
|
public void testLesspWithTooFewArguments() {
|
||||||
|
evaluateString("(<)");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue