]> gerrit.simantics Code Review - simantics/platform.git/blob - bundles/org.simantics.scl.compiler/src/org/simantics/scl/compiler/elaboration/expressions/EGetConstraint.java
Fixed multiple issues causing dangling references to discarded queries
[simantics/platform.git] / bundles / org.simantics.scl.compiler / src / org / simantics / scl / compiler / elaboration / expressions / EGetConstraint.java
1 package org.simantics.scl.compiler.elaboration.expressions;
2
3 import org.simantics.scl.compiler.elaboration.contexts.SimplificationContext;
4 import org.simantics.scl.compiler.elaboration.contexts.TranslationContext;
5 import org.simantics.scl.compiler.elaboration.contexts.TypingContext;
6 import org.simantics.scl.compiler.errors.Locations;
7 import org.simantics.scl.compiler.types.TPred;
8 import org.simantics.scl.compiler.types.exceptions.MatchException;
9
10 public class EGetConstraint extends SimplifiableExpression {
11     TPred constraint;
12     public EVariable evidence;
13         
14     public EGetConstraint(long loc, TPred constraint) {
15         super(loc);
16         this.constraint = constraint;
17     }
18     
19     @Override
20     public Expression inferType(TypingContext context) {
21         Variable variable = new Variable("evidence");
22         variable.setType(constraint);
23         evidence = new EVariable(getLocation(), variable);
24         evidence.setType(variable.getType());
25         context.addConstraintDemand(evidence);
26         return this;
27     }
28     
29     @Override
30     protected void updateType() throws MatchException {
31         setType(constraint);
32     }
33     
34     @Override
35     public Expression simplify(SimplificationContext context) {
36         return evidence.simplify(context);
37     }
38     
39     @Override
40     public Expression resolve(TranslationContext context) {
41         return this;
42     }
43     
44     @Override
45     public void setLocationDeep(long loc) {
46         if(location == Locations.NO_LOCATION) {
47             location = loc;
48             if(evidence != null)
49                 evidence.setLocationDeep(loc);
50         }
51     }
52     
53     @Override
54     public void accept(ExpressionVisitor visitor) {
55         visitor.visit(this);
56     }
57     
58     @Override
59     public Expression accept(ExpressionTransformer transformer) {
60         return transformer.transform(this);
61     }
62
63 }