2016-12-19 13:05:53 -05:00
|
|
|
package function.builtin;
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
import java.text.MessageFormat;
|
|
|
|
|
|
|
|
import error.LispException;
|
2016-12-19 13:05:53 -05:00
|
|
|
import function.*;
|
2016-12-15 15:33:48 -05:00
|
|
|
import sexpression.*;
|
2017-01-29 14:33:46 -05:00
|
|
|
import table.FunctionTable;
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-02-26 16:47:06 -05:00
|
|
|
@FunctionNames({ "SYMBOL-FUNCTION" })
|
2016-12-07 16:38:26 -05:00
|
|
|
public class SYMBOL_FUNCTION extends LispFunction {
|
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
private ArgumentValidator argumentValidator;
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
public SYMBOL_FUNCTION() {
|
|
|
|
this.argumentValidator = new ArgumentValidator("SYMBOL-FUNCTION");
|
|
|
|
this.argumentValidator.setExactNumberOfArguments(1);
|
|
|
|
this.argumentValidator.setEveryArgumentExpectedType(Symbol.class);
|
|
|
|
}
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
public SExpression call(Cons argumentList) {
|
|
|
|
argumentValidator.validate(argumentList);
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-02-24 11:07:06 -05:00
|
|
|
SExpression symbol = argumentList.getFirst();
|
2017-01-29 14:33:46 -05:00
|
|
|
LispFunction function = FunctionTable.lookupFunction(symbol.toString());
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-02-27 14:10:20 -05:00
|
|
|
if (function != null)
|
2017-02-27 14:54:31 -05:00
|
|
|
return createRepresentation(symbol, function);
|
2017-02-06 13:43:27 -05:00
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
throw new UndefinedSymbolFunctionException(symbol);
|
|
|
|
}
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-02-27 14:54:31 -05:00
|
|
|
private SExpression createRepresentation(SExpression symbol, LispFunction function) {
|
2017-02-27 14:10:20 -05:00
|
|
|
if (function instanceof UserDefinedFunction)
|
|
|
|
return ((UserDefinedFunction) function).getLambdaExpression();
|
|
|
|
|
2017-02-27 14:54:31 -05:00
|
|
|
String typeIndicator = function instanceof LispSpecialFunction ? "SPECIAL-FUNCTION" : "FUNCTION";
|
|
|
|
|
|
|
|
return new Symbol(MessageFormat.format("#<{0} {1}>", typeIndicator, symbol));
|
2017-02-27 14:10:20 -05:00
|
|
|
}
|
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
public static class UndefinedSymbolFunctionException extends LispException {
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
private static final long serialVersionUID = 1L;
|
|
|
|
private SExpression function;
|
2016-12-07 16:38:26 -05:00
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
public UndefinedSymbolFunctionException(SExpression function) {
|
|
|
|
this.function = function;
|
2016-12-07 16:38:26 -05:00
|
|
|
}
|
|
|
|
|
2017-01-22 11:11:16 -05:00
|
|
|
@Override
|
|
|
|
public String getMessage() {
|
|
|
|
return MessageFormat.format("SYMBOL-FUNCTION: undefined function: {0}", function);
|
|
|
|
}
|
2016-12-07 16:38:26 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|