Book Image

Gradle Effective Implementation Guide

Book Image

Gradle Effective Implementation Guide

Overview of this book

Gradle is the next generation in build automation. It uses convention-over-configuration to provide good defaults, but is also flexible enough to be usable in every situation you encounter in daily development. Build logic is described with a powerful DSL and empowers developers to create reusable and maintainable build logic."Gradle Effective Implementation Guide" is a great introduction and reference for using Gradle. The Gradle build language is explained with hands on code and practical applications. You learn how to apply Gradle in your Java, Scala or Groovy projects, integrate with your favorite IDE and how to integrate with well-known continuous integration servers.Start with the foundations and work your way through hands on examples to build your knowledge of Gradle to skyscraper heights. You will quickly learn the basics of Gradle, how to write tasks, work with files and how to use write build scripts using the Groovy DSL. Then as you develop you will be shown how to use Gradle for Java projects. Compile, package, test and deploy your applications with ease. When you've mastered the simple, move on to the sublime and integrate your code with continuous integration servers and IDEs. By the end of the "Gradle Effective Implementation Guide" you will be able to use Gradle in your daily development. Writing tasks, applying plugins and creating build logic will be second nature.
Table of Contents (20 chapters)
Gradle Effective Implementation Guide
Credits
About the Author
Acknowledgement
About the Reviewers
www.PacktPub.com
Preface
Index

Working with multi-project builds


Let's start with a simple multi-project structure. We have a root project called garden with two other projects, tree and flower. The project structure is as follows:

garden/
    tree/
    flower/

We will add a new task printInfo to each of these projects. The task will print out the name of the project to System.out. We must add a file build.gradle to each project, with the following contents:

task printInfo << {
    println "This is ${project.name}"
}

To execute the task for each project, we must first enter the correct directory and then invoke the task with Gradle. Or, we run build.gradle for a specific project with the -b argument of Gradle. We get the following output, if we run the task for each project:

garden $ gradle -q printInfo
This is garden
garden $ cd tree
tree $ gradle -q printInfo
This is tree
tree $ cd ..
garden $ gradle -b flower/build.gradle printInfo
This is flower

We have multiple projects, but we haven't used Gradle's support for...