]> gerrit.simantics Code Review - simantics/platform.git/blob
b9625af78c5817621bb8f68245e6179f5336ea02
[simantics/platform.git] /
1 package org.simantics.scl.compiler.compilation;
2
3 import org.simantics.scl.compiler.common.names.Name;
4 import org.simantics.scl.compiler.elaboration.contexts.EnvironmentalContext;
5 import org.simantics.scl.compiler.elaboration.expressions.EConstant;
6 import org.simantics.scl.compiler.elaboration.expressions.EError;
7 import org.simantics.scl.compiler.elaboration.expressions.Expression;
8 import org.simantics.scl.compiler.elaboration.modules.SCLValue;
9 import org.simantics.scl.compiler.environment.Environment;
10 import org.simantics.scl.compiler.errors.ErrorLog;
11 import org.simantics.scl.compiler.errors.Locations;
12 import org.simantics.scl.compiler.internal.codegen.types.JavaTypeTranslator;
13 import org.simantics.scl.compiler.internal.codegen.utils.JavaNamingPolicy;
14 import org.simantics.scl.compiler.internal.header.ModuleHeader;
15 import org.simantics.scl.compiler.module.ConcreteModule;
16 import org.simantics.scl.compiler.module.repository.ModuleRepository;
17 import org.simantics.scl.compiler.types.Type;
18
19 import gnu.trove.map.hash.THashMap;
20
21 public class CompilationContext implements EnvironmentalContext {
22     public final ErrorLog errorLog = new ErrorLog();
23     public ModuleRepository moduleRepository;
24     public Environment environment;
25     public JavaTypeTranslator javaTypeTranslator;
26     public JavaNamingPolicy namingPolicy;
27     public ConcreteModule module;
28     public ModuleHeader header;
29     
30     private THashMap<Name, SCLValue> valueCache = new THashMap<Name, SCLValue>();
31
32     public SCLValue getValue(Name name) {
33         if(valueCache.containsKey(name))
34             return valueCache.get(name);
35         SCLValue value = environment.getValue(name);
36         if(value == null)
37             errorLog.log(Locations.NO_LOCATION, "Couldn't find " + name + ".");
38         valueCache.put(name, value);
39         return value;
40     }
41     
42     public Expression getConstant(Name name, Type ... typeParameters) {
43         SCLValue value = getValue(name);
44         if(value == null)
45             return new EError(Locations.NO_LOCATION);
46         return new EConstant(value, typeParameters);
47     }
48 }