All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.snapscript.core.function.dispatch.ClosureDispatcher Maven / Gradle / Ivy
package org.snapscript.core.function.dispatch;
import static org.snapscript.core.constraint.Constraint.NONE;
import static org.snapscript.core.error.Reason.INVOKE;
import org.snapscript.core.constraint.Constraint;
import org.snapscript.core.error.ErrorHandler;
import org.snapscript.core.function.Connection;
import org.snapscript.core.function.Function;
import org.snapscript.core.function.index.FunctionAdapter;
import org.snapscript.core.function.resolve.FunctionCall;
import org.snapscript.core.function.resolve.FunctionResolver;
import org.snapscript.core.scope.Scope;
import org.snapscript.core.type.Type;
import org.snapscript.core.variable.Value;
public class ClosureDispatcher implements FunctionDispatcher {
private final FunctionResolver resolver;
private final ErrorHandler handler;
private final String name;
public ClosureDispatcher(FunctionResolver resolver, ErrorHandler handler, String name) {
this.handler = handler;
this.resolver = resolver;
this.name = name;
}
@Override
public Constraint compile(Scope scope, Constraint constraint, Type... arguments) throws Exception {
return NONE;
}
@Override
public Connection connect(Scope scope, Value value, Object... arguments) throws Exception {
Function function = value.getValue();
Connection call = bind(scope, function, arguments); // this is not used often
if(call == null) {
handler.handleRuntimeError(INVOKE, scope, function, name, arguments);
}
return call;
}
private Connection bind(Scope scope, Function function, Object... arguments) throws Exception {
FunctionCall call = resolver.resolveInstance(scope, function, name, arguments); // this is not used often
if(call == null) {
Object adapter = FunctionAdapter.wrap(function);
FunctionCall instance = resolver.resolveInstance(scope, adapter, name, arguments);
if(instance != null) {
return new ClosureConnection(instance, true);
}
return null;
}
return new ClosureConnection(call, false);
}
private static class ClosureConnection implements Connection {
private final FunctionCall call;
private final boolean wrap;
public ClosureConnection(FunctionCall call, boolean wrap) {
this.wrap = wrap;
this.call = call;
}
@Override
public boolean match(Scope scope, Object object, Object... arguments) throws Exception {
return call.match(scope, object, arguments);
}
@Override
public Object invoke(Scope scope, Value value, Object... arguments) throws Exception {
Function function = value.getValue();
if(wrap) {
FunctionAdapter adapter = FunctionAdapter.wrap(function);
return call.invoke(scope, adapter, arguments);
}
return call.invoke(scope, function, arguments);
}
}
}