All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.javascript.jscomp.CompilerOptions Maven / Gradle / Ivy

Go to download

Closure Compiler is a JavaScript optimizing compiler. It parses your JavaScript, analyzes it, removes dead code and rewrites and minimizes what's left. It also checks syntax, variable references, and types, and warns about common JavaScript pitfalls. It is used in many of Google's JavaScript apps, including Gmail, Google Web Search, Google Maps, and Google Docs.

There is a newer version: v20240317
Show newest version
/*
 * Copyright 2009 The Closure Compiler Authors.
 *
 * 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.javascript.jscomp;

import com.google.common.base.Preconditions;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import com.google.common.collect.Multimap;
import com.google.common.collect.Sets;
import com.google.javascript.rhino.Node;
import com.google.javascript.rhino.SourcePosition;
import com.google.javascript.rhino.Token;

import java.io.Serializable;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Set;

/**
 * Compiler options
 * @author [email protected] (Nick Santos)
 */
public class CompilerOptions implements Serializable, Cloneable {
  // TODO(nicksantos): All public properties of this class should be made
  // package-private, and have a public setter.

  private static final long serialVersionUID = 7L;

  /**
   * The JavaScript language version accepted.
   */
  private LanguageMode languageIn;

  /**
   * The JavaScript language version accepted.
   */
  private LanguageMode languageOut;

  /**
   * Whether the compiler handles `const' keyword or not.
   */
  boolean acceptConstKeyword;

  /**
   * Whether the compiler should assume that a function's "this" value
   * never needs coercion (for example in non-strict "null" or "undefined" will
   * be coerced to the global "this" and primitives to objects).
   */
  private boolean assumeStrictThis;

  // TODO(johnlenz): Add an language output mode.

