Class CreateStartScripts
- All Implemented Interfaces:
Comparable<Task>
,org.gradle.api.internal.DynamicObjectAware
,org.gradle.api.internal.IConventionAware
,org.gradle.api.internal.TaskInternal
,Named
,ExtensionAware
,Task
,Configurable<Task>
- Direct Known Subclasses:
CreateStartScripts
Example:
task createStartScripts(type: CreateStartScripts) { outputDir = file('build/sample') mainClass = 'org.gradle.test.Main' applicationName = 'myApp' classpath = files('path/to/some.jar') }
Note: the Gradle "application"
plugin adds a pre-configured task of this type named "startScripts"
.
The task generates separate scripts targeted at Microsoft Windows environments and UNIX-like environments (e.g. Linux, macOS).
The actual generation is implemented by the getWindowsStartScriptGenerator()
and getUnixStartScriptGenerator()
properties, of type ScriptGenerator
.
Example:
task createStartScripts(type: CreateStartScripts) { unixStartScriptGenerator = new CustomUnixStartScriptGenerator() windowsStartScriptGenerator = new CustomWindowsStartScriptGenerator() } class CustomUnixStartScriptGenerator implements ScriptGenerator { void generateScript(JavaAppStartScriptGenerationDetails details, Writer destination) { // implementation } } class CustomWindowsStartScriptGenerator implements ScriptGenerator { void generateScript(JavaAppStartScriptGenerationDetails details, Writer destination) { // implementation } }
The default generators are of the type TemplateBasedScriptGenerator
, with default templates.
This templates can be changed via the TemplateBasedScriptGenerator.setTemplate(org.gradle.api.resources.TextResource)
method.
The default implementations used by this task use Groovy's SimpleTemplateEngine to parse the template, with the following variables available:
applicationName
optsEnvironmentVar
exitEnvironmentVar
mainModule
mainClass
executableDir
defaultJvmOpts
appNameSystemProperty
appHomeRelativePath
classpath
Example:
task createStartScripts(type: CreateStartScripts) { unixStartScriptGenerator.template = resources.text.fromFile('customUnixStartScript.txt') windowsStartScriptGenerator.template = resources.text.fromFile('customWindowsStartScript.txt') }
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.gradle.api.Task
Task.Namer
-
Field Summary
Fields inherited from interface org.gradle.api.Task
TASK_ACTION, TASK_CONSTRUCTOR_ARGS, TASK_DEPENDS_ON, TASK_DESCRIPTION, TASK_GROUP, TASK_NAME, TASK_OVERWRITE, TASK_TYPE
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
generate()
The application's name.The class path for the application.The application's default JVM options.The directory to write the scripts into in the distribution.The environment variable to use to control exit value (Windows only).protected org.gradle.internal.jvm.JavaModuleDetector
The main class name used to start the Java application.Deprecated.The main module name used to start the modular Java application.Returns the module path handling for executing the main class.protected ObjectFactory
The environment variable to use to provide additional options to the JVM.The directory to write the scripts into.Returns the full path to the Unix script.The UNIX-like start script generator.Returns the full path to the Windows script.The Windows start script generator.void
setApplicationName
(String applicationName) void
setClasspath
(FileCollection classpath) void
setDefaultJvmOpts
(Iterable<String> defaultJvmOpts) void
setExecutableDir
(String executableDir) The directory to write the scripts into in the distribution.void
setExitEnvironmentVar
(String exitEnvironmentVar) void
setMainClassName
(String mainClassName) Deprecated.void
setOptsEnvironmentVar
(String optsEnvironmentVar) void
setOutputDir
(File outputDir) void
setUnixStartScriptGenerator
(ScriptGenerator unixStartScriptGenerator) void
setWindowsStartScriptGenerator
(ScriptGenerator windowsStartScriptGenerator) Methods inherited from class org.gradle.api.internal.ConventionTask
conventionMapping, conventionMapping, getConventionMapping
Methods inherited from class org.gradle.api.DefaultTask
compareTo, configure, dependsOn, doFirst, doFirst, doFirst, doLast, doLast, doLast, finalizedBy, getActions, getAnt, getDependsOn, getDescription, getDestroyables, getDidWork, getEnabled, getExtensions, getFinalizedBy, getGroup, getInputs, getLocalState, getLogger, getLogging, getMustRunAfter, getName, getOutputs, getPath, getProject, getShouldRunAfter, getState, getTaskDependencies, getTemporaryDir, getTimeout, hasProperty, mustRunAfter, onlyIf, onlyIf, onlyIf, property, setActions, setDependsOn, setDescription, setDidWork, setEnabled, setFinalizedBy, setGroup, setMustRunAfter, setOnlyIf, setOnlyIf, setOnlyIf, setProperty, setShouldRunAfter, shouldRunAfter, usesService
Methods inherited from class org.gradle.api.internal.AbstractTask
acceptServiceReferences, appendParallelSafeAction, doNotTrackState, getAsDynamicObject, getConvention, getIdentityPath, getImpliesSubProjects, getLifecycleDependencies, getOnlyIf, getReasonNotToTrackState, getReasonTaskIsIncompatibleWithConfigurationCache, getRequiredServices, getServices, getSharedResources, getStandardOutputCapture, getTaskActions, getTaskIdentity, getTemporaryDirFactory, hasTaskActions, injectIntoNewInstance, isCompatibleWithConfigurationCache, isEnabled, isHasCustomActions, notCompatibleWithConfigurationCache, prependParallelSafeAction, setImpliesSubProjects
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.gradle.api.Task
doNotTrackState, getConvention, notCompatibleWithConfigurationCache
-
Constructor Details
-
CreateStartScripts
public CreateStartScripts()
-
-
Method Details
-
getObjectFactory
-
getJavaModuleDetector
@Inject protected org.gradle.internal.jvm.JavaModuleDetector getJavaModuleDetector() -
getOptsEnvironmentVar
The environment variable to use to provide additional options to the JVM. -
getExitEnvironmentVar
The environment variable to use to control exit value (Windows only). -
getUnixScript
Returns the full path to the Unix script. The target directory is represented by the output directory, the file name is the application name without a file extension. -
getWindowsScript
Returns the full path to the Windows script. The target directory is represented by the output directory, the file name is the application name plus the file extension .bat. -
getOutputDir
The directory to write the scripts into. -
setOutputDir
-
getExecutableDir
The directory to write the scripts into in the distribution.- Since:
- 4.5
-
setExecutableDir
The directory to write the scripts into in the distribution.- Since:
- 4.5
-
getMainModule
The main module name used to start the modular Java application.- Since:
- 6.4
-
getMainClass
The main class name used to start the Java application.- Since:
- 6.4
-
getMainClassName
Deprecated.The main class name used to start the Java application. -
setMainClassName
Deprecated. -
getDefaultJvmOpts
The application's default JVM options. Defaults to an empty list. -
setDefaultJvmOpts
-
getApplicationName
The application's name. -
setApplicationName
-
setOptsEnvironmentVar
-
setExitEnvironmentVar
-
getClasspath
The class path for the application. -
getModularity
Returns the module path handling for executing the main class.- Since:
- 6.4
-
setClasspath
-
getUnixStartScriptGenerator
The UNIX-like start script generator.Defaults to an implementation of
TemplateBasedScriptGenerator
. -
setUnixStartScriptGenerator
-
getWindowsStartScriptGenerator
The Windows start script generator.Defaults to an implementation of
TemplateBasedScriptGenerator
. -
setWindowsStartScriptGenerator
-
generate
public void generate() -
getRelativeClasspath
-