Class Javac
- All Implemented Interfaces:
- Cloneable,- SelectorContainer
- sourcedir
- destdir
- deprecation
- classpath
- bootclasspath
- extdirs
- optimize
- debug
- encoding
- target
- depend
- verbose
- failonerror
- includeantruntime
- includejavaruntime
- source
- compiler
- release
When this task executes, it will recursively scan the sourcedir and destdir looking for Java source files to compile. This task makes its compile decision based on timestamp.
- Since:
- Ant 1.1
- 
Nested Class SummaryNested ClassesModifier and TypeClassDescriptionclassAdds an "compiler" attribute to Commandline$Attribute used to filter command line attributes based on the current implementation.
- 
Field SummaryFieldsFields inherited from class org.apache.tools.ant.taskdefs.MatchingTaskfilesetFields inherited from class org.apache.tools.ant.ProjectComponentdescription, location, project
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidadd(CompilerAdapter adapter) Set the compiler adapter explicitly.protected voidCheck that all required attributes have been set and nothing silly has been entered.protected voidcompile()Perform the compilation.Adds a path to the bootclasspath.Adds a path to the classpath.Adds an implementation specific command-line argument.The classpath to use when loading the compiler implementation if it is not a built-in one.Adds a path to extdirs.Adds a path to the modulepath.Adds a path to modulesourcepath.Adds a path to sourcepath.Adds a path for source compilation.Adds a path to the upgrademodulepath.voidexecute()Executes the task.Gets the bootclasspath that will be used to compile the classes against.Gets the classpath to be used for this compilation.The implementation for this particular task.The implementation for this particular task.String[]Get the additional implementation specific command line arguments.booleangetDebug()Gets the debug flag.Get the value of debugLevel.booleanGets the depend flag.booleanGets the deprecation flag.Gets the destination directory into which the java source files should be compiled.Gets the java source file encoding name.The value of the executable attribute, if any.Gets the extension directories that will be used during the compilation.booleanGets the failonerror flag.File[]Gets the list of files to be compiled.booleanGets whether or not the ant classpath is to be included in the classpath.booleanGets whether or not the java runtime should be included in this task's classpath.The name of the javac executable to use in fork-mode.booleanGet the listfiles flag.Gets the memoryInitialSize flag.Gets the memoryMaximumSize flag.Gets the modulepath to be used for this compilation.Gets the modulesourcepath to be used for this compilation.Gets the destination directory into which the generated native header files should be placed.booleanShould the -nowarn option be used.booleanGets the optimize flag.Gets the version to use for the--releaseswitch that combinessource,targetand setting the bootclasspath.Get the value of source.Gets the sourcepath to be used for this compilation.Gets the source dirs to find the source java files.protected StringGets the target VM that the classes will be compiled for.booleanGet the result of the javac task (success or failure).Where Ant should place temporary files.Gets the upgrademodulepath to be used for this compilation.booleanGets the verbose flag.booleanIs this a forked invocation of JDK's javac?booleanGet the value of the includeDestClasses property.protected booleanisJdkCompiler(String compilerImpl) Is the compiler implementation a jdk compilerprotected PathRecreate src.protected voidClear the list of files to be compiled and copied..protected voidScans the directory looking for source files to be compiled.voidsetBootclasspath(Path bootclasspath) Sets the bootclasspath that will be used to compile the classes against.voidAdds a reference to a classpath defined elsewhere.voidsetClasspath(Path classpath) Set the classpath to be used for this compilation.voidAdds a reference to a classpath defined elsewhere.voidsetCompiler(String compiler) Choose the implementation for this particular task.voidsetCreateMissingPackageInfoClass(boolean b) Whether package-info.class files will be created by Ant matching package-info.java files that have been compiled but didn't create class files themselves.voidsetDebug(boolean debug) Indicates whether source should be compiled with debug information; defaults to off.voidKeyword list to be appended to the -g command-line switch.voidsetDepend(boolean depend) Enables dependency-tracking for compilers that support this (jikes and classic).voidsetDeprecation(boolean deprecation) Indicates whether source should be compiled with deprecation information; defaults to off.voidsetDestdir(File destDir) Set the destination directory into which the Java source files should be compiled.voidsetEncoding(String encoding) Set the Java source file encoding name.voidsetErrorProperty(String errorProperty) The property to set on compilation failure.voidsetExecutable(String forkExec) Sets the name of the javac executable.voidsetExtdirs(Path extdirs) Sets the extension directories that will be used during the compilation.voidsetFailonerror(boolean fail) Indicates whether the build will continue even if there are compilation errors; defaults to true.voidsetFork(boolean f) If true, forks the javac compiler.voidsetIncludeantruntime(boolean include) If true, includes Ant's own classpath in the classpath.voidsetIncludeDestClasses(boolean includeDestClasses) This property controls whether to include the destination classes directory in the classpath given to the compiler.voidsetIncludejavaruntime(boolean include) If true, includes the Java runtime libraries in the classpath.voidsetListfiles(boolean list) If true, list the source files being handed off to the compiler.voidsetMemoryInitialSize(String memoryInitialSize) The initial size of the memory for the underlying VM if javac is run externally; ignored otherwise.voidsetMemoryMaximumSize(String memoryMaximumSize) The maximum size of the memory for the underlying VM if javac is run externally; ignored otherwise.voidsetModulepath(Path mp) Set the modulepath to be used for this compilation.voidAdds a reference to a modulepath defined elsewhere.voidsetModulesourcepath(Path msp) Set the modulesourcepath to be used for this compilation.voidAdds a reference to a modulesourcepath defined elsewhere.voidsetNativeHeaderDir(File nhDir) Set the destination directory into which the generated native header files should be placed.voidsetNowarn(boolean flag) If true, enables the -nowarn option.voidsetOptimize(boolean optimize) If true, compiles with optimization enabled.voidsetProceed(boolean proceed) voidsetRelease(String release) Sets the version to use for the--releaseswitch that combinessource,targetand setting the bootclasspath.voidValue of the -source command-line switch; will be ignored by all implementations except modern, jikes and gcj (gcj uses -fsource).voidsetSourcepath(Path sourcepath) Set the sourcepath to be used for this compilation.voidAdds a reference to a source path defined elsewhere.voidSet the source directories to find the source Java files.voidSets the target VM that the classes will be compiled for.voidsetTempdir(File tmpDir) Where Ant should place temporary files.voidsetUpdatedProperty(String updatedProperty) The property to set on compilation success.voidsetUpgrademodulepath(Path ump) Set the upgrademodulepath to be used for this compilation.voidAdds a reference to the upgrademodulepath defined elsewhere.voidsetVerbose(boolean verbose) If true, asks the compiler for verbose output.Methods inherited from class org.apache.tools.ant.taskdefs.MatchingTaskadd, addAnd, addContains, addContainsRegexp, addCustom, addDate, addDepend, addDepth, addDifferent, addFilename, addMajority, addModified, addNone, addNot, addOr, addPresent, addSelector, addSize, addType, appendSelector, createExclude, createExcludesFile, createInclude, createIncludesFile, createPatternSet, getDirectoryScanner, getImplicitFileSet, getSelectors, hasSelectors, selectorCount, selectorElements, setCaseSensitive, setDefaultexcludes, setExcludes, setExcludesfile, setFollowSymlinks, setIncludes, setIncludesfile, setProject, XsetIgnore, XsetItemsMethods inherited from class org.apache.tools.ant.TaskbindToOwner, getOwningTarget, getRuntimeConfigurableWrapper, getTaskName, getTaskType, getWrapper, handleErrorFlush, handleErrorOutput, handleFlush, handleInput, handleOutput, init, isInvalid, log, log, log, log, maybeConfigure, perform, reconfigure, setOwningTarget, setRuntimeConfigurableWrapper, setTaskName, setTaskTypeMethods inherited from class org.apache.tools.ant.ProjectComponentclone, getDescription, getLocation, getProject, setDescription, setLocation
- 
Field Details- 
failOnErrorprotected boolean failOnError
- 
listFilesprotected boolean listFiles
- 
compileList
 
- 
- 
Constructor Details- 
Javacpublic Javac()Javac task for compilation of Java files.
 
- 
- 
Method Details- 
getDebugLevel
- 
setDebugLevelKeyword list to be appended to the -g command-line switch. This will be ignored by all implementations except modern and classic(ver >= 1.2). Legal values are none or a comma-separated list of the following keywords: lines, vars, and source. If debuglevel is not specified, by default, :none will be appended to -g. If debug is not turned on, this attribute will be ignored.- Parameters:
- v- Value to assign to debugLevel.
 
- 
getSource
- 
setSourceValue of the -source command-line switch; will be ignored by all implementations except modern, jikes and gcj (gcj uses -fsource).If you use this attribute together with jikes or gcj, you must make sure that your version of jikes supports the -source switch. Legal values are 1.3, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, and any integral number bigger than 4 - by default, no -source argument will be used at all. - Parameters:
- v- Value to assign to source.
 
- 
createSrc
- 
recreateSrc
- 
setSrcdirSet the source directories to find the source Java files.- Parameters:
- srcDir- the source directories as a path
 
- 
getSrcdirGets the source dirs to find the source java files.- Returns:
- the source directories as a path
 
- 
setDestdirSet the destination directory into which the Java source files should be compiled.- Parameters:
- destDir- the destination director
 