  /**
   * Configures the compiler for use as an IDE backend.  In this mode:
   * 
    *
  • No optimization passes will run.
  • *
  • The last time custom passes are invoked is * {@link CustomPassExecutionTime#BEFORE_OPTIMIZATIONS}
  • *
  • The compiler will always try to process all inputs fully, even * if it encounters errors.
  • *
  • The compiler may record more information than is strictly * needed for codegen.
  • *
*/ public boolean ideMode; /** * Even if checkTypes is disabled, clients might want to still infer types. * This is mostly used when ideMode is enabled. */ boolean inferTypes; /** * Configures the compiler to skip as many passes as possible. */ boolean skipAllPasses; /** * If true, name anonymous functions only. All others passes will be skipped. */ boolean nameAnonymousFunctionsOnly; /** * Configures the compiler to run expensive sanity checks after * every pass. Only intended for internal development. */ DevMode devMode; //-------------------------------- // Input Options //-------------------------------- boolean manageClosureDependencies = false; List manageClosureDependenciesEntryPoints = ImmutableList.of(); /** Returns localized replacement for MSG_* variables */ // Transient so that clients don't have to implement Serializable. public transient MessageBundle messageBundle = null; //-------------------------------- // Checks //-------------------------------- /** Checks that all symbols are defined */ public boolean checkSymbols; public CheckLevel checkShadowVars; /** * Checks that all variables with the @noshadow attribute are * never shadowed. */ public void setCheckShadowVars(CheckLevel level) { this.checkShadowVars = level; } public CheckLevel aggressiveVarCheck; /** Checks for suspicious variable definitions and undefined variables */ public void setAggressiveVarCheck(CheckLevel level) { this.aggressiveVarCheck = level; } public CheckLevel checkFunctions; /** Checks function arity */ public void setCheckFunctions(CheckLevel level) { this.checkFunctions = level; } public CheckLevel checkMethods; /** Checks method arity */ public void setCheckMethods(CheckLevel level) { this.checkMethods = level; } /** Makes sure no duplicate messages */ public boolean checkDuplicateMessages; /** Allows old deprecated js message style */ public boolean allowLegacyJsMessages; /** * Whether we should throw an exception in case if the message absent from a * bundle. */ public boolean strictMessageReplacement; /** Checks for suspicious statements that have no effect */ public boolean checkSuspiciousCode; /** Checks for invalid control structures */ public boolean checkControlStructures; /** Checks types on expressions */ public boolean checkTypes; /** Tightens types based on a global analysis. */ public boolean tightenTypes; // TODO(user): A temporary flag to prevent the type inference from // running in the global scope because it takes too long to finish. /** Runs a flow sensitive type inference in the global scope */ public boolean inferTypesInGlobalScope; /** Checks for inexistant property calls */ public boolean checkTypedPropertyCalls; public CheckLevel reportMissingOverride; /** * Flags a warning if a property is missing the @override annotation, but it * overrides a base class property. */ public void setReportMissingOverride(CheckLevel level) { this.reportMissingOverride = level; } public CheckLevel reportUnknownTypes; /** Flags a warning for every node whose type could not be determined. */ public void setReportUnknownTypes(CheckLevel level) { this.reportUnknownTypes = level; } /** Checks for missing goog.require() calls **/ public CheckLevel checkRequires; public void setCheckRequires(CheckLevel level) { this.checkRequires = level; } public CheckLevel checkProvides; /** Checks for missing goog.provides() calls **/ public void setCheckProvides(CheckLevel level) { this.checkProvides = level; } public CheckLevel checkGlobalNamesLevel; /** * Checks the integrity of references to qualified global names. * (e.g. "a.b") */ public void setCheckGlobalNamesLevel(CheckLevel level) { this.checkGlobalNamesLevel = level; } public CheckLevel brokenClosureRequiresLevel; /** Sets the check level for bad Closure require calls. */ public void setBrokenClosureRequiresLevel(CheckLevel level) { this.brokenClosureRequiresLevel = level; } public CheckLevel checkGlobalThisLevel; /** * Checks for certain uses of the {@code this} keyword that are considered * unsafe because they are likely to reference the global {@code this} * object unintentionally. * * If this is off, but collapseProperties is on, then the compiler will * usually ignore you and run this check anyways. */ public void setCheckGlobalThisLevel(CheckLevel level) { this.checkGlobalThisLevel = level; } public CheckLevel checkMissingGetCssNameLevel; /** * Checks that certain string literals only appear in strings used as * goog.getCssName arguments. */ public void setCheckMissingGetCssNameLevel(CheckLevel level) { this.checkMissingGetCssNameLevel = level; } /** * Regex of string literals that may only appear in goog.getCssName arguments. */ public String checkMissingGetCssNameBlacklist; /** Checks that the synctactic restrictions of ES5 strict mode are met. */ // TODO(johnlenz): remove this. public boolean checkEs5Strict; /** Checks that the synctactic restrictions of Caja are met. */ public boolean checkCaja; /** * A set of extra annotation names which are accepted and silently ignored * when encountered in a source file. Defaults to null which has the same * effect as specifying an empty set. */ Set extraAnnotationNames; //-------------------------------- // Optimizations //-------------------------------- /** Folds constants (e.g. (2 + 3) to 5) */ public boolean foldConstants; /** Remove assignments to values that can not be referenced */ public boolean deadAssignmentElimination; /** Inlines constants (symbols that are all CAPS) */ public boolean inlineConstantVars; /** Inlines short functions */ public boolean inlineFunctions; /** Enhanced function inlining */ public boolean decomposeExpressions; /** Enhanced function inlining */ public boolean inlineAnonymousFunctionExpressions; /** Enhanced function inlining */ public boolean inlineLocalFunctions; /** Move code to a deeper module */ public boolean crossModuleCodeMotion; /** Merge two variables together as one. */ public boolean coalesceVariableNames; /** Move methds to a deeper module */ public boolean crossModuleMethodMotion; /** Inlines trivial getters */ public boolean inlineGetters; /** Inlines variables */ public boolean inlineVariables; /** Inlines variables */ public boolean inlineLocalVariables; // TODO(user): This is temporary. Once flow sensitive inlining is stable // Remove this. public boolean flowSensitiveInlineVariables; /** Removes code associated with unused global names */ public boolean smartNameRemoval; /** Removes code that will never execute */ public boolean removeDeadCode; public CheckLevel checkUnreachableCode; /** Checks for unreachable code */ public void setCheckUnreachableCode(CheckLevel level) { this.checkUnreachableCode = level; } public CheckLevel checkMissingReturn; /** Checks for missing return statements */ public void setCheckMissingReturn(CheckLevel level) { this.checkMissingReturn = level; } /** Extracts common prototype member declarations */ public boolean extractPrototypeMemberDeclarations; /** Removes functions that have no body */ public boolean removeEmptyFunctions; /** Removes unused member prototypes */ public boolean removeUnusedPrototypeProperties; /** Tells AnalyzePrototypeProperties it can remove externed props. */ public boolean removeUnusedPrototypePropertiesInExterns; /** Removes unused variables */ public boolean removeUnusedVars; /** Removes unused variables in local scope. */ public boolean removeUnusedLocalVars; /** Adds variable aliases for externals to reduce code size */ public boolean aliasExternals; /** * If set to a non-empty string, then during an alias externals pass only * externals with these names will be considered for aliasing. */ public String aliasableGlobals; /** * Additional globals that can not be aliased since they may be undefined or * can cause errors. Comma separated list of symbols. e.g. "foo,bar" */ public String unaliasableGlobals; /** Collapses multiple variable declarations into one */ public boolean collapseVariableDeclarations; /** Group multiple variable declarations into one */ public boolean groupVariableDeclarations; /** * Collapses anonymous function declarations into named function * declarations */ public boolean collapseAnonymousFunctions; /** * If set to a non-empty set, those strings literals will be aliased to a * single global instance per string, to avoid creating more objects than * necessary. */ public Set aliasableStrings; /** * A blacklist in the form of a regular expression to block strings that * contains certain words from being aliased. * If the value is the empty string, no words are blacklisted. */ public String aliasStringsBlacklist; /** * Aliases all string literals to global instances, to avoid creating more * objects than necessary (if true, overrides any set of strings passed in * to aliasableStrings) */ public boolean aliasAllStrings; /** Print string usage as part of the compilation log. */ boolean outputJsStringUsage; /** Converts quoted property accesses to dot syntax (a['b'] -> a.b) */ public boolean convertToDottedProperties; /** Reduces the size of common function expressions. */ public boolean rewriteFunctionExpressions; /** * Remove unused and constant parameters. */ public boolean optimizeParameters; /** * Remove unused return values. */ public boolean optimizeReturns; /** * Remove unused parameters from call sites. */ public boolean optimizeCalls; /** * Provide formal names for elements of arguments array. */ public boolean optimizeArgumentsArray; /** Chains calls to functions that return this. */ boolean chainCalls; //-------------------------------- // Renaming //-------------------------------- /** Controls which variables get renamed. */ public VariableRenamingPolicy variableRenaming; /** Controls which properties get renamed. */ public PropertyRenamingPolicy propertyRenaming; /** Should we use affinity information when generating property names. */ boolean propertyAffinity; /** Controls label renaming. */ public boolean labelRenaming; /** Reserve property names on the global this object. */ public boolean reserveRawExports; /** Should shadow variable names in outer scope. */ boolean shadowVariables; /** * Generate pseudo names for variables and properties for debugging purposes. */ public boolean generatePseudoNames; /** Specifies a prefix for all globals */ public String renamePrefix; /** Aliases true, false, and null to variables with shorter names. */ public boolean aliasKeywords; /** Flattens multi-level property names (e.g. a$b = x) */ public boolean collapseProperties; /** Split object literals into individual variables when possible. */ public boolean collapseObjectLiterals; /** Flattens multi-level property names on extern types (e.g. String$f = x) */ boolean collapsePropertiesOnExternTypes; /** * Devirtualize prototype method by rewriting them to be static calls that * take the this pointer as their first argument */ public boolean devirtualizePrototypeMethods; /** * Use @nosideeffects annotations, function bodies and name graph * to determine if calls have side effects. Requires --check_types. */ public boolean computeFunctionSideEffects; /** * Where to save debug report for compute function side effects. */ public String debugFunctionSideEffectsPath; /** * Rename properties to disambiguate between unrelated fields based on * type information. */ public boolean disambiguateProperties; /** Rename unrelated properties to the same name to reduce code size. */ public boolean ambiguateProperties; /** Give anonymous functions names for easier debugging */ public AnonymousFunctionNamingPolicy anonymousFunctionNaming; /** Serialized input variable renaming map. */ public byte[] inputVariableMapSerialized; /** Serialized input property renaming map. */ public byte[] inputPropertyMapSerialized; /** Whether to export test functions. */ public boolean exportTestFunctions; /** Specialize the initial module at the cost of later modules */ public boolean specializeInitialModule; //-------------------------------- // Special-purpose alterations //-------------------------------- /** Inserts runtime type assertions for debugging. */ boolean runtimeTypeCheck; /** * A JS function to be used for logging runtime type assertion * failures. It will be passed the warning as a string and the * faulty expression as arguments. */ String runtimeTypeCheckLogFunction; /** A CodingConvention to use during the compile. */ private CodingConvention codingConvention; /** Instrument code for the purpose of collecting coverage data. */ public boolean instrumentForCoverage; /** * Instrument code for the purpose of collecting coverage data - restrict to * coverage pass only, and skip all other passes. */ public boolean instrumentForCoverageOnly; /** Add code to skip properties that Caja adds to Object.prototype */ public boolean ignoreCajaProperties; public String syntheticBlockStartMarker; public String syntheticBlockEndMarker; /** Compiling locale */ public String locale; /** Sets the special "COMPILED" value to true */ public boolean markAsCompiled; /** Removes try...catch...finally blocks for easier debugging */ public boolean removeTryCatchFinally; /** Processes goog.provide() and goog.require() calls */ public boolean closurePass; /** Rewrite new Date(goog.now()) to new Date(). */ boolean rewriteNewDateGoogNow; /** Remove goog.abstractMethod assignments. */ boolean removeAbstractMethods; /** Remove goog.asserts calls. */ boolean removeClosureAsserts; /** Gather CSS names (requires closurePass) */ public boolean gatherCssNames; /** Names of types to strip */ public Set stripTypes; /** Name suffixes that determine which variables and properties to strip */ public Set stripNameSuffixes; /** Name prefixes that determine which variables and properties to strip */ public Set stripNamePrefixes; /** Qualified type name prefixes that determine which types to strip */ public Set stripTypePrefixes; /** Custom passes */ public transient Multimap customPasses; /** Mark no side effect calls */ public boolean markNoSideEffectCalls; /** Replacements for @defines. Will be Boolean, Numbers, or Strings */ private Map defineReplacements; /** What kind of processing to do for goog.tweak functions. */ private TweakProcessing tweakProcessing; /** Replacements for tweaks. Will be Boolean, Numbers, or Strings */ private Map tweakReplacements; /** Move top level function declarations to the top */ public boolean moveFunctionDeclarations; /** Instrumentation template to use */ public String instrumentationTemplate; /** * App identifier string for use by the instrumentation template's * app_name_setter */ public String appNameStr; /** Record function information */ public boolean recordFunctionInformation; public boolean generateExports; /** Map used in the renaming of CSS class names. */ public CssRenamingMap cssRenamingMap; /** Process instances of goog.testing.ObjectPropertyString. */ boolean processObjectPropertyString; /** Id generators to replace. */ Set idGenerators; /** Configuration strings */ List replaceStringsFunctionDescriptions; String replaceStringsPlaceholderToken; // A list of strings that should not be used as replacements Set replaceStringsReservedStrings; // Fixes open source issue: 390 boolean operaCompoundAssignFix; //-------------------------------- // Output options //-------------------------------- /** Output in pretty indented format */ public boolean prettyPrint; /** Line break the output a bit more aggressively */ public boolean lineBreak; /** Prints a separator comment before each js script */ public boolean printInputDelimiter; /** The string to use as the separator for printInputDelimiter */ public String inputDelimiter = "// Input %num%"; /** Where to save a report of global name usage */ public String reportPath; public TracerMode tracer; private boolean colorizeErrorOutput; public ErrorFormat errorFormat; public String jsOutputFile; private ComposeWarningsGuard warningsGuard = new ComposeWarningsGuard(); int summaryDetailLevel = 1; int lineLengthThreshold = CodePrinter.DEFAULT_LINE_LENGTH_THRESHOLD; //-------------------------------- // Special Output Options //-------------------------------- /** * Whether the exports should be made available via {@link Result} after * compilation. This is implicitly true if {@link #externExportsPath} is set. */ private boolean externExports; /** The output path for the created externs file. */ String externExportsPath; /** Where to save a cross-reference report from the name reference graph */ public String nameReferenceReportPath; /** Where to save the name reference graph */ public String nameReferenceGraphPath; //-------------------------------- // Debugging Options //-------------------------------- /** The output path for the source map. */ public String sourceMapOutputPath; /** The detail level for the generated source map. */ public SourceMap.DetailLevel sourceMapDetailLevel = SourceMap.DetailLevel.SYMBOLS; /** The source map file format */ public SourceMap.Format sourceMapFormat = SourceMap.Format.DEFAULT; public List sourceMapLocationMappings = Collections.emptyList(); /** * Charset to use when generating code. If null, then output ASCII. * This needs to be a string because CompilerOptions is serializable. */ String outputCharset; /** * Whether the named objects types included 'undefined' by default. */ boolean looseTypes; /** * Data holder Alias Transformation information accumulated during a compile. */ private transient AliasTransformationHandler aliasHandler; /** * Initializes compiler options. All options are disabled by default. * * Command-line frontends to the compiler should set these properties * like a builder. */ public CompilerOptions() { // Accepted language languageIn = LanguageMode.ECMASCRIPT3; // Language variation acceptConstKeyword = false; // Checks skipAllPasses = false; nameAnonymousFunctionsOnly = false; devMode = DevMode.OFF; checkSymbols = false; checkShadowVars = CheckLevel.OFF; aggressiveVarCheck = CheckLevel.OFF; checkFunctions = CheckLevel.OFF; checkMethods = CheckLevel.OFF; checkDuplicateMessages = false; allowLegacyJsMessages = false; strictMessageReplacement = false; checkSuspiciousCode = false; checkControlStructures = false; checkTypes = false; tightenTypes = false; inferTypesInGlobalScope = false; checkTypedPropertyCalls = false; reportMissingOverride = CheckLevel.OFF; reportUnknownTypes = CheckLevel.OFF; checkRequires = CheckLevel.OFF; checkProvides = CheckLevel.OFF; checkGlobalNamesLevel = CheckLevel.OFF; brokenClosureRequiresLevel = CheckLevel.ERROR; checkGlobalThisLevel = CheckLevel.OFF; checkUnreachableCode = CheckLevel.OFF; checkMissingReturn = CheckLevel.OFF; checkMissingGetCssNameLevel = CheckLevel.OFF; checkMissingGetCssNameBlacklist = null; checkCaja = false; computeFunctionSideEffects = false; chainCalls = false; extraAnnotationNames = null; // Optimizations foldConstants = false; coalesceVariableNames = false; deadAssignmentElimination = false; inlineConstantVars = false; inlineFunctions = false; inlineLocalFunctions = false; assumeStrictThis = false; crossModuleCodeMotion = false; crossModuleMethodMotion = false; inlineGetters = false; inlineVariables = false; inlineLocalVariables = false; smartNameRemoval = false; removeDeadCode = false; extractPrototypeMemberDeclarations = false; removeUnusedPrototypeProperties = false; removeUnusedPrototypePropertiesInExterns = false; removeUnusedVars = false; removeUnusedLocalVars = false; aliasExternals = false; collapseVariableDeclarations = false; groupVariableDeclarations = false; collapseAnonymousFunctions = false; aliasableStrings = Collections.emptySet(); aliasStringsBlacklist = ""; aliasAllStrings = false; outputJsStringUsage = false; convertToDottedProperties = false; rewriteFunctionExpressions = false; optimizeParameters = false; optimizeReturns = false; // Renaming variableRenaming = VariableRenamingPolicy.OFF; propertyRenaming = PropertyRenamingPolicy.OFF; propertyAffinity = false; labelRenaming = false; generatePseudoNames = false; shadowVariables = false; renamePrefix = null; aliasKeywords = false; collapseProperties = false; collapsePropertiesOnExternTypes = false; collapseObjectLiterals = false; devirtualizePrototypeMethods = false; disambiguateProperties = false; ambiguateProperties = false; anonymousFunctionNaming = AnonymousFunctionNamingPolicy.OFF; exportTestFunctions = false; // Alterations runtimeTypeCheck = false; runtimeTypeCheckLogFunction = null; instrumentForCoverage = false; instrumentForCoverageOnly = false; ignoreCajaProperties = false; syntheticBlockStartMarker = null; syntheticBlockEndMarker = null; locale = null; markAsCompiled = false; removeTryCatchFinally = false; closurePass = false; rewriteNewDateGoogNow = true; removeAbstractMethods = true; removeClosureAsserts = false; stripTypes = Collections.emptySet(); stripNameSuffixes = Collections.emptySet(); stripNamePrefixes = Collections.emptySet(); stripTypePrefixes = Collections.emptySet(); customPasses = null; markNoSideEffectCalls = false; defineReplacements = Maps.newHashMap(); tweakProcessing = TweakProcessing.OFF; tweakReplacements = Maps.newHashMap(); moveFunctionDeclarations = false; instrumentationTemplate = null; appNameStr = ""; recordFunctionInformation = false; generateExports = false; cssRenamingMap = null; processObjectPropertyString = false; idGenerators = Collections.emptySet(); replaceStringsFunctionDescriptions = Collections.emptyList(); replaceStringsPlaceholderToken = ""; replaceStringsReservedStrings = Collections.emptySet(); // Output printInputDelimiter = false; prettyPrint = false; lineBreak = false; reportPath = null; tracer = TracerMode.OFF; colorizeErrorOutput = false; errorFormat = ErrorFormat.SINGLELINE; debugFunctionSideEffectsPath = null; jsOutputFile = ""; externExports = false; nameReferenceReportPath = null; nameReferenceGraphPath = null; // Debugging aliasHandler = NULL_ALIAS_TRANSFORMATION_HANDLER; operaCompoundAssignFix = true; } /** * Returns the map of define replacements. */ public Map getDefineReplacements() { return getReplacementsHelper(defineReplacements); } /** * Returns the map of tweak replacements. */ public Map getTweakReplacements() { return getReplacementsHelper(tweakReplacements); } /** * Creates a map of String->Node from a map of String->Number/String/Boolean. */ private static Map getReplacementsHelper( Map source) { Map map = Maps.newHashMap(); for (Map.Entry entry : source.entrySet()) { String name = entry.getKey(); Object value = entry.getValue(); if (value instanceof Boolean) { map.put(name, ((Boolean) value).booleanValue() ? new Node(Token.TRUE) : new Node(Token.FALSE)); } else if (value instanceof Integer) { map.put(name, Node.newNumber(((Integer) value).intValue())); } else if (value instanceof Double) { map.put(name, Node.newNumber(((Double) value).doubleValue())); } else { Preconditions.checkState(value instanceof String); map.put(name, Node.newString((String) value)); } } return map; } /** * Sets the value of the {@code @define} variable in JS * to a boolean literal. */ public void setDefineToBooleanLiteral(String defineName, boolean value) { defineReplacements.put(defineName, new Boolean(value)); } /** * Sets the value of the {@code @define} variable in JS to a * String literal. */ public void setDefineToStringLiteral(String defineName, String value) { defineReplacements.put(defineName, value); } /** * Sets the value of the {@code @define} variable in JS to a * number literal. */ public void setDefineToNumberLiteral(String defineName, int value) { defineReplacements.put(defineName, new Integer(value)); } /** * Sets the value of the {@code @define} variable in JS to a * number literal. */ public void setDefineToDoubleLiteral(String defineName, double value) { defineReplacements.put(defineName, new Double(value)); } /** * Sets the value of the tweak in JS * to a boolean literal. */ public void setTweakToBooleanLiteral(String tweakId, boolean value) { tweakReplacements.put(tweakId, new Boolean(value)); } /** * Sets the value of the tweak in JS to a * String literal. */ public void setTweakToStringLiteral(String tweakId, String value) { tweakReplacements.put(tweakId, value); } /** * Sets the value of the tweak in JS to a * number literal. */ public void setTweakToNumberLiteral(String tweakId, int value) { tweakReplacements.put(tweakId, new Integer(value)); } /** * Sets the value of the tweak in JS to a * number literal. */ public void setTweakToDoubleLiteral(String tweakId, double value) { tweakReplacements.put(tweakId, new Double(value)); } /** * Skip all possible passes, to make the compiler as fast as possible. */ public void skipAllCompilerPasses() { skipAllPasses = true; } /** * Whether the warnings guard in this Options object enables the given * group of warnings. */ boolean enables(DiagnosticGroup type) { return warningsGuard.enables(type); } /** * Whether the warnings guard in this Options object disables the given * group of warnings. */ boolean disables(DiagnosticGroup type) { return warningsGuard.disables(type); } /** * Configure the given type of warning to the given level. */ public void setWarningLevel(DiagnosticGroup type, CheckLevel level) { addWarningsGuard(new DiagnosticGroupWarningsGuard(type, level)); } WarningsGuard getWarningsGuard() { return warningsGuard; } /** * Reset the warnings guard. */ public void resetWarningsGuard() { warningsGuard = new ComposeWarningsGuard(); } /** * The emergency fail safe removes all strict and ERROR-escalating * warnings guards. */ void useEmergencyFailSafe() { warningsGuard = warningsGuard.makeEmergencyFailSafeGuard(); } /** * Add a guard to the set of warnings guards. */ public void addWarningsGuard(WarningsGuard guard) { warningsGuard.addGuard(guard); } /** * Sets the variable and property renaming policies for the compiler, * in a way that clears warnings about the renaming policy being * uninitialized from flags. */ public void setRenamingPolicy(VariableRenamingPolicy newVariablePolicy, PropertyRenamingPolicy newPropertyPolicy) { this.variableRenaming = newVariablePolicy; this.propertyRenaming = newPropertyPolicy; } public void setPropertyAffinity(boolean useAffinity) { this.propertyAffinity = useAffinity; } /** Should shadow outer scope variable name during renaming. */ public void setShadowVariables(boolean shadow) { this.shadowVariables = shadow; } /** * If true, flattens multi-level property names on extern types * (e.g. String$f = x). This should only be used with the typed version of * the externs files. */ public void setCollapsePropertiesOnExternTypes(boolean collapse) { collapsePropertiesOnExternTypes = collapse; } /** * If true, process goog.testing.ObjectPropertyString instances. */ public void setProcessObjectPropertyString(boolean process) { processObjectPropertyString = process; } /** * Sets the id generators to replace. */ public void setIdGenerators(Set idGenerators) { this.idGenerators = Sets.newHashSet(idGenerators); } /** * Sets the functions whose debug strings to replace. */ public void setReplaceStringsConfiguration( String placeholderToken, List functionDescriptors) { this.replaceStringsPlaceholderToken = placeholderToken; this.replaceStringsFunctionDescriptions = Lists.newArrayList(functionDescriptors); } public void setRewriteNewDateGoogNow(boolean rewrite) { this.rewriteNewDateGoogNow = rewrite; } public void setRemoveAbstractMethods(boolean remove) { this.removeAbstractMethods = remove; } public void setRemoveClosureAsserts(boolean remove) { this.removeClosureAsserts = remove; } /** * If true, name anonymous functions only. All other passes will be skipped. */ public void setNameAnonymousFunctionsOnly(boolean value) { this.nameAnonymousFunctionsOnly = value; } public void lineLengthThreshold(int value) { this.lineLengthThreshold = value; } public void setColorizeErrorOutput(boolean colorizeErrorOutput) { this.colorizeErrorOutput = colorizeErrorOutput; } public boolean shouldColorizeErrorOutput() { return colorizeErrorOutput; } /** * If true, chain calls to functions that return this. */ public void setChainCalls(boolean value) { this.chainCalls = value; } /** * If true, accept `const' keyword. */ public void setAcceptConstKeyword(boolean value) { this.acceptConstKeyword = value; } /** * Enable runtime type checking, which adds JS type assertions for debugging. * * @param logFunction A JS function to be used for logging runtime type * assertion failures. */ public void enableRuntimeTypeCheck(String logFunction) { this.runtimeTypeCheck = true; this.runtimeTypeCheckLogFunction = logFunction; } public void disableRuntimeTypeCheck() { this.runtimeTypeCheck = false; } public void setGenerateExports(boolean generateExports) { this.generateExports = generateExports; } public void setCodingConvention(CodingConvention codingConvention) { this.codingConvention = codingConvention; } public CodingConvention getCodingConvention() { return codingConvention; } /** * Sort inputs by their goog.provide/goog.require calls, and prune inputs * whose symbols are not required. */ public void setManageClosureDependencies(boolean newVal) { manageClosureDependencies = newVal; } /** * Sort inputs by their goog.provide/goog.require calls. * * @param entryPoints Entry points to the program. Must be goog.provide'd * symbols. Any goog.provide'd symbols that are not a transitive * dependency of the entry points will be deleted. * Files without goog.provides, and their dependencies, * will always be left in. */ public void setManageClosureDependencies(List entryPoints) { Preconditions.checkNotNull(entryPoints); manageClosureDependencies = true; manageClosureDependenciesEntryPoints = entryPoints; } /** * Controls how detailed the compilation summary is. Values: * 0 (never print summary), 1 (print summary only if there are * errors or warnings), 2 (print summary if type checking is on, * see --check_types), 3 (always print summary). The default level * is 1 */ public void setSummaryDetailLevel(int summaryDetailLevel) { this.summaryDetailLevel = summaryDetailLevel; } public void enableExternExports(boolean enable) { this.externExports = enable; } public void setExtraAnnotationNames(Set extraAnnotationNames) { this.extraAnnotationNames = Sets.newHashSet(extraAnnotationNames); } public boolean isExternExportsEnabled() { return externExports; } /** * Sets the output charset by name. */ public void setOutputCharset(String charsetName) { this.outputCharset = charsetName; } /** * Sets how goog.tweak calls are processed. */ public void setTweakProcessing(TweakProcessing tweakProcessing) { this.tweakProcessing = tweakProcessing; } public TweakProcessing getTweakProcessing() { return tweakProcessing; } /** * Sets how goog.tweak calls are processed. */ public void setLanguageIn(LanguageMode languageIn) { this.languageIn = languageIn; this.languageOut = languageIn; } public LanguageMode getLanguageIn() { return languageIn; } public LanguageMode getLanguageOut() { return languageOut; } /** * Whether to include "undefined" in the default types. * For example: * "{Object}" is normally "Object|null" becomes "Object|null|undefined" * "{?string}" is normally "string|null" becomes "string|null|undefined" * In either case "!" annotated types excluded both null and undefined. */ public void setLooseTypes(boolean looseTypes) { this.looseTypes = looseTypes; } @Override public Object clone() throws CloneNotSupportedException { CompilerOptions clone = (CompilerOptions) super.clone(); // TODO(bolinfest): Add relevant custom cloning. return clone; } public void setAliasTransformationHandler( AliasTransformationHandler changes) { this.aliasHandler = changes; } public AliasTransformationHandler getAliasTransformationHandler() { return this.aliasHandler; } /** * If true, enables type inference. If checkTypes is enabled, this flag has * no effect. */ public void setInferTypes(boolean enable) { inferTypes = enable; } /** * Gets the inferTypes flag. Note that if checkTypes is enabled, this flag * is ignored when configuring the compiler. */ public boolean getInferTypes() { return inferTypes; } /** * @return Whether assumeStrictThis is set. */ public boolean isAssumeStrictThis() { return assumeStrictThis; } /** * If true, enables enables additional optimizations. */ public void setAssumeStrictThis(boolean enable) { this.assumeStrictThis = enable; } ////////////////////////////////////////////////////////////////////////////// // Enums /** When to do the extra sanity checks */ static enum LanguageMode { /** * Tranditional JavaScript */ ECMASCRIPT3, /** * Shiny new JavaScript */ ECMASCRIPT5, /** * Nitpicky, shiny new JavaScript */ ECMASCRIPT5_STRICT, } /** When to do the extra sanity checks */ static enum DevMode { /** * Don't do any extra sanity checks. */ OFF, /** * After the initial parse */ START, /** * At the start and at the end of all optimizations. */ START_AND_END, /** * After every pass */ EVERY_PASS } public static enum TracerMode { ALL, // Collect all timing and size metrics. FAST, // Collect all timing and size metrics, except gzipped size. OFF; // Collect no timing and size metrics. boolean isOn() { return this != OFF; } } public static enum TweakProcessing { OFF, // Do not run the ProcessTweaks pass. CHECK, // Run the pass, but do not strip out the calls. STRIP; // Strip out all calls to goog.tweak.*. public boolean isOn() { return this != OFF; } public boolean shouldStrip() { return this == STRIP; } } /** * A Role Specific Interface for JsCompiler that represents a data holder * object which is used to store goog.scope alias code changes to code made * during a compile. There is no guarantee that individual alias changes are * invoked in the order they occur during compilation, so implementations * should not assume any relevance to the order changes arrive. *

* Calls to the mutators are expected to resolve very quickly, so * implementations should not perform expensive operations in the mutator * methods. * * @author [email protected] (Tyler Goodwin) */ public interface AliasTransformationHandler { /** * Builds an AliasTransformation implementation and returns it to the * caller. *

* Callers are allowed to request multiple AliasTransformation instances for * the same file, though it is expected that the first and last char values * for multiple instances will not overlap. *

* This method is expected to have a side-effect of storing off the created * AliasTransformation, which guarantees that invokers of this interface * cannot leak AliasTransformation to this implementation that the * implementor did not create * * @param sourceFile the source file the aliases re contained in. * @param position the region of the source file associated with the * goog.scope call. The item of the SourcePosition is the returned * AliasTransformation */ public AliasTransformation logAliasTransformation( String sourceFile, SourcePosition position); } /** * A Role Specific Interface for the JsCompiler to report aliases used to * change the code during a compile. *

* While aliases defined by goog.scope are expected to by only 1 per file, and * the only top level structure in the file, this is not enforced. */ public interface AliasTransformation { /** * Adds an alias definition to the AliasTransformation instance. *

* Last definition for a given alias is kept if an alias is inserted * multiple times (since this is generally the behavior in JavaScript code). * * @param alias the name of the alias. * @param definition the definition of the alias. */ void addAlias(String alias, String definition); } /** * A Null implementation of the CodeChanges interface which performs all * operations as a No-Op */ static final AliasTransformationHandler NULL_ALIAS_TRANSFORMATION_HANDLER = new NullAliasTransformationHandler(); private static class NullAliasTransformationHandler implements AliasTransformationHandler, Serializable { private static final long serialVersionUID = 0L; private static final AliasTransformation NULL_ALIAS_TRANSFORMATION = new NullAliasTransformation(); @Override public AliasTransformation logAliasTransformation( String sourceFile, SourcePosition position) { position.setItem(NULL_ALIAS_TRANSFORMATION); return NULL_ALIAS_TRANSFORMATION; } private static class NullAliasTransformation implements AliasTransformation, Serializable { private static final long serialVersionUID = 0L; @Override public void addAlias(String alias, String definition) { } } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy