com.google.gwt.dev.CompilerContext Maven / Gradle / Ivy
/*
* Copyright 2013 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
* in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License
* is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
* or implied. See the License for the specific language governing permissions and limitations under
* the License.
*/
package com.google.gwt.dev;
import com.google.gwt.dev.cfg.LibraryBuilder;
import com.google.gwt.dev.cfg.LibraryGroup;
import com.google.gwt.dev.cfg.ModuleDef;
import com.google.gwt.dev.javac.UnitCache;
import com.google.gwt.dev.resource.ResourceOracle;
import com.google.gwt.thirdparty.guava.common.collect.Multimap;
import java.util.Set;
/**
* Contains most global read-only compiler state and makes it easily accessible to the far flung
* reaches of the compiler call graph without the constant accumulation of more and more function
* parameters.
*/
public class CompilerContext {
/**
* CompilerContext builder.
*/
public static class Builder {
private ResourceOracle buildResourceOracle;
private LibraryBuilder libraryBuilder;
private LibraryGroup libraryGroup;
private ModuleDef module;
private PrecompileTaskOptions options = new PrecompileTaskOptionsImpl();
private ResourceOracle publicResourceOracle;
private ResourceOracle sourceResourceOracle;
private UnitCache unitCache;
public CompilerContext build() {
CompilerContext compilerContext = new CompilerContext();
compilerContext.buildResourceOracle = buildResourceOracle;
compilerContext.libraryBuilder = libraryBuilder;
compilerContext.libraryGroup = libraryGroup;
compilerContext.module = module;
compilerContext.options = options;
compilerContext.publicResourceOracle = publicResourceOracle;
compilerContext.sourceResourceOracle = sourceResourceOracle;
compilerContext.unitCache = unitCache;
return compilerContext;
}
public Builder buildResourceOracle(ResourceOracle buildResourceOracle) {
this.buildResourceOracle = buildResourceOracle;
return this;
}
public Builder libraryBuilder(LibraryBuilder libraryBuilder) {
this.libraryBuilder = libraryBuilder;
return this;
}
public Builder libraryGroup(LibraryGroup libraryGroup) {
this.libraryGroup = libraryGroup;
return this;
}
public Builder module(ModuleDef module) {
this.module = module;
return this;
}
public Builder options(PrecompileTaskOptions options) {
this.options = options;
return this;
}
public Builder publicResourceOracle(ResourceOracle publicResourceOracle) {
this.publicResourceOracle = publicResourceOracle;
return this;
}
public Builder sourceResourceOracle(ResourceOracle sourceResourceOracle) {
this.sourceResourceOracle = sourceResourceOracle;
return this;
}
public Builder unitCache(UnitCache unitCache) {
this.unitCache = unitCache;
return this;
}
}
private ResourceOracle buildResourceOracle;
private LibraryBuilder libraryBuilder;
private LibraryGroup libraryGroup;
private ModuleDef module;
// TODO(stalcup): split this into module parsing, precompilation, compilation, and linking option
// sets.
private PrecompileTaskOptions options = new PrecompileTaskOptionsImpl();
private ResourceOracle publicResourceOracle;
private ResourceOracle sourceResourceOracle;
private UnitCache unitCache;
/**
* Walks the parts of the library dependency graph that have not run the given generator
* referenced by name and accumulates and returns a map from binding property name to newly legal
* values that were declared in those libraries.
*
* The resulting map represents the set of binding property changes that have not yet been taken
* into account in the output of a particular generator and which may need to trigger the
* re-execution of said generator.
*/
public Multimap gatherNewBindingPropertyValuesForGenerator(String generatorName) {
Multimap newBindingPropertyValues =
getLibraryGroup().gatherNewBindingPropertyValuesForGenerator(generatorName);
newBindingPropertyValues.putAll(libraryBuilder.getNewBindingPropertyValuesByName());
return newBindingPropertyValues;
}
/**
* Walks the parts of the library dependency graph that have not run the given generator
* referenced by name and accumulates and returns a map from configuration property name to newly
* set values that were declared in those libraries.
*
* The resulting map represents the set of configuration property value changes that have not yet
* been taken into account in the output of a particular generator and which may need to trigger
* the re-execution of said generator.
*/
public Multimap gatherNewConfigurationPropertyValuesForGenerator(
String generatorName) {
Multimap newConfigurationPropertyValues =
getLibraryGroup().gatherNewConfigurationPropertyValuesForGenerator(generatorName);
newConfigurationPropertyValues.putAll(libraryBuilder.getNewConfigurationPropertyValuesByName());
return newConfigurationPropertyValues;
}
public Set gatherNewReboundTypeNamesForGenerator(String generatorName) {
Set newReboundTypeNames =
getLibraryGroup().gatherNewReboundTypeNamesForGenerator(generatorName);
newReboundTypeNames.addAll(libraryBuilder.getReboundTypeNames());
return newReboundTypeNames;
}
public Set gatherOldReboundTypeNamesForGenerator(String generatorName) {
return getLibraryGroup().gatherOldReboundTypeNamesForGenerator(generatorName);
}
public ResourceOracle getBuildResourceOracle() {
return buildResourceOracle;
}
public LibraryBuilder getLibraryBuilder() {
return libraryBuilder;
}
public LibraryGroup getLibraryGroup() {
return libraryGroup;
}
public ModuleDef getModule() {
return module;
}
public PrecompileTaskOptions getOptions() {
return options;
}
public ResourceOracle getPublicResourceOracle() {
return publicResourceOracle;
}
public ResourceOracle getSourceResourceOracle() {
return sourceResourceOracle;
}
public UnitCache getUnitCache() {
return unitCache;
}
}