- 
getDestdirGets the destination directory into which the java source files should be compiled.- Returns:
- the destination directory
 
- 
setNativeHeaderDirSet the destination directory into which the generated native header files should be placed.- Parameters:
- nhDir- where to place generated native header files
- Since:
- Ant 1.9.8
 
- 
getNativeHeaderDirGets the destination directory into which the generated native header files should be placed.- Returns:
- where to place generated native header files
- Since:
- Ant 1.9.8
 
- 
setSourcepathSet the sourcepath to be used for this compilation.- Parameters:
- sourcepath- the source path
 
- 
getSourcepathGets the sourcepath to be used for this compilation.- Returns:
- the source path
 
- 
createSourcepath
- 
setSourcepathRefAdds a reference to a source path defined elsewhere.- Parameters:
- r- a reference to a source path
 
- 
setModulesourcepathSet the modulesourcepath to be used for this compilation.- Parameters:
- msp- the modulesourcepath
- Since:
- 1.9.7
 
- 
getModulesourcepathGets the modulesourcepath to be used for this compilation.- Returns:
- the modulesourcepath
- Since:
- 1.9.7
 
- 
createModulesourcepathAdds a path to modulesourcepath.- Returns:
- a modulesourcepath to be configured
- Since:
- 1.9.7
 
- 
setModulesourcepathRefAdds a reference to a modulesourcepath defined elsewhere.- Parameters:
- r- a reference to a modulesourcepath
- Since:
- 1.9.7
 
- 
setClasspathSet the classpath to be used for this compilation.- Parameters:
- classpath- an Ant Path object containing the compilation classpath.
 
- 
getClasspathGets the classpath to be used for this compilation.- Returns:
- the class path
 
- 
createClasspath
- 
setClasspathRefAdds a reference to a classpath defined elsewhere.- Parameters:
- r- a reference to a classpath
 
- 
setModulepathSet the modulepath to be used for this compilation.- Parameters:
- mp- an Ant Path object containing the modulepath.
- Since:
- 1.9.7
 
- 
getModulepathGets the modulepath to be used for this compilation.- Returns:
- the modulepath
- Since:
- 1.9.7
 
- 
createModulepathAdds a path to the modulepath.- Returns:
- a modulepath to be configured
- Since:
- 1.9.7
 
- 
setModulepathRefAdds a reference to a modulepath defined elsewhere.- Parameters:
- r- a reference to a modulepath
- Since:
- 1.9.7
 
- 
setUpgrademodulepathSet the upgrademodulepath to be used for this compilation.- Parameters:
- ump- an Ant Path object containing the upgrademodulepath.
- Since:
- 1.9.7
 
- 
getUpgrademodulepathGets the upgrademodulepath to be used for this compilation.- Returns:
- the upgrademodulepath
- Since:
- 1.9.7
 
- 
createUpgrademodulepathAdds a path to the upgrademodulepath.- Returns:
- an upgrademodulepath to be configured
- Since:
- 1.9.7
 
- 
setUpgrademodulepathRefAdds a reference to the upgrademodulepath defined elsewhere.- Parameters:
- r- a reference to an upgrademodulepath
- Since:
- 1.9.7
 
- 
setBootclasspathSets the bootclasspath that will be used to compile the classes against.- Parameters:
- bootclasspath- a path to use as a boot class path (may be more than one)
 
- 
getBootclasspathGets the bootclasspath that will be used to compile the classes against.- Returns:
- the boot path
 
- 
createBootclasspathAdds a path to the bootclasspath.- Returns:
- a path to be configured
 
- 
setBootClasspathRefAdds a reference to a classpath defined elsewhere.- Parameters:
- r- a reference to a classpath
 
- 
setExtdirsSets the extension directories that will be used during the compilation.- Parameters:
- extdirs- a path
 
- 
getExtdirsGets the extension directories that will be used during the compilation.- Returns:
- the extension directories as a path
 
- 
createExtdirs
- 
setListfilespublic void setListfiles(boolean list) If true, list the source files being handed off to the compiler.- Parameters:
- list- if true list the source files
 
- 
getListfilespublic boolean getListfiles()Get the listfiles flag.- Returns:
- the listfiles flag
 
- 
setFailonerrorpublic void setFailonerror(boolean fail) Indicates whether the build will continue even if there are compilation errors; defaults to true.- Parameters:
- fail- if true halt the build on failure
 
- 
setProceedpublic void setProceed(boolean proceed) - Parameters:
- proceed- inverse of failoferror
 
- 
getFailonerrorpublic boolean getFailonerror()Gets the failonerror flag.- Returns:
- the failonerror flag
 
- 
setDeprecationpublic void setDeprecation(boolean deprecation) Indicates whether source should be compiled with deprecation information; defaults to off.- Parameters:
- deprecation- if true turn on deprecation information
 
- 
getDeprecationpublic boolean getDeprecation()Gets the deprecation flag.- Returns:
- the deprecation flag
 
- 
setMemoryInitialSizeThe initial size of the memory for the underlying VM if javac is run externally; ignored otherwise. Defaults to the standard VM memory setting. (Examples: 83886080, 81920k, or 80m)- Parameters:
- memoryInitialSize- string to pass to VM
 
- 
getMemoryInitialSizeGets the memoryInitialSize flag.- Returns:
- the memoryInitialSize flag
 
- 
setMemoryMaximumSizeThe maximum size of the memory for the underlying VM if javac is run externally; ignored otherwise. Defaults to the standard VM memory setting. (Examples: 83886080, 81920k, or 80m)- Parameters:
- memoryMaximumSize- string to pass to VM
 
- 
getMemoryMaximumSizeGets the memoryMaximumSize flag.- Returns:
- the memoryMaximumSize flag
 
- 
setEncodingSet the Java source file encoding name.- Parameters:
- encoding- the source file encoding
 
- 
getEncodingGets the java source file encoding name.- Returns:
- the source file encoding name
 
- 
setDebugpublic void setDebug(boolean debug) Indicates whether source should be compiled with debug information; defaults to off.- Parameters:
- debug- if true compile with debug information
 
