Class CompilerConfiguration


  • public class CompilerConfiguration
    extends java.lang.Object
    Compilation control flags and coordination stuff.
    • Field Summary

      Fields 
      Modifier and Type Field Description
      static java.lang.String[] ALLOWED_JDKS
      An array of the valid targetBytecode values
      static int ASM_API_VERSION  
      static java.lang.String CURRENT_JVM_VERSION
      Deprecated.
      static CompilerConfiguration DEFAULT
      A convenience for getting a default configuration.
      static java.lang.String DEFAULT_SOURCE_ENCODING
      The default source encoding
      static java.lang.String INVOKEDYNAMIC
      This ("indy") is the Optimization Option value for enabling invokedynamic compilation.
      static java.util.Map<java.lang.String,​java.lang.Integer> JDK_TO_BYTECODE_VERSION_MAP
      JDK version to bytecode version mapping
      static java.lang.String JDK10
      This ("10") is the value for targetBytecode to compile for a JDK 10.
      static java.lang.String JDK11
      This ("11") is the value for targetBytecode to compile for a JDK 11.
      static java.lang.String JDK12
      This ("12") is the value for targetBytecode to compile for a JDK 12.
      static java.lang.String JDK4
      This ("1.4") is the value for targetBytecode to compile for a JDK 1.4.
      static java.lang.String JDK5
      This ("1.5") is the value for targetBytecode to compile for a JDK 1.5.
      static java.lang.String JDK6
      This ("1.6") is the value for targetBytecode to compile for a JDK 1.6.
      static java.lang.String JDK7
      This ("1.7") is the value for targetBytecode to compile for a JDK 1.7.
      static java.lang.String JDK8
      This ("1.8") is the value for targetBytecode to compile for a JDK 1.8.
      static java.lang.String JDK9
      This ("9") is the value for targetBytecode to compile for a JDK 9.
      static java.lang.String POST_JDK5
      Deprecated. 
      static java.lang.String PRE_JDK5
      Deprecated. 
    • Field Detail

      • INVOKEDYNAMIC

        public static final java.lang.String INVOKEDYNAMIC
        This ("indy") is the Optimization Option value for enabling invokedynamic compilation.
        See Also:
        Constant Field Values
      • JDK4

        public static final java.lang.String JDK4
        This ("1.4") is the value for targetBytecode to compile for a JDK 1.4.
        See Also:
        Constant Field Values
      • JDK5

        public static final java.lang.String JDK5
        This ("1.5") is the value for targetBytecode to compile for a JDK 1.5.
        See Also:
        Constant Field Values
      • JDK6

        public static final java.lang.String JDK6
        This ("1.6") is the value for targetBytecode to compile for a JDK 1.6.
        See Also:
        Constant Field Values
      • JDK7

        public static final java.lang.String JDK7
        This ("1.7") is the value for targetBytecode to compile for a JDK 1.7.
        See Also:
        Constant Field Values
      • JDK8

        public static final java.lang.String JDK8
        This ("1.8") is the value for targetBytecode to compile for a JDK 1.8.
        See Also:
        Constant Field Values
      • JDK9

        public static final java.lang.String JDK9
        This ("9") is the value for targetBytecode to compile for a JDK 9.
        See Also:
        Constant Field Values
      • JDK10

        public static final java.lang.String JDK10
        This ("10") is the value for targetBytecode to compile for a JDK 10.
        See Also:
        Constant Field Values
      • JDK11

        public static final java.lang.String JDK11
        This ("11") is the value for targetBytecode to compile for a JDK 11.
        See Also:
        Constant Field Values
      • JDK12

        public static final java.lang.String JDK12
        This ("12") is the value for targetBytecode to compile for a JDK 12.
        See Also:
        Constant Field Values
      • POST_JDK5

        @Deprecated
        public static final java.lang.String POST_JDK5
        Deprecated.
        This constant is for comparing targetBytecode to ensure it is set to JDK 1.5 or later.
        See Also:
        Constant Field Values
      • PRE_JDK5

        @Deprecated
        public static final java.lang.String PRE_JDK5
        Deprecated.
        This constant is for comparing targetBytecode to ensure it is set to an earlier value than JDK 1.5.
        See Also:
        Constant Field Values
      • JDK_TO_BYTECODE_VERSION_MAP

        public static final java.util.Map<java.lang.String,​java.lang.Integer> JDK_TO_BYTECODE_VERSION_MAP
        JDK version to bytecode version mapping
      • ALLOWED_JDKS

        public static final java.lang.String[] ALLOWED_JDKS
        An array of the valid targetBytecode values
      • CURRENT_JVM_VERSION

        @Deprecated
        public static final java.lang.String CURRENT_JVM_VERSION
        Deprecated.
      • DEFAULT_SOURCE_ENCODING

        public static final java.lang.String DEFAULT_SOURCE_ENCODING
        The default source encoding
        See Also:
        Constant Field Values
      • DEFAULT

        public static final CompilerConfiguration DEFAULT
        A convenience for getting a default configuration. Do not modify it! See CompilerConfiguration(Properties) for an example on how to make a suitable copy to modify. But if you're really starting from a default context, then you probably just want new CompilerConfiguration().
    • Constructor Detail

      • CompilerConfiguration

        public CompilerConfiguration()
        Sets the Flags to defaults.
      • CompilerConfiguration

        public CompilerConfiguration​(CompilerConfiguration configuration)
        Copy constructor. Use this if you have a mostly correct configuration for your compilation but you want to make a some changes programatically. An important reason to prefer this approach is that your code will most likely be forward compatible with future changes to this configuration API.

        An example of this copy constructor at work:

            // In all likelihood there is already a configuration in your code's context
            // for you to copy, but for the sake of this example we'll use the global default.
            CompilerConfiguration myConfiguration = new CompilerConfiguration(CompilerConfiguration.DEFAULT);
            myConfiguration.setDebug(true);
        
        Parameters:
        configuration - The configuration to copy.
      • CompilerConfiguration

        public CompilerConfiguration​(java.util.Properties configuration)
                              throws ConfigurationException
        Sets the Flags to the specified configuration, with defaults for those not supplied. Note that those "defaults" here do not include checking the settings in System.getProperties() in general, only file.encoding, groovy.target.directory and groovy.source.encoding are.

        If you want to set a few flags but keep Groovy's default configuration behavior then be sure to make your settings in a Properties that is backed by System.getProperties() (which is done using this constructor). That might be done like this:

         Properties myProperties = new Properties(System.getProperties());
         myProperties.setProperty("groovy.output.debug", "true");
         myConfiguration = new CompilerConfiguration(myProperties);
         
        And you also have to contend with a possible SecurityException when getting the system properties (See System.getProperties()). A safer approach would be to copy a default CompilerConfiguration and make your changes there using the setter:
         // In all likelihood there is already a configuration for you to copy,
         // but for the sake of this example we'll use the global default.
         CompilerConfiguration myConfiguration = new CompilerConfiguration(CompilerConfiguration.DEFAULT);
         myConfiguration.setDebug(true);
         

        Property KeyGet/Set Property Name
        "groovy.warnings"getWarningLevel()
        "groovy.source.encoding"getSourceEncoding()
        "groovy.target.directory"getTargetDirectory()
        "groovy.target.bytecode"getTargetBytecode()
        "groovy.classpath"getClasspath()
        "groovy.output.verbose"getVerbose()
        "groovy.output.debug"getDebug()
        "groovy.errors.tolerance"getTolerance()
        "groovy.script.extension"getDefaultScriptExtension()
        "groovy.script.base"getScriptBaseClass()
        "groovy.recompile"getRecompileGroovySource()
        "groovy.recompile.minimumInterval"getMinimumRecompilationInterval()
        Parameters:
        configuration - The properties to get flag values from.
        Throws:
        ConfigurationException
    • Method Detail

      • isPostJDK5

        public static boolean isPostJDK5​(java.lang.String bytecodeVersion)
        Checks if the specified bytecode version string represents a JDK 1.5+ compatible bytecode version.
        Parameters:
        bytecodeVersion - The parameter can take one of the values in ALLOWED_JDKS.
        Returns:
        true if the bytecode version is JDK 1.5+
      • isPostJDK7

        public static boolean isPostJDK7​(java.lang.String bytecodeVersion)
        Checks if the specified bytecode version string represents a JDK 1.7+ compatible bytecode version.
        Parameters:
        bytecodeVersion - The parameter can take one of the values in ALLOWED_JDKS.
        Returns:
        true if the bytecode version is JDK 1.7+
      • isPostJDK8

        public static boolean isPostJDK8​(java.lang.String bytecodeVersion)
        Checks if the specified bytecode version string represents a JDK 1.8+ compatible bytecode version.
        Parameters:
        bytecodeVersion - The parameter can take one of the values in ALLOWED_JDKS.
        Returns:
        true if the bytecode version is JDK 1.8+
      • isPostJDK9

        public static boolean isPostJDK9​(java.lang.String bytecodeVersion)
        Checks if the specified bytecode version string represents a JDK 1.8+ compatible bytecode version.
        Parameters:
        bytecodeVersion - The parameter can take one of the values in ALLOWED_JDKS.
        Returns:
        true if the bytecode version is JDK 9.0+
      • getWarningLevel

        public int getWarningLevel()
        Gets the currently configured warning level. See WarningMessage for level details.
      • setWarningLevel

        public void setWarningLevel​(int level)
        Sets the warning level. See WarningMessage for level details.
      • getSourceEncoding

        public java.lang.String getSourceEncoding()
        Gets the currently configured source file encoding.
      • setSourceEncoding

        public void setSourceEncoding​(java.lang.String encoding)
        Sets the encoding to be used when reading source files.
      • getOutput

        @Deprecated
        public java.io.PrintWriter getOutput()
        Deprecated.
        not used anymore
        Gets the currently configured output writer.
      • setOutput

        @Deprecated
        public void setOutput​(java.io.PrintWriter output)
        Deprecated.
        not used anymore, has no effect
        Sets the output writer.
      • getTargetDirectory

        public java.io.File getTargetDirectory()
        Gets the target directory for writing classes.
      • setTargetDirectory

        public void setTargetDirectory​(java.lang.String directory)
        Sets the target directory.
      • setTargetDirectory

        public void setTargetDirectory​(java.io.File directory)
        Sets the target directory.
      • getClasspath

        public java.util.List<java.lang.String> getClasspath()
        Returns:
        the classpath
      • setClasspath

        public void setClasspath​(java.lang.String classpath)
        Sets the classpath.
      • setClasspathList

        public void setClasspathList​(java.util.List<java.lang.String> parts)
        sets the classpath using a list of Strings
        Parameters:
        parts - list of strings containing the classpath parts
      • getVerbose

        public boolean getVerbose()
        Returns true if verbose operation has been requested.
      • setVerbose

        public void setVerbose​(boolean verbose)
        Turns verbose operation on or off.
      • getDebug

        public boolean getDebug()
        Returns true if debugging operation has been requested.
      • getParameters

        public boolean getParameters()
        Returns true if parameter metadata generation has been enabled.
      • setDebug

        public void setDebug​(boolean debug)
        Turns debugging operation on or off.
      • setParameters

        public void setParameters​(boolean parameters)
        Turns parameter metadata generation on or off.
      • getTolerance

        public int getTolerance()
        Returns the requested error tolerance.
      • setTolerance

        public void setTolerance​(int tolerance)
        Sets the error tolerance, which is the number of non-fatal errors (per unit) that should be tolerated before compilation is aborted.
      • getScriptBaseClass

        public java.lang.String getScriptBaseClass()
        Gets the name of the base class for scripts. It must be a subclass of Script.
      • setScriptBaseClass

        public void setScriptBaseClass​(java.lang.String scriptBaseClass)
        Sets the name of the base class for scripts. It must be a subclass of Script.
      • setScriptExtensions

        public void setScriptExtensions​(java.util.Set<java.lang.String> scriptExtensions)
      • getScriptExtensions

        public java.util.Set<java.lang.String> getScriptExtensions()
      • getDefaultScriptExtension

        public java.lang.String getDefaultScriptExtension()
      • setDefaultScriptExtension

        public void setDefaultScriptExtension​(java.lang.String defaultScriptExtension)
      • setRecompileGroovySource

        public void setRecompileGroovySource​(boolean recompile)
      • getRecompileGroovySource

        public boolean getRecompileGroovySource()
      • setMinimumRecompilationInterval

        public void setMinimumRecompilationInterval​(int time)
      • getMinimumRecompilationInterval

        public int getMinimumRecompilationInterval()
      • setTargetBytecode

        public void setTargetBytecode​(java.lang.String version)
        Allow setting the bytecode compatibility level. The parameter can take one of the values in ALLOWED_JDKS.
        Parameters:
        version - the bytecode compatibility level
      • getTargetBytecode

        public java.lang.String getTargetBytecode()
        Retrieves the compiler bytecode compatibility level. Defaults to the minimum officially supported bytecode version for any particular Groovy version.
        Returns:
        bytecode compatibility level
      • getJointCompilationOptions

        public java.util.Map<java.lang.String,​java.lang.Object> getJointCompilationOptions()
        Gets the joint compilation options for this configuration.
        Returns:
        the options
      • setJointCompilationOptions

        public void setJointCompilationOptions​(java.util.Map<java.lang.String,​java.lang.Object> options)
        Sets the joint compilation options for this configuration. Using null will disable joint compilation.
        Parameters:
        options - the options
      • getOptimizationOptions

        public java.util.Map<java.lang.String,​java.lang.Boolean> getOptimizationOptions()
        Gets the optimization options for this configuration.
        Returns:
        the options (always not null)
      • setOptimizationOptions

        public void setOptimizationOptions​(java.util.Map<java.lang.String,​java.lang.Boolean> options)
        Sets the optimization options for this configuration. No entry or a true for that entry means to enable that optimization, a false means the optimization is disabled. Valid keys are "all" and "int".
        Parameters:
        options - the options.
        Throws:
        java.lang.IllegalArgumentException - if the options are null
      • addCompilationCustomizers

        public CompilerConfiguration addCompilationCustomizers​(CompilationCustomizer... customizers)
        Adds compilation customizers to the compilation process. A compilation customizer is a class node operation which performs various operations going from adding imports to access control.
        Parameters:
        customizers - the list of customizers to be added
        Returns:
        this configuration instance
      • getCompilationCustomizers

        public java.util.List<CompilationCustomizer> getCompilationCustomizers()
        Returns the list of compilation customizers.
        Returns:
        the customizers (always not null)
      • getDisabledGlobalASTTransformations

        public java.util.Set<java.lang.String> getDisabledGlobalASTTransformations()
        Returns the list of disabled global AST transformation class names.
        Returns:
        a list of global AST transformation fully qualified class names
      • setDisabledGlobalASTTransformations

        public void setDisabledGlobalASTTransformations​(java.util.Set<java.lang.String> disabledGlobalASTTransformations)
        Disables the specified global AST transformations. In order to avoid class loading side effects, it is not recommended to use MyASTTransformation.class.getName() by directly use the class name as a string. Disabled AST transformations only apply to automatically loaded global AST transformations, that is to say transformations defined in a META-INF/services/org.codehaus.groovy.transform.ASTTransformation file. If you explicitly add a global AST transformation in your compilation process, for example using the ASTTransformationCustomizer or using a CompilationUnit.PrimaryClassNodeOperation, then nothing will prevent the transformation from being loaded.
        Parameters:
        disabledGlobalASTTransformations - a set of fully qualified class names of global AST transformations which should not be loaded.
      • setBytecodePostprocessor

        public void setBytecodePostprocessor​(BytecodeProcessor bytecodePostprocessor)
      • isIndyEnabled

        public boolean isIndyEnabled()
        Check whether invoke dynamic enabled
        Returns:
        the result