Build.gradle: Difference between revisions

From NovaOrdis Knowledge Base
Jump to navigation Jump to search
 
(23 intermediate revisions by the same user not shown)
Line 1: Line 1:
=Overview=
=External=
* https://docs.gradle.org/current/userguide/writing_build_scripts.html


The project-level configuration script that contains task configuration for the current project, written in the Gradle's DSL. It tells Gradle what to build. The build script may contain any Groovy language element, including:
=Internal=
* [[Gradle_Concepts#Configuration_Scripts_and_Core_Types|Gradle Concepts]]
* [[Gradle Project#Overview|Project]]


* <tt>println</tt>
=Overview=
* [[#Variables|variable declarations]]
build.gradle is referred to as an Gradle build script. It is the script interface to a [[Gradle_Project#Project_API_and_build.gradle_DSL|Project instance]].
* [[Gradle_Concepts_ToDeplete#Plugin|plugin declarations]]
* [[#Repositories|repositories]]
 
The property access and method calls are delegated to a [[Gradle_Concepts_ToDeplete#Project|project object]].
 
build.gradle can be created automatically on project setup with [[Gradle_Operations#Start_a_Project|gradle init]]. To make build scripts more concise, Gradle automatically adds the set of default Gradle import statements to the script.  
 
build scripts are optional for multi-project builds.
 
build.gradle is written in [[Groovy]]. Groovy has both double-quoted and single-quoted String literals. The main difference is that double-quoted String literals support String interpolation.


=Example=
=Example=
<syntaxhighlight lang='groovy'>


<syntaxhighlight lang='groovy'>
apply plugin: 'java'
apply plugin: 'java'


group = "io.novaordis.playground.gradle"
// name comes from the directory name or it can be changed in settings.gradle
version = "1.0"
group = "playground.example"
sourceCompatibility = 1.8
version = "0.1.0"
targetCompatibility = 1.8
description = "A Gradle example project"


repositories {
repositories {
    mavenLocal()
     mavenCentral()
     mavenCentral()
}
configurations.all {
    resolutionStrategy.cacheChangingModulesFor 3600, 'seconds'
}
}


Line 41: Line 31:
configurations {
configurations {
     testImplementation.exclude group: 'com.example'
     testImplementation.exclude group: 'com.example'
}
configurations.all {
    resolutionStrategy.cacheChangingModulesFor 3600, 'seconds'
}
}


Line 55: Line 49:
     main = "io.novaordis.playground.gradle.java.Main"
     main = "io.novaordis.playground.gradle.java.Main"
}
}
</syntaxhighlight>
=Non-Default Build File Name=
The name of the build file can be changed using [[Gradle_Concepts_ToDeplete#Project_Descriptor|project descriptors]]:
<syntaxhighlight lang='groovy'>
project(':projectA').buildFileName = 'projectA.gradle'
</syntaxhighlight>
</syntaxhighlight>


Line 71: Line 57:
</syntaxhighlight>
</syntaxhighlight>


=DSL=
=Code=


The following elements are part of [https://docs.gradle.org/current/dsl/org.gradle.api.Project.html Project] API.
The build script may include general-purpose Java and Groovy code:
 
<syntaxhighlight lang='groovy'>
==configurations.all==


Applies enclosed to all [[Gradle_Concepts_ToDeplete#Dependency_Configuration|configurations]].
class Experimental {


<syntaxhighlight lang='groovy'>
     private String name;
configurations.all {
     resolutionStrategy.cacheDynamicVersionsFor 10, 'minutes'
}
</syntaxhighlight>


Alternative:
    Experimental(String name) {


<syntaxhighlight lang='groovy'>
        this.name = name;
configurations.all {
    resolutionStrategy {
        cacheDynamicVersionsFor 10, 'minutes'
     }
     }
}
</syntaxhighlight>


===Configuration===
    @Override
 
    public String toString() {
====resolutionStrategy====
        return name;
 
     }
{{External|https://docs.gradle.org/current/dsl/org.gradle.api.artifacts.ResolutionStrategy.html}}
 
=====cacheDynamicVersionsFor=====
 
Configures [[Gradle_Concepts_ToDeplete#Dynamic_Version|dynamic version]] caching threshold.
 
<syntaxhighlight lang='groovy'>
resolutionStrategy.cacheDynamicVersionsFor 10, 'minutes'
</syntaxhighlight>
 
=====cacheChangingModulesFor=====
 
==configurations==
 
<syntaxhighlight lang='groovy'>
configurations {
     testCompile.exclude group: 'io.example'
}
}
</syntaxhighlight>


==buildscript==
def experimental = new Experimental("blue");


Used when [[Gradle Gradle_Concepts_ToDeplete#External_Plugins|external plugins]] need to be downloaded.
task test {
 
     doLast {
<syntaxhighlight lang='groovy'>
         println experimental
buildscript {
     repositories {
         maven { url 'https://plugins.gradle.org/m2/' }
     }
     }
  dependencies {
    classpath 'com.netflix.nebula:gradle-ospackage-plugin:4.3.0'
  }
}
}
</syntaxhighlight>
</syntaxhighlight>
==<span id='Repositories'></span>repositories==
{{External|https://docs.gradle.org/current/userguide/declaring_repositories.html}}
[[Gradle_Concepts_ToDeplete#Repository|Repositories]] are declared in a 'repositories' block:
<syntaxhighlight lang='groovy'>
repositories {
    ...
}
</syntaxhighlight>
Multiple repositories can be declared in the same block. Syntax examples are available for [[Gradle_Concepts_ToDeplete#Custom_Maven_Repository|custom Maven repositories]], [[Gradle_Concepts_ToDeplete#flatDir|directory-based repositories]], [[Gradle_Concepts_ToDeplete#Maven_Central|Maven Central]], etc. The most common setting is declaring that our dependencies are available in Maven Central:
<syntaxhighlight lang='groovy'>
repositories {
    mavenCentral()
}
</syntaxhighlight>
=Multi-Project Configuration=
==allprojects==
The <tt>allprojects</tt> block is used to add configuration items that will apply to all [[Gradle_Concepts_ToDeplete#Multi-Project_Build|sub-projects]], as well as the root project.
<syntaxhighlight lang='groovy'>
allprojects {
  repositories {
    ...
  }
}
</syntaxhighlight>
"allprojects" is a property that contains a list with the current project and all its subprojects underneath it. It can be called with a closure, and the statements of the closure are delegated to the projects.
==subprojects==
The <tt>subprojects</tt> block is used to add configuration times for sub-projects only.
<syntaxhighlight lang='groovy'>
subprojects {
    ...
}
</syntaxhighlight>
=Custom Tasks=
{{Internal|Gradle Custom Task#Overview|Custom Tasks}}
=Respond to Build Lifecycle Events=
Example of how to respond to [[Gradle_Concepts_ToDeplete#Build_Phases|project build lifecycle events]].
<syntaxhighlight lang='groovy'>
allprojects {
      afterEvaluate { project ->
          if (project.hasTests) {
              println "Adding test task to $project"
              project.task('test') {
                  doLast {
                        println "running tests for $project"
                  }
              }
          }
    }
}
</syntaxhighlight>
<syntaxhighlight lang='groovy'>
gradle.afterProject {project, projectState ->
      if (projectState.failure) {
          println "Evaluation of $project FAILED"
      } else {
          println "Evaluation of $project succeeded"
      }
}
</syntaxhighlight>
=Respond to Task Lifecycle Events=
Examples of how to respond to [[Gradle_Concepts_ToDeplete#Task|task]] lifecycle events.
==Task Creation==
<syntaxhighlight lang='groovy'>
tasks.whenTaskAdded { task ->
      task.ext.srcDir = 'src/main/java'
}
</syntaxhighlight>
==Task Execution==
<syntaxhighlight lang='groovy'>
gradle.taskGraph.beforeTask { Task task ->
      println "executing $task ..."
}
gradle.taskGraph.afterTask { Task task, TaskState state ->
      if (state.failure) {
          println "FAILED"
      }
      else {
          println "done"
      }
}</syntaxhighlight>

Latest revision as of 22:10, 11 October 2020

External

Internal

Overview

build.gradle is referred to as an Gradle build script. It is the script interface to a Project instance.

Example

apply plugin: 'java'

// name comes from the directory name or it can be changed in settings.gradle
group = "playground.example"
version = "0.1.0"
description = "A Gradle example project"

repositories {
    mavenLocal()
    mavenCentral()
}

dependencies {
    implementation 'org.slf4j:slf4j-api:1.7.12'
    testImplementation 'junit:junit:4.+'
}

configurations {
    testImplementation.exclude group: 'com.example'
}

configurations.all {
    resolutionStrategy.cacheChangingModulesFor 3600, 'seconds'
}

compileJava {
    options.compilerArgs += ['-Xlint']
}

javadoc {
    options.charSet = 'UTF-8'
}

task runMain(type: JavaExec) {
    classpath = sourceSets.main.runtimeClasspath
    main = "io.novaordis.playground.gradle.java.Main"
}

Comments

// This is a comment

Code

The build script may include general-purpose Java and Groovy code:

class Experimental {

    private String name;

    Experimental(String name) {

        this.name = name;
    }

    @Override
    public String toString() {
        return name;
    }
}

def experimental = new Experimental("blue");

task test {
    doLast {
        println experimental
    }
}