- 
getDebugpublic boolean getDebug()Gets the debug flag.- Returns:
- the debug flag
 
- 
setOptimizepublic void setOptimize(boolean optimize) If true, compiles with optimization enabled.- Parameters:
- optimize- if true compile with optimization enabled
 
- 
getOptimizepublic boolean getOptimize()Gets the optimize flag.- Returns:
- the optimize flag
 
- 
setDependpublic void setDepend(boolean depend) Enables dependency-tracking for compilers that support this (jikes and classic).- Parameters:
- depend- if true enable dependency-tracking
 
- 
getDependpublic boolean getDepend()Gets the depend flag.- Returns:
- the depend flag
 
- 
setVerbosepublic void setVerbose(boolean verbose) If true, asks the compiler for verbose output.- Parameters:
- verbose- if true, asks the compiler for verbose output
 
- 
getVerbosepublic boolean getVerbose()Gets the verbose flag.- Returns:
- the verbose flag
 
- 
setTargetSets the target VM that the classes will be compiled for. Valid values depend on the compiler, for jdk 1.4 the valid values are "1.1", "1.2", "1.3", "1.4", "1.5", "1.6", "1.7", "1.8", "1.9" and any integral number bigger than 4- Parameters:
- target- the target VM
 
- 
getTargetGets the target VM that the classes will be compiled for.- Returns:
- the target VM
 
- 
setReleaseSets the version to use for the--releaseswitch that combinessource,targetand setting the bootclasspath. Values depend on the compiler, for jdk 9 the valid values are "6", "7", "8", "9".- Parameters:
- release- the value of the release attribute
- Since:
- Ant 1.9.8
 
- 
getReleaseGets the version to use for the--releaseswitch that combinessource,targetand setting the bootclasspath.- Returns:
- the value of the release attribute
- Since:
- Ant 1.9.8
 
- 
setIncludeantruntimepublic void setIncludeantruntime(boolean include) If true, includes Ant's own classpath in the classpath.- Parameters:
- include- if true, includes Ant's own classpath in the classpath
 
- 
getIncludeantruntimepublic boolean getIncludeantruntime()Gets whether or not the ant classpath is to be included in the classpath.- Returns:
- whether or not the ant classpath is to be included in the classpath
 
- 
setIncludejavaruntimepublic void setIncludejavaruntime(boolean include) If true, includes the Java runtime libraries in the classpath.- Parameters:
- include- if true, includes the Java runtime libraries in the classpath
 
- 
getIncludejavaruntimepublic boolean getIncludejavaruntime()Gets whether or not the java runtime should be included in this task's classpath.- Returns:
- the includejavaruntime attribute
 
- 
setForkpublic void setFork(boolean f) If true, forks the javac compiler.- Parameters:
- f- "true|false|on|off|yes|no"
 
- 
setExecutableSets the name of the javac executable.Ignored unless fork is true or extJavac has been specified as the compiler. - Parameters:
- forkExec- the name of the executable
 
- 
getExecutableThe value of the executable attribute, if any.- Returns:
- the name of the java executable
- Since:
- Ant 1.6
 
- 
isForkedJavacpublic boolean isForkedJavac()Is this a forked invocation of JDK's javac?- Returns:
- true if this is a forked invocation
 
- 
getJavacExecutableThe name of the javac executable to use in fork-mode.This is either the name specified with the executable attribute or the full path of the javac compiler of the VM Ant is currently running in - guessed by Ant. You should not invoke this method if you want to get the value of the executable command - use getExecutablefor this.- Returns:
- the name of the javac executable
 
- 
setNowarnpublic void setNowarn(boolean flag) If true, enables the -nowarn option.- Parameters:
- flag- if true, enable the -nowarn option
 
- 
getNowarnpublic boolean getNowarn()Should the -nowarn option be used.- Returns:
- true if the -nowarn option should be used
 
