# Integrating with Application Plugin
Shadow reacts to the presence of Gradle's
application
(opens new window) plugin and will automatically
configure additional tasks for running the shadowed JAR and creating distributions containing the shadowed JAR.
Just like the normal jar
task, when the application
plugin is applied, the shadowJar
manifest will be
configured to contain the Main-Class
attribute with the value specified in the project's mainClassName
attribute.
// Using Shadow with Application Plugin
plugins {
id 'java'
id 'application'
id 'com.gradleup.shadow'
}
application {
mainClass = 'myapp.Main'
}
# Running the Shadow JAR
When applied along with the application
plugin, the runShadow
task will be created for starting
the application from the shadowed JAR.
The runShadow
task is a JavaExec
(opens new window)
task that is configured to execute java -jar myproject-all.jar
.
It can be configured the same as any other JavaExec
task.
// Configuring the runShadow Task
plugins {
id 'java'
id 'application'
id 'com.gradleup.shadow'
}
application {
mainClass = 'myapp.Main'
// Optionally, you can add default JVM arguments to the start scripts like this:
applicationDefaultJvmArgs = ['--add-opens=java.base/java.lang=ALL-UNNAMED']
}
tasks.named('runShadow', JavaExec) {
args 'foo'
}
# Distributing the Shadow JAR
The Shadow plugin will also configure distribution tasks when in the presence of the application
plugin.
The plugin will create shadowDistZip
and shadowDistTar
which creates Zip and Tar distributions
respectively.
Each distribution will contain the shadowed JAR file along with the necessary start scripts to launch
the application.
Additionally, the plugin will create the installShadowDist
and startShadowScripts
tasks which stages the necessary
files for a distribution to build/install/<project name>-shadow/
.
You can also add more files into the distribution like:
// Add extra files to the distribution
plugins {
id 'java'
id 'application'
id 'com.gradleup.shadow'
}
application {
mainClass = 'myapp.Main'
// Optionally, you can include `some/dir` files in the distribution like this:
applicationDistribution.from('some/dir') {
include '*.txt'
}
}
// `shadow` is the name of the distribution created by Shadow plugin
distributions.named('shadow') {
// Optionally, you can add more files into extra directory in the distribution like this:
contents.into('extra') {
from project.file('extra/echo.sh')
}
}
View the official doc described (opens new window) for more information about configuring distributions.