slcom/slangc/model/expressions/InstanceofExpression.sauce

65 lines
1.9 KiB
Plaintext
Raw Normal View History

package slangc.model.expressions;
import slangc.api.BytecodeInstructionWriter;
import slangc.api.Reporter;
import slangc.bytecode.TypeSignature;
import slangc.model.ExpressionModel;
import slangc.model.ExpressionOwner;
import slangc.model.ExpressionResult;
import slangc.model.TypeModel;
import slangc.parser.Branch;
import slangc.parser.Node;
public class InstanceofExpression extends ExpressionModel implements ExpressionOwner {
TypeModel type;
ExpressionModel valueExpression;
public InstanceofExpression(ExpressionOwner owner, Node source) {
super(owner, source);
valueExpression = ExpressionModel.construct(this, ((Branch)source).getSubnode(0));
type = owner.resolveType(((Branch)source).getSubnode(2));
}
public TypeModel getType() {
return type;
}
public ExpressionModel getValueExpression() {
return valueExpression;
}
@Override
public void dump(Reporter reporter, String indent, String incr) {
reporter.note("DUMP", indent + "> Instanceof '" + type + "':");
dumpResolved(reporter, indent + incr, incr);
valueExpression.dump(reporter, indent + incr, incr);
}
@Override
public ExpressionModel[] getSubexpressions() {
return new ExpressionModel[] {valueExpression};
}
@Override
public TypeModel getExpectedResult(ExpressionModel e) {
// TODO: I'm not sure if there are cases where cast influences decoding of right-hand-side
return null;
}
@Override
protected ExpressionResult resolveResult() {
return new ExpressionResult.TypedValue((TypeModel)lookupSimpleName("boolean"));
}
@Override
public TypeSignature innerGenerate(BytecodeInstructionWriter w) {
TypeSignature incoming = valueExpression.generate(w);
w.genTypeCheck(incoming, getType().getTypeSignature());
return getSystem().getDefaultBooleanType().getTypeSignature();
}
public TypeModel resolveType(Node n) {
return super.resolveType(n); // TODO: Better support for interfaces
}
}