- 
createCompilerArgAdds an implementation specific command-line argument.- Returns:
- a ImplementationSpecificArgument to be configured
 
- 
getCurrentCompilerArgsGet the additional implementation specific command line arguments.- Returns:
- array of command line arguments, guaranteed to be non-null.
 
- 
setTempdirWhere Ant should place temporary files.- Parameters:
- tmpDir- the temporary directory
- Since:
- Ant 1.6
 
- 
getTempdirWhere Ant should place temporary files.- Returns:
- the temporary directory
- Since:
- Ant 1.6
 
- 
setUpdatedPropertyThe property to set on compilation success. This property will not be set if the compilation fails, or if there are no files to compile.- Parameters:
- updatedProperty- the property name to use.
- Since:
- Ant 1.7.1.
 
- 
setErrorPropertyThe property to set on compilation failure. This property will be set if the compilation fails.- Parameters:
- errorProperty- the property name to use.
- Since:
- Ant 1.7.1.
 
- 
setIncludeDestClassespublic void setIncludeDestClasses(boolean includeDestClasses) This property controls whether to include the destination classes directory in the classpath given to the compiler. The default value is "true".- Parameters:
- includeDestClasses- the value to use.
 
- 
isIncludeDestClassespublic boolean isIncludeDestClasses()Get the value of the includeDestClasses property.- Returns:
- the value.
 
- 
getTaskSuccesspublic boolean getTaskSuccess()Get the result of the javac task (success or failure).- Returns:
- true if compilation succeeded, or was not necessary, false if the compilation failed.
 
- 
createCompilerClasspathThe classpath to use when loading the compiler implementation if it is not a built-in one.- Returns:
- Path
- Since:
- Ant 1.8.0
 
- 
addSet the compiler adapter explicitly.- Parameters:
- adapter- CompilerAdapter
- Since:
- Ant 1.8.0
 
- 
setCreateMissingPackageInfoClasspublic void setCreateMissingPackageInfoClass(boolean b) Whether package-info.class files will be created by Ant matching package-info.java files that have been compiled but didn't create class files themselves.- Parameters:
- b- boolean
- Since:
- Ant 1.8.3
 
- 
executeExecutes the task.- Overrides:
- executein class- Task
- Throws:
- BuildException- if an error occurs
 
- 
resetFileListsprotected void resetFileLists()Clear the list of files to be compiled and copied..
- 
scanDir
- 
getFileListGets the list of files to be compiled.- Returns:
- the list of files as an array
 
- 
isJdkCompilerIs the compiler implementation a jdk compiler- Parameters:
- compilerImpl- the name of the compiler implementation
- Returns:
- true if compilerImpl is "modern", "classic", "javac1.1", "javac1.2", "javac1.3", "javac1.4", "javac1.5", "javac1.6", "javac1.7", "javac1.8", "javac1.9", "javac9" or "javac10+".
 
- 
getSystemJavac- Returns:
- the executable name of the java compiler
 
- 
setCompilerChoose the implementation for this particular task.- Parameters:
- compiler- the name of the compiler
- Since:
- Ant 1.5
 
- 
getCompilerThe implementation for this particular task.Defaults to the build.compiler property but can be overridden via the compiler and fork attributes. If fork has been set to true, the result will be extJavac and not classic or java1.2 - no matter what the compiler attribute looks like. - Returns:
- the compiler.
- Since:
- Ant 1.5
- See Also:
 
- 
getCompilerVersionThe implementation for this particular task.Defaults to the build.compiler property but can be overridden via the compiler attribute. This method does not take the fork attribute into account. - Returns:
- the compiler.
- Since:
- Ant 1.5
- See Also:
 
- 
checkParametersCheck that all required attributes have been set and nothing silly has been entered.- Throws:
- BuildException- if an error occurs
- Since:
- Ant 1.5
 
- 
compileprotected void compile()Perform the compilation.- Since:
- Ant 1.5
 
 
-