]> gerrit.simantics Code Review - simantics/platform.git/blob
872da88f11c313659c247106f1b266c4f2cddd5d
[simantics/platform.git] /
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.internal.parsing.types.TypeAst;
8 import org.simantics.scl.compiler.types.Type;
9 import org.simantics.scl.compiler.types.exceptions.MatchException;
10
11 import gnu.trove.map.hash.TObjectIntHashMap;
12 import gnu.trove.set.hash.TIntHashSet;
13
14 public class ETypeAnnotation extends SimplifiableExpression {
15     public Expression value;
16     Type type;
17     TypeAst typeAst;
18         
19     public ETypeAnnotation(Expression value, TypeAst typeAst) {
20         this.value = value;
21         this.typeAst = typeAst;
22     }
23
24     public ETypeAnnotation(long loc, Expression value, Type type) {
25         super(loc);
26         this.value = value;
27         this.type = type;
28     }
29
30     @Override
31     public void collectVars(TObjectIntHashMap<Variable> allVars,
32             TIntHashSet vars) {
33         value.collectVars(allVars, vars);
34     }
35
36     @Override
37     protected void updateType() throws MatchException {
38         setType(type);
39     }
40
41     @Override
42     public Expression simplify(SimplificationContext context) {
43         return value.simplify(context);
44     }
45
46     @Override
47     public Expression resolve(TranslationContext context) {
48         value = value.resolve(context);
49         type = context.toType(typeAst);
50         return this;
51     }
52     
53     @Override
54     public Expression resolveAsPattern(TranslationContext context) {
55         value = value.resolveAsPattern(context);
56         type = context.toType(typeAst);
57         return this;
58     }
59     
60     @Override
61     public Expression inferType(TypingContext context) {
62         return value.checkType(context, type);
63     }
64     
65     @Override
66     public void setLocationDeep(long loc) {
67         if(location == Locations.NO_LOCATION) {
68             location = loc;
69             value.setLocationDeep(loc);
70         }
71     }
72     
73     @Override
74     public void accept(ExpressionVisitor visitor) {
75         visitor.visit(this);
76     }
77     
78     public Expression getValue() {
79         return value;
80     }
81     
82     @Override
83     public Expression accept(ExpressionTransformer transformer) {
84         return transformer.transform(this);
85     }
86
87 }