CINXE.COM
Upgrading your build from Gradle 5.x to 6.0
<!DOCTYPE html> <html lang=""> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta name="generator" content="Asciidoctor 2.0.23"> <title>Upgrading your build from Gradle 5.x to 6.0</title> <style> /* * Copyright 2018 the original author or authors. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* Custom Admonition Blocks */ body { --gradle-blue: #209BC4; --gradle-bg-dark: #010002; --gradle-bg-gray: #F8F8F8; --gradle-bg-white: #FFFFFF; --gradle-blue: #209BC4; --gradle-blue-lite: #4DC9C0; --gradle-blue-dark: #1b3262; --gradle-blue-darker: #19274f; --button-gradient-angle: 160deg; --caution-color: #e40046; --caution-on-color: #fff; --important-color: #802392; --important-on-color: #fff; --note-color: #2d7dd2; --note-on-color: #fff; --tip-color: #43b929; --tip-on-color: #fff; --warning-color: #f70; --warning-on-color: #fff; --admonition-background: #fafafa; --doc-icon-filter: invert(14.5%); --rem-base: 18; --black-color: #000; --white-color: #fff; --text-color: #02303A; --title-color: #02303A; --header-color: rgba(0, 0, 0, 0.85); --footer-color: #fff; --footer-other-text-color: #02303; --footer-form-color: #1BA8CB; --code-color: #f7f7f8; --code-text-color: rgba(0, 0, 0, 0.9); --code-link-color: #021274; --num-color: rgba(0, 0, 0, 0.8); --nav-color: #f8f8f7; --table-color: #f7f8f7; --box-shadow-color: rgba(0, 0, 0, .15); --top-header-color: #fff; --footer-white-color: #fff; --footer-text-color: #fff; --quoteblock-color: #7a2518; --menu-burger-color: #fff; --various-border-color: #e7e7e9; } body.dark-theme { --admonition-background: #2a2929; --black-color: #fff; --white-color: #121212; --text-color: #aaa; --title-color: #fff; --header-color: rgba(255, 255, 255, 0.85); --footer-color: #121212; --footer-other-text-color: #ddd; --code-color: #1f1f1f; --code-text-color: rgba(255, 255, 255, 0.9); --code-link-color: #1fafcc; --num-color: #fff; --nav-color: #121212; --table-color: #121212; --box-shadow-color: rgba(255, 255, 255, .15); --top-header-color: #242526; --footer-white-color: #242526; --footer-text-color: #aaa; --footer-form-color: #1BA8CB; --quoteblock-color: #1DA2BD; --menu-burger-color: #242526; --various-border-color: #242526; } @media (prefers-color-scheme: dark) { /* defaults to dark theme */ body { --admonition-background: #2a2929; --black-color: #fff; --white-color: #121212; --text-color: #aaa; --title-color: #fff; --header-color: rgba(255, 255, 255, 0.85); --footer-color: #121212; --footer-other-text-color: #ddd; --code-color: #1f1f1f; --code-text-color: rgba(255, 255, 255, 0.9); --code-link-color: #1fafcc; --num-color: #fff; --nav-color: #121212; --table-color: #121212; --box-shadow-color: rgba(255, 255, 255, .15); --top-header-color: #242526; --footer-white-color: #242526; --footer-text-color: #aaa; --footer-form-color: #1BA8CB; --quoteblock-color: #1DA2BD; --menu-burger-color: #242526; --various-border-color: #242526; } body.light-theme { --gradle-blue: #209BC4; --gradle-bg-dark: #010002; --gradle-bg-gray: #F8F8F8; --gradle-bg-white: #FFFFFF; --gradle-blue: #209BC4; --gradle-blue-lite: #4DC9C0; --gradle-blue-dark: #1b3262; --gradle-blue-darker: #19274f; --button-gradient-angle: 160deg; --caution-color: #e40046; --caution-on-color: #fff; --important-color: #802392; --important-on-color: #fff; --note-color: #2d7dd2; --note-on-color: #fff; --tip-color: #43b929; --tip-on-color: #fff; --warning-color: #f70; --warning-on-color: #fff; --admonition-background: #fafafa; --doc-icon-filter: invert(14.5%); --rem-base: 18; --black-color: #000; --white-color: #fff; --text-color: #02303A; --title-color: #02303A; --header-color: rgba(0, 0, 0, 0.85); --footer-color: #fff; --footer-other-text-color: #02303; --code-color: #f7f7f8; --code-text-color: rgba(0, 0, 0, 0.9); --code-link-color: #021274; --num-color: rgba(0, 0, 0, 0.8); --nav-color: #f8f8f7; --table-color: #f7f8f7; --box-shadow-color: rgba(0, 0, 0, .15); --top-header-color: #fff; --footer-white-color: #fff; --footer-text-color: #fff; --footer-form-color: #1BA8CB; --quoteblock-color: #7a2518; --menu-burger-color: #fff; --various-border-color: #e7e7e9; } } .cls-1 { fill: #02303a; } body.dark-theme { .cls-1 { fill: #fff; } } @media (prefers-color-scheme: dark) { .cls-1 { fill: #fff; } body.light-theme { .cls-1 { fill: #02303a; } } } /* Lato (normal, regular) */ @font-face { font-family: Lato; font-weight: 400; font-style: normal; src: url("https://assets.gradle.com/lato/fonts/lato-normal/lato-normal.woff2") format("woff2"), url("https://assets.gradle.com/lato/fonts/lato-normal/lato-normal.woff") format("woff"); } /* Lato (normal, italic) */ @font-face { font-display: swap; font-family: Lato; font-weight: 400; font-style: italic; src: url("https://assets.gradle.com/lato/fonts/lato-normal-italic/lato-normal-italic.woff2") format("woff2"), url("https://assets.gradle.com/lato/fonts/lato-normal-italic/lato-normal-italic.woff") format("woff"); } /* Lato (bold, regular) */ @font-face { font-display: swap; font-family: Lato; font-weight: 500; font-style: normal; src: url("https://assets.gradle.com/lato/fonts/lato-semibold/lato-semibold.woff2") format("woff2"), url("https://assets.gradle.com/lato/fonts/lato-semibold/lato-semibold.woff") format("woff"); } /* Lato (bold, regular) */ @font-face { font-display: swap; font-family: Lato; font-weight: 800; font-style: normal; src: url("https://assets.gradle.com/lato/fonts/lato-heavy/lato-heavy.woff2") format("woff2"), url("https://assets.gradle.com/lato/fonts/lato-heavy/lato-heavy.woff") format("woff"); } /* BEGIN asciidoc.css */ /*! normalize.css v2.1.2 | MIT License | git.io/normalize */ /* ========================================================================== HTML5 display definitions ========================================================================== */ /** Correct `block` display not defined in IE 8/9. */ article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary { display: block; } /** Correct `inline-block` display not defined in IE 8/9. */ audio, canvas, video { display: inline-block; } /** Prevent modern browsers from displaying `audio` without controls. Remove excess height in iOS 5 devices. */ audio:not([controls]) { display: none; height: 0; } /** Address `[hidden]` styling not present in IE 8/9. Hide the `template` element in IE, Safari, and Firefox < 22. */ [hidden], template { display: none; } script { display: none !important; } /* ========================================================================== Base ========================================================================== */ /** 1. Set default font family to sans-serif. 2. Prevent iOS text size adjust after orientation change, without disabling user zoom. */ html { font-family: sans-serif; /* 1 */ -ms-text-size-adjust: 100%; /* 2 */ -webkit-text-size-adjust: 100%; /* 2 */ } /** Remove default margin. */ body { margin: 0; } /* ========================================================================== Links ========================================================================== */ /** Remove the gray background color from active links in IE 10. */ a { background: transparent; } /** Address `outline` inconsistency between Chrome and other browsers. */ a:focus { outline: thin dotted; } /** Improve readability when focused and also mouse hovered in all browsers. */ a:active, a:hover { outline: 0; } /* ========================================================================== Typography ========================================================================== */ /** Address variable `h1` font-size and margin within `section` and `article` contexts in Firefox 4+, Safari 5, and Chrome. */ h1 { font-size: 2em; margin: 0.67em 0; } /** Address styling not present in IE 8/9, Safari 5, and Chrome. */ abbr[title] { border-bottom: 1px dotted; } /** Address style set to `bolder` in Firefox 4+, Safari 5, and Chrome. */ b, strong { font-weight: bold; } /** Address styling not present in Safari 5 and Chrome. */ dfn { font-style: italic; } /** Address differences between Firefox and other browsers. */ hr { -moz-box-sizing: content-box; box-sizing: content-box; height: 0; } /** Address styling not present in IE 8/9. */ mark { background: #ff0; color: var(--black-color); } /** Correct font family set oddly in Safari 5 and Chrome. */ code, kbd, pre, samp { font-family: monospace, serif; font-size: 1em; } /** Improve readability of pre-formatted text in all browsers. */ pre { white-space: pre-wrap; } /** Set consistent quote types. */ q { quotes: "\201C""\201D""\2018""\2019"; } /** Address inconsistent and variable font size in all browsers. */ small { font-size: 80%; } /** Prevent `sub` and `sup` affecting `line-height` in all browsers. */ sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } sup { top: -0.5em; } sub { bottom: -0.25em; } /* ========================================================================== Embedded content ========================================================================== */ /** Remove border when inside `a` element in IE 8/9. */ img { border: 0; } /** Correct overflow displayed oddly in IE 9. */ svg:not(:root) { overflow: hidden; } /* ========================================================================== Figures ========================================================================== */ /** Address margin not present in IE 8/9 and Safari 5. */ figure { margin: 0; } /* ========================================================================== Forms ========================================================================== */ /** Define consistent border, margin, and padding. */ fieldset { border: 1px solid #c0c0c0; margin: 0 2px; padding: 0.35em 0.625em 0.75em; } /** 1. Correct `color` not being inherited in IE 8/9. 2. Remove padding so people aren't caught out if they zero out fieldsets. */ legend { border: 0; /* 1 */ padding: 0; /* 2 */ } /** 1. Correct font family not being inherited in all browsers. 2. Correct font size not being inherited in all browsers. 3. Address margins set differently in Firefox 4+, Safari 5, and Chrome. */ button, input, select, textarea { font-family: inherit; /* 1 */ font-size: 100%; /* 2 */ margin: 0; /* 3 */ } /** Address Firefox 4+ setting `line-height` on `input` using `!important` in the UA stylesheet. */ button, input { line-height: normal; } /** Address inconsistent `text-transform` inheritance for `button` and `select`. All other form control elements do not inherit `text-transform` values. Correct `button` style inheritance in Chrome, Safari 5+, and IE 8+. Correct `select` style inheritance in Firefox 4+ and Opera. */ button, select { text-transform: none; } /** 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio` and `video` controls. 2. Correct inability to style clickable `input` types in iOS. 3. Improve usability and consistency of cursor style between image-type `input` and others. */ button, html input[type="button"], input[type="reset"], input[type="submit"] { -webkit-appearance: button; /* 2 */ cursor: pointer; /* 3 */ } /** Re-set default cursor for disabled elements. */ button[disabled], html input[disabled] { cursor: default; } /** 1. Address box sizing set to `content-box` in IE 8/9. 2. Remove excess padding in IE 8/9. */ input[type="checkbox"], input[type="radio"] { box-sizing: border-box; /* 1 */ padding: 0; /* 2 */ } /** 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome. 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome (include `-moz` to future-proof). */ input[type="search"] { -webkit-appearance: textfield; /* 1 */ -moz-box-sizing: content-box; -webkit-box-sizing: content-box; /* 2 */ box-sizing: content-box; } /** Remove inner padding and search cancel button in Safari 5 and Chrome on OS X. */ input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; } /** Remove inner padding and border in Firefox 4+. */ button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; } /** 1. Remove default vertical scrollbar in IE 8/9. 2. Improve readability and alignment in all browsers. */ textarea { overflow: auto; /* 1 */ vertical-align: top; /* 2 */ } /* ========================================================================== Tables ========================================================================== */ /** Remove most spacing between table cells. */ table { border-collapse: collapse; border-spacing: 0; } meta.foundation-mq-small { font-family: "only screen and (min-width: 768px)"; width: 768px; } meta.foundation-mq-medium { font-family: "only screen and (min-width:1280px)"; width: 1280px; } meta.foundation-mq-large { font-family: "only screen and (min-width:1440px)"; width: 1440px; } *, *:before, *:after { -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; } html, body { font-size: 100%; } body { background: var(--white-color); color: var(--num-color); padding: 0; margin: 0; font-family: "Noto Serif", "DejaVu Serif", serif; font-weight: normal; font-style: normal; line-height: 1; position: relative; cursor: auto; } a:hover { cursor: pointer; } img, object, embed { max-width: 100%; height: auto; } object, embed { height: 100%; } img { -ms-interpolation-mode: bicubic; } #map_canvas img, #map_canvas embed, #map_canvas object, .map_canvas img, .map_canvas embed, .map_canvas object { max-width: none !important; } .left { float: left !important; } .right { float: right !important; } .text-left { text-align: left !important; } .text-right { text-align: right !important; } .text-center { text-align: center !important; } .text-justify { text-align: justify !important; } .hide { display: none; } .antialiased { -webkit-font-smoothing: antialiased; } img { display: inline-block; vertical-align: middle; } textarea { height: auto; min-height: 50px; } select { width: 100%; } object, svg { display: inline-block; vertical-align: middle; } .center { margin-left: auto; margin-right: auto; } .spread { width: 100%; } p.lead, .paragraph.lead>p, #preamble>.sectionbody>.paragraph:first-of-type p { font-size: 1.21875em; line-height: 1.6; } .subheader, .admonitionblock td.content>.title, .audioblock>.title, .exampleblock>.title, .imageblock>.title, .listingblock>.title, .literalblock>.title, .stemblock>.title, .openblock>.title, .paragraph>.title, .quoteblock>.title, table.tableblock>.title, .verseblock>.title, .videoblock>.title, .dlist>.title, .olist>.title, .ulist>.title, .qlist>.title, .hdlist>.title { line-height: 1.45; color: #7a2518; font-weight: normal; margin-top: 0; margin-bottom: 0.25em; } /* Typography resets */ div, dl, dt, dd, ul, ol, li, h1, h2, h3, #toctitle, .sidebarblock>.content>.title, h4, h5, h6, pre, form, p, blockquote, th, td { margin: 0; padding: 0; direction: ltr; } /* Default Link Styles */ a { color: #2156a5; text-decoration: underline; line-height: inherit; } a:hover, a:focus { color: #1d4b8f; } a img { border: none; } /* Default paragraph styles */ p { font-family: inherit; font-weight: normal; font-size: 1em; line-height: 1.6; margin-bottom: 1.25em; text-rendering: optimizeLegibility; } p aside { font-size: 0.875em; line-height: 1.35; font-style: italic; } /* Default header styles */ h1, h2, h3, #toctitle, .sidebarblock>.content>.title, h4, h5, h6 { font-family: "Open Sans", "DejaVu Sans", sans-serif; font-weight: 300; font-style: normal; color: #ba3925; text-rendering: optimizeLegibility; margin-top: 1em; margin-bottom: 0.5em; line-height: 1.0125em; } h1 small, h2 small, h3 small, #toctitle small, .sidebarblock>.content>.title small, h4 small, h5 small, h6 small { font-size: 60%; color: #e99b8f; line-height: 0; } h1 { font-size: 2.125em; } h2 { font-size: 1.6875em; } h3, #toctitle, .sidebarblock>.content>.title { font-size: 1.375em; } h4 { font-size: 1.125em; } h5 { font-size: 1.125em; } h6 { font-size: 1em; } hr { border: solid #ddddd8; border-width: 1px 0 0; clear: both; margin: 1.25em 0 1.1875em; height: 0; } /* Helpful Typography Defaults */ em, i { font-style: italic; line-height: inherit; } strong, b { font-weight: bold; line-height: inherit; } small { font-size: 60%; line-height: inherit; } code { font-family: "Droid Sans Mono", "DejaVu Sans Mono", monospace; font-weight: normal; color: var(--code-text-color); } a code { color: var(--code-link-color); } /* Lists */ ul, ol, dl { font-size: 1em; line-height: 1.6; margin-bottom: 1.25em; list-style-position: outside; font-family: inherit; } ul, ol { margin-left: 1.5em; } ul.no-bullet, ol.no-bullet { margin-left: 1.5em; } /* Unordered Lists */ ul li ul, ul li ol { margin-left: 1.25em; margin-bottom: 0; font-size: 1em; /* Override nested font-size change */ } ul.square li ul, ul.circle li ul, ul.disc li ul { list-style: inherit; } ul.square { list-style-type: square; } ul.circle { list-style-type: circle; } ul.disc { list-style-type: disc; } ul.no-bullet { list-style: none; } /* Ordered Lists */ ol li ul, ol li ol { margin-left: 1.25em; margin-bottom: 0; } /* Definition Lists */ dl dt { margin-bottom: 0.3125em; font-weight: bold; } dl dd { margin-bottom: 1.25em; } /* Abbreviations */ abbr, acronym { text-transform: uppercase; font-size: 90%; color: var(--num-color); border-bottom: 1px dotted #dddddd; cursor: help; } abbr { text-transform: none; } /* Blockquotes */ blockquote { margin: 0 0 1.25em; padding: 0.5625em 1.25em 0 1.1875em; border-left: 1px solid #dddddd; } blockquote cite { display: block; font-size: 0.9375em; color: rgba(0, 0, 0, 0.6); } blockquote cite:before { content: "\2014 \0020"; } blockquote cite a, blockquote cite a:visited { color: rgba(0, 0, 0, 0.6); } blockquote, blockquote p { line-height: 1.6; color: var(--header-color); } /* Microformats */ .vcard { display: inline-block; margin: 0 0 1.25em 0; border: 1px solid #dddddd; padding: 0.625em 0.75em; } .vcard li { margin: 0; display: block; } .vcard .fn { font-weight: bold; font-size: 0.9375em; } .vevent .summary { font-weight: bold; } .vevent abbr { cursor: auto; text-decoration: none; font-weight: bold; border: none; padding: 0 0.0625em; } @media only screen and (min-width: 768px) { h1, h2, h3, #toctitle, .sidebarblock>.content>.title, h4, h5, h6 { line-height: 1.2; } h1 { font-size: 2.75em; } h2 { font-size: 2.3125em; } h3, #toctitle, .sidebarblock>.content>.title { font-size: 1.6875em; } h4 { font-size: 1.4375em; } } /* Tables */ table { background: var(--white-color); margin-bottom: 1.25em; border: solid 1px #dedede; } table thead, table tfoot { background: var(--table-color); font-weight: bold; } table thead tr th, table thead tr td, table tfoot tr th, table tfoot tr td { padding: 0.5em 0.625em 0.625em; font-size: inherit; color: var(--num-color); text-align: left; } table tr th, table tr td { padding: 0.5625em 0.625em; font-size: inherit; color: var(--num-color); } table tr.even, table tr.alt, table tr:nth-of-type(even) { background: var(--nav-color); } table thead tr th, table tfoot tr th, table tbody tr td, table tr td, table tfoot tr td { display: table-cell; line-height: 1.6; } body { tab-size: 4; } h1, h2, h3, #toctitle, .sidebarblock>.content>.title, h4, h5, h6 { line-height: 1.2; word-spacing: -0.05em; } h1 strong, h2 strong, h3 strong, #toctitle strong, .sidebarblock>.content>.title strong, h4 strong, h5 strong, h6 strong { font-weight: 400; } .clearfix:before, .clearfix:after, .float-group:before, .float-group:after { content: " "; display: table; } .clearfix:after, .float-group:after { clear: both; } *:not(pre)>code { font-size: 0.9375em; font-style: normal !important; letter-spacing: 0; padding: 0.1em 0.5ex; word-spacing: -0.15em; background-color: var(--code-color); -webkit-border-radius: 4px; border-radius: 4px; line-height: 1.45; text-rendering: optimizeSpeed; word-wrap: break-word; } *:not(pre)>code.nobreak { word-wrap: normal; } *:not(pre)>code.nowrap { white-space: nowrap; } pre, pre>code { line-height: 1.45; color: var(--code-text-color); font-family: "Droid Sans Mono", "DejaVu Sans Mono", "Monospace", monospace; font-weight: normal; text-rendering: optimizeSpeed; } em em { font-style: normal; } strong strong { font-weight: normal; } .keyseq { color: rgba(51, 51, 51, 0.8); } kbd { font-family: "Droid Sans Mono", "DejaVu Sans Mono", monospace; display: inline-block; color: var(--num-color); font-size: 0.65em; line-height: 1.45; background-color: #f7f7f7; border: 1px solid #ccc; -webkit-border-radius: 3px; border-radius: 3px; -webkit-box-shadow: 0 1px 0 rgba(0, 0, 0, 0.2), 0 0 0 0.1em white inset; box-shadow: 0 1px 0 rgba(0, 0, 0, 0.2), 0 0 0 0.1em white inset; margin: 0 0.15em; padding: 0.2em 0.5em; vertical-align: middle; position: relative; top: -0.1em; white-space: nowrap; } .keyseq kbd:first-child { margin-left: 0; } .keyseq kbd:last-child { margin-right: 0; } .menuseq, .menu { color: var(--num-color); } b.button:before, b.button:after { position: relative; top: -1px; font-weight: normal; } b.button:before { content: "["; padding: 0 3px 0 2px; } b.button:after { content: "]"; padding: 0 2px 0 3px; } p a>code:hover { color: var(--code-text-color); } #header, #content, #footnotes, #footer { width: 100%; margin-left: auto; margin-right: auto; margin-top: 0; margin-bottom: 0; max-width: 62.5em; *zoom: 1; position: relative; padding-left: 0.9375em; padding-right: 0.9375em; } #header:before, #header:after, #content:before, #content:after, #footnotes:before, #footnotes:after, #footer:before, #footer:after { content: " "; display: table; } #header:after, #content:after, #footnotes:after, #footer:after { clear: both; } #content { margin-top: 1.25em; } #content:before { content: none; } #header>h1:first-child { color: var(--header-color); margin-top: 2.25rem; margin-bottom: 0; } #header>h1:first-child+#toc { margin-top: 8px; border-top: 1px solid #ddddd8; } #header>h1:only-child, body.toc2 #header>h1:nth-last-child(2) { border-bottom: 1px solid #ddddd8; padding-bottom: 8px; } #header .details { border-bottom: 1px solid #ddddd8; line-height: 1.45; padding-top: 0.25em; padding-bottom: 0.25em; padding-left: 0.25em; color: rgba(0, 0, 0, 0.6); display: -ms-flexbox; display: -webkit-flex; display: flex; -ms-flex-flow: row wrap; -webkit-flex-flow: row wrap; flex-flow: row wrap; } #header .details span:first-child { margin-left: -0.125em; } #header .details span.email a { color: var(--header-color); } #header .details br { display: none; } #header .details br+span:before { content: "\00a0\2013\00a0"; } #header .details br+span.author:before { content: "\00a0\22c5\00a0"; color: var(--header-color); } #header .details br+span#revremark:before { content: "\00a0|\00a0"; } #header #revnumber { text-transform: capitalize; } #header #revnumber:after { content: "\00a0"; } #content>h1:first-child:not([class]) { color: var(--header-color); border-bottom: 1px solid #ddddd8; padding-bottom: 8px; margin-top: 0; padding-top: 1rem; margin-bottom: 1.25rem; } #toc { border-bottom: 1px solid #efefed; padding-bottom: 0.5em; } #toc>ul { margin-left: 0.125em; } #toc ul.sectlevel0>li>a { font-style: italic; } #toc ul.sectlevel0 ul.sectlevel1 { margin: 0.5em 0; } #toc ul { font-family: "Open Sans", "DejaVu Sans", sans-serif; list-style-type: none; } #toc li { line-height: 1.3334; margin-top: 0.3334em; } #toc a { text-decoration: none; } #toc a:active { text-decoration: underline; } #toctitle { color: #7a2518; font-size: 1.2em; } @media only screen and (min-width: 768px) { #toctitle { font-size: 1.375em; } body.toc2 { padding-left: 15em; padding-right: 0; } #toc.toc2 { margin-top: 0 !important; background-color: var(--nav-color); position: fixed; width: 15em; left: 0; top: 0; border-right: 1px solid #efefed; border-top-width: 0 !important; border-bottom-width: 0 !important; z-index: 1000; padding: 1.25em 1em; height: 100%; overflow: auto; } #toc.toc2 #toctitle { margin-top: 0; margin-bottom: 0.8rem; font-size: 1.2em; } #toc.toc2>ul { font-size: 0.9em; margin-bottom: 0; } #toc.toc2 ul ul { margin-left: 0; padding-left: 1em; } #toc.toc2 ul.sectlevel0 ul.sectlevel1 { padding-left: 0; margin-top: 0.5em; margin-bottom: 0.5em; } body.toc2.toc-right { padding-left: 0; padding-right: 15em; } body.toc2.toc-right #toc.toc2 { border-right-width: 0; border-left: 1px solid #efefed; left: auto; right: 0; } } @media only screen and (min-width: 1280px) { body.toc2 { padding-left: 20em; padding-right: 0; } #toc.toc2 { width: 20em; } #toc.toc2 #toctitle { font-size: 1.375em; } #toc.toc2>ul { font-size: 0.95em; } #toc.toc2 ul ul { padding-left: 1.25em; } body.toc2.toc-right { padding-left: 0; padding-right: 20em; } } #content #toc { border-style: solid; border-width: 1px; border-color: #e0e0dc; margin-bottom: 1.25em; padding: 1.25em; background: var(--nav-color); -webkit-border-radius: 4px; border-radius: 4px; } #content #toc> :first-child { margin-top: 0; } #content #toc> :last-child { margin-bottom: 0; } #footer { max-width: 100%; background-color: var(--num-color); padding: 1.25em; } #footer-text { color: rgba(255, 255, 255, 0.8); line-height: 1.44; } .sect1 { padding-bottom: 0.625em; } @media only screen and (min-width: 768px) { .sect1 { padding-bottom: 1.25em; } } .sect1+.sect1 { border-top: 1px solid #efefed; } #content h1>a.anchor, h2>a.anchor, h3>a.anchor, #toctitle>a.anchor, .sidebarblock>.content>.title>a.anchor, h4>a.anchor, h5>a.anchor, h6>a.anchor { position: absolute; z-index: 1001; width: 1.5ex; margin-left: -1.5ex; display: block; text-decoration: none !important; visibility: hidden; text-align: center; font-weight: normal; } #content h1>a.anchor:before, h2>a.anchor:before, h3>a.anchor:before, #toctitle>a.anchor:before, .sidebarblock>.content>.title>a.anchor:before, h4>a.anchor:before, h5>a.anchor:before, h6>a.anchor:before { content: "\00A7"; font-size: 0.85em; display: block; padding-top: 0.1em; } #content h1:hover>a.anchor, #content h1>a.anchor:hover, h2:hover>a.anchor, h2>a.anchor:hover, h3:hover>a.anchor, #toctitle:hover>a.anchor, .sidebarblock>.content>.title:hover>a.anchor, h3>a.anchor:hover, #toctitle>a.anchor:hover, .sidebarblock>.content>.title>a.anchor:hover, h4:hover>a.anchor, h4>a.anchor:hover, h5:hover>a.anchor, h5>a.anchor:hover, h6:hover>a.anchor, h6>a.anchor:hover { visibility: visible; } #content h1>a.link, h2>a.link, h3>a.link, #toctitle>a.link, .sidebarblock>.content>.title>a.link, h4>a.link, h5>a.link, h6>a.link { color: #ba3925; text-decoration: none; } #content h1>a.link:hover, h2>a.link:hover, h3>a.link:hover, #toctitle>a.link:hover, .sidebarblock>.content>.title>a.link:hover, h4>a.link:hover, h5>a.link:hover, h6>a.link:hover { color: #a53221; } .audioblock, .imageblock, .literalblock, .listingblock, .stemblock, .videoblock { margin-bottom: 1.25em; } .admonitionblock td.content>.title, .audioblock>.title, .exampleblock>.title, .imageblock>.title, .listingblock>.title, .literalblock>.title, .stemblock>.title, .openblock>.title, .paragraph>.title, .quoteblock>.title, table.tableblock>.title, .verseblock>.title, .videoblock>.title, .dlist>.title, .olist>.title, .ulist>.title, .qlist>.title, .hdlist>.title { text-rendering: optimizeLegibility; text-align: left; font-family: "Noto Serif", "DejaVu Serif", serif; font-size: 1rem; font-style: italic; } table.tableblock>caption.title { white-space: nowrap; overflow: visible; max-width: 0; } .paragraph.lead>p, #preamble>.sectionbody>.paragraph:first-of-type p { color: var(--header-color); } table.tableblock #preamble>.sectionbody>.paragraph:first-of-type p { font-size: inherit; } /* Custom SVG logos coloring */ path { fill: #02303A; } body.dark-theme { path { fill: white; } } @media (prefers-color-scheme: dark) { path { fill: white; } body.light-theme { path { fill: #02303A; } } } /* Custom scroll bar */ /* Works on Firefox */ .docs-navigation { scrollbar-width: auto; scrollbar-color: #686868 #e7e7e9; } /* Works on Chrome, Edge, and Safari */ .docs-navigation::-webkit-scrollbar { width: 12px; } .docs-navigation::-webkit-scrollbar-track { background: #e7e7e9; } .docs-navigation::-webkit-scrollbar-thumb { background-color: #686868; border-radius: 20px; border: 3px #686868; } body.dark-theme { /* Works on Firefox */ * { scrollbar-width: auto; scrollbar-color: #686868 #242526; } /* Works on Chrome, Edge, and Safari */ *::-webkit-scrollbar { width: auto; } *::-webkit-scrollbar-track { background: #242526; } *::-webkit-scrollbar-thumb { background-color: #686868; border-radius: 20px; border: 3px #686868; } } @media (prefers-color-scheme: dark) { /* Works on Firefox */ * { scrollbar-width: auto; scrollbar-color: #686868 #242526; } /* Works on Chrome, Edge, and Safari */ *::-webkit-scrollbar { width: auto; } *::-webkit-scrollbar-track { background: #242526; } *::-webkit-scrollbar-thumb { background-color: #686868; border-radius: 20px; border: 3px #686868; } body.light-theme { .docs-navigation { scrollbar-width: auto; scrollbar-color: #686868 #e7e7e9; } /* Works on Chrome, Edge, and Safari */ .docs-navigation::-webkit-scrollbar { width: 12px; } .docs-navigation::-webkit-scrollbar-track { background: #e7e7e9; } .docs-navigation::-webkit-scrollbar-thumb { background-color: #686868; border-radius: 20px; border: 3px #686868; } } } /* Custom Admonition Blocks - Icons from https://github.com/primer/octicons */ .admonitionblock td div:last-of-type p { margin-bottom: 0em !important; } .admonitionblock { margin: 1.4rem 0 0 } .admonitionblock i { font-family: inherit; } .admonitionblock i.fa { background: no-repeat 50%/1em 1em; display: inline-block; filter: var(--doc-icon-filter); font-style: normal; height: 1em; -webkit-hyphens: none; hyphens: none; vertical-align: -.125em; width: 1em } .admonitionblock p, .admonitionblock td.content { font-size: 1rem; } .admonitionblock td.content>.title+*, .admonitionblock td.content>:not(.title):first-child { margin-top: 0 } .admonitionblock pre { font-size: calc(15/var(--rem-base)*1rem) } .admonitionblock>table { position: relative; table-layout: fixed; border: none; width: 100% } .admonitionblock td.content { word-wrap: anywhere; background: var(--admonition-background); padding: 1rem 1rem 1rem 1rem; width: 100%; border-radius: 4px; } .admonitionblock td.icon { background: linear-gradient(90deg, rgba(0, 0, 0, .2) 0, rgba(0, 0, 0, .2)) no-repeat 0 /2.075em 100%; border-radius: .5em; font-size: calc(15/var(--rem-base)*1rem); left: 0; line-height: 1; padding: .25em .075em; position: absolute; top: 0; transform: translate(-.5rem, -50%) } .admonitionblock td.icon i { align-items: center; background-position-x: .5em; display: inline-flex; filter: invert(100%); padding-left: 2em; vertical-align: initial; width: auto } .admonitionblock td.icon i::after { content: attr(title); filter: invert(100%); font-style: normal; font-weight: bold; margin: -.05em; padding: 0 .5em; text-transform: uppercase } .admonitionblock.caution td.icon { background-color: var(--caution-color); color: var(--caution-on-color) } .admonitionblock.caution td.icon i { background-image: url(./img/octicons-16.svg#view-flame) } .admonitionblock.important td.icon { background-color: var(--important-color); color: var(--important-on-color) } .admonitionblock.important td.icon i { background-image: url(./img/octicons-16.svg#view-stop) } .admonitionblock.note td.icon { background-color: var(--note-color); color: var(--note-on-color) } .admonitionblock.note td.icon i { background-image: url(./img/octicons-16.svg#view-info) } .admonitionblock.tip td.icon { background-color: var(--tip-color); color: var(--tip-on-color) } .admonitionblock.tip td.icon i { background-image: url(./img/octicons-16.svg#view-light-bulb) } .admonitionblock.warning td.icon { background-color: var(--warning-color); color: var(--warning-on-color) } .admonitionblock.warning td.icon i { background-image: url(./img/octicons-16.svg#view-alert) } /* Custom collapsible block */ details summary { width: 100%; padding: 1rem 0; border-top: 1px solid gray; position: relative; cursor: pointer; list-style: none; } details summary:after { content: "+"; color: var(--black-color); position: absolute; font-size: 1.75rem; line-height: 0; margin-top: 0.3rem; right: 0; font-weight: 400; transform-origin: center; transition: 200ms linear; } details[open] summary:after { transform: rotate(45deg); font-size: 2rem; } details summary { outline: 0; } details p { font-size: 0.95rem; margin: 0 0 1rem; padding-top: 1rem; } .exampleblock>.content { border-style: solid; border-width: 1px; border-color: #e6e6e6; margin-bottom: 1.25em; padding: 1.25em; background: var(--white-color); -webkit-border-radius: 4px; border-radius: 4px; } .exampleblock>.content> :first-child { margin-top: 0; } .exampleblock>.content> :last-child { margin-bottom: 0; } .sidebarblock { border-style: solid; border-width: 1px; border-color: #e0e0dc; margin-bottom: 1.25em; padding: 1.25em; background: var(--nav-color); -webkit-border-radius: 4px; border-radius: 4px; } .sidebarblock> :first-child { margin-top: 0; } .sidebarblock> :last-child { margin-bottom: 0; } .sidebarblock>.content>.title { color: #7a2518; margin-top: 0; text-align: center; } .exampleblock>.content> :last-child> :last-child, .exampleblock>.content .olist>ol>li:last-child> :last-child, .exampleblock>.content .ulist>ul>li:last-child> :last-child, .exampleblock>.content .qlist>ol>li:last-child> :last-child, .sidebarblock>.content> :last-child> :last-child, .sidebarblock>.content .olist>ol>li:last-child> :last-child, .sidebarblock>.content .ulist>ul>li:last-child> :last-child, .sidebarblock>.content .qlist>ol>li:last-child> :last-child { margin-bottom: 0; } .literalblock pre, .listingblock pre:not(.highlight), .listingblock pre[class="highlight"], .listingblock pre[class^="highlight "], .listingblock pre.CodeRay, .listingblock pre.prettyprint { background: var(--code-color); } .sidebarblock .literalblock pre, .sidebarblock .listingblock pre:not(.highlight), .sidebarblock .listingblock pre[class="highlight"], .sidebarblock .listingblock pre[class^="highlight "], .sidebarblock .listingblock pre.CodeRay, .sidebarblock .listingblock pre.prettyprint { background: #f2f1f1; } .literalblock pre, .literalblock pre[class], .listingblock pre, .listingblock pre[class] { -webkit-border-radius: 4px; border-radius: 4px; word-wrap: break-word; padding: 1em; font-size: 0.8125em; } .literalblock pre.nowrap, .literalblock pre[class].nowrap, .listingblock pre.nowrap, .listingblock pre[class].nowrap { overflow-x: auto; white-space: pre; word-wrap: normal; } @media only screen and (min-width: 768px) { .literalblock pre, .literalblock pre[class], .listingblock pre, .listingblock pre[class] { font-size: 0.90625em; } } @media only screen and (min-width: 1280px) { .literalblock pre, .literalblock pre[class], .listingblock pre, .listingblock pre[class] { font-size: 1em; } } .literalblock.output pre { color: var(--code-color); background-color: var(--code-text-color); } .listingblock pre.highlightjs { padding: 0; } .listingblock pre.highlightjs>code { padding: 1em; -webkit-border-radius: 4px; border-radius: 4px; } .listingblock pre.prettyprint { border-width: 0; } .listingblock>.content { position: relative; } .listingblock code[data-lang]:before { display: none; content: attr(data-lang); position: absolute; font-size: 0.75em; top: 0.425rem; right: 0.5rem; line-height: 1; text-transform: uppercase; color: #999; } .listingblock:hover code[data-lang]:before { display: block; } .listingblock.terminal pre .command:before { content: attr(data-prompt); padding-right: 0.5em; color: #999; } .listingblock.terminal pre .command:not([data-prompt]):before { content: "$"; } table.pyhltable { border-collapse: separate; border: 0; margin-bottom: 0; background: none; } table.pyhltable td { vertical-align: top; padding-top: 0; padding-bottom: 0; line-height: 1.45; } table.pyhltable td.code { padding-left: .75em; padding-right: 0; } pre.pygments .lineno, table.pyhltable td:not(.code) { color: #999; padding-left: 0; padding-right: .5em; border-right: 1px solid #ddddd8; } pre.pygments .lineno { display: inline-block; margin-right: .25em; } table.pyhltable .linenodiv { background: none !important; padding-right: 0 !important; } .quoteblock { margin: 0 1em 1.25em 1.5em; display: table; } .quoteblock>.title { margin-left: -1.5em; margin-bottom: 0.75em; } .quoteblock blockquote, .quoteblock blockquote p { color: var(--header-color); font-size: 1.15rem; line-height: 1.75; word-spacing: 0.1em; letter-spacing: 0; font-style: italic; text-align: justify; } .quoteblock blockquote { margin: 0; padding: 0; border: 0; } .quoteblock blockquote:before { content: "\201c"; float: left; font-size: 2.75em; font-weight: bold; line-height: 0.6em; margin-left: -0.6em; color: var(--quoteblock-color); text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1); } .quoteblock blockquote>.paragraph:last-child p { margin-bottom: 0; } .quoteblock .attribution { margin-top: 0.5em; margin-right: 0.5ex; text-align: right; } .quoteblock .quoteblock { margin-left: 0; margin-right: 0; padding: 0.5em 0; border-left: 3px solid rgba(0, 0, 0, 0.6); } .quoteblock .quoteblock blockquote { padding: 0 0 0 0.75em; } .quoteblock .quoteblock blockquote:before { display: none; } .verseblock { margin: 0 1em 1.25em 1em; } .verseblock pre { font-family: "Open Sans", "DejaVu Sans", sans; font-size: 1.15rem; color: var(--header-color); font-weight: 300; text-rendering: optimizeLegibility; } .verseblock pre strong { font-weight: 400; } .verseblock .attribution { margin-top: 1.25rem; margin-left: 0.5ex; } .quoteblock .attribution, .verseblock .attribution { font-size: 0.9375em; line-height: 1.45; font-style: italic; } .quoteblock .attribution br, .verseblock .attribution br { display: none; } .quoteblock .attribution cite, .verseblock .attribution cite { display: block; letter-spacing: -0.025em; color: rgba(0, 0, 0, 0.6); } .quoteblock.abstract { margin: 0 0 1.25em 0; display: block; } .quoteblock.abstract blockquote, .quoteblock.abstract blockquote p { text-align: left; word-spacing: 0; } .quoteblock.abstract blockquote:before, .quoteblock.abstract blockquote p:first-of-type:before { display: none; } table.tableblock { max-width: 100%; border-collapse: separate; } table.tableblock td>.paragraph:last-child p>p:last-child, table.tableblock th>p:last-child, table.tableblock td>p:last-child { margin-bottom: 0; } table.tableblock, th.tableblock, td.tableblock { border: 0 solid #dedede; } table.grid-all th.tableblock, table.grid-all td.tableblock { border-width: 0 1px 1px 0; } table.grid-all tfoot>tr>th.tableblock, table.grid-all tfoot>tr>td.tableblock { border-width: 1px 1px 0 0; } table.grid-cols th.tableblock, table.grid-cols td.tableblock { border-width: 0 1px 0 0; } table.grid-all *>tr>.tableblock:last-child, table.grid-cols *>tr>.tableblock:last-child { border-right-width: 0; } table.grid-rows th.tableblock, table.grid-rows td.tableblock { border-width: 0 0 1px 0; } table.grid-all tbody>tr:last-child>th.tableblock, table.grid-all tbody>tr:last-child>td.tableblock, table.grid-all thead:last-child>tr>th.tableblock, table.grid-rows tbody>tr:last-child>th.tableblock, table.grid-rows tbody>tr:last-child>td.tableblock, table.grid-rows thead:last-child>tr>th.tableblock { border-bottom-width: 0; } table.grid-rows tfoot>tr>th.tableblock, table.grid-rows tfoot>tr>td.tableblock { border-width: 1px 0 0 0; } table.frame-all { border-width: 1px; } table.frame-sides { border-width: 0 1px; } table.frame-topbot { border-width: 1px 0; } th.halign-left, td.halign-left { text-align: left; } th.halign-right, td.halign-right { text-align: right; } th.halign-center, td.halign-center { text-align: center; } th.valign-top, td.valign-top { vertical-align: top; } th.valign-bottom, td.valign-bottom { vertical-align: bottom; } th.valign-middle, td.valign-middle { vertical-align: middle; } table thead th, table tfoot th { font-weight: bold; } tbody tr th { display: table-cell; line-height: 1.6; background: var(--table-color); } tbody tr th, tbody tr th p, tfoot tr th, tfoot tr th p { color: var(--num-color); font-weight: bold; } p.tableblock>code:only-child { background: none; padding: 0; } p.tableblock { font-size: 1em; } td>div.verse { white-space: pre; } ol { margin-left: 1.75em; } ul li ol { margin-left: 1.5em; } dl dd { margin-left: 1.125em; } dl dd:last-child, dl dd:last-child> :last-child { margin-bottom: 0; } ol>li p, ul>li p, ul dd, ol dd, .olist .olist, .ulist .ulist, .ulist .olist, .olist .ulist { margin-bottom: 0.625em; } ul.unstyled, ol.unnumbered, ul.checklist, ul.none { list-style-type: none; } ul.unstyled, ol.unnumbered, ul.checklist { margin-left: 0.625em; } ul.checklist li>p:first-child>.fa-square-o:first-child, ul.checklist li>p:first-child>.fa-check-square-o:first-child { width: 1em; font-size: 0.85em; } ul.checklist li>p:first-child>input[type="checkbox"]:first-child { width: 1em; position: relative; top: 1px; } ul.inline { margin: 0 auto 0.625em auto; margin-left: -1.375em; margin-right: 0; padding: 0; list-style: none; overflow: hidden; } ul.inline>li { list-style: none; float: left; margin-left: 1.375em; display: block; } ul.inline>li>* { display: block; } .unstyled dl dt { font-weight: normal; font-style: normal; } ol.arabic { list-style-type: decimal; } ol.decimal { list-style-type: decimal-leading-zero; } ol.loweralpha { list-style-type: lower-alpha; } ol.upperalpha { list-style-type: upper-alpha; } ol.lowerroman { list-style-type: lower-roman; } ol.upperroman { list-style-type: upper-roman; } ol.lowergreek { list-style-type: lower-greek; } .hdlist>table, .colist>table { border: 0; background: none; } .hdlist>table>tbody>tr, .colist>table>tbody>tr { background: none; } td.hdlist1, td.hdlist2 { vertical-align: top; padding: 0 0.625em; } td.hdlist1 { font-weight: bold; padding-bottom: 1.25em; } .literalblock+.colist { margin-top: -0.5em; } .colist>table tr>td:first-of-type { padding: 0 0.75em; line-height: 1; } .colist>table tr>td:first-of-type img { max-width: initial; } .colist>table tr>td:last-of-type { padding: 0.25em 0; } .thumb, .th { line-height: 0; display: inline-block; border: solid 4px var(--white-color); -webkit-box-shadow: 0 0 0 1px #dddddd; box-shadow: 0 0 0 1px #dddddd; } .imageblock.left, .imageblock[style*="float: left"] { margin: 0.25em 0.625em 1.25em 0; } .imageblock.right, .imageblock[style*="float: right"] { margin: 0.25em 0 1.25em 0.625em; } .imageblock>.title { margin-bottom: 0; } .imageblock.thumb, .imageblock.th { border-width: 6px; } .imageblock.thumb>.title, .imageblock.th>.title { padding: 0 0.125em; } .image.left, .image.right { margin-top: 0.25em; margin-bottom: 0.25em; display: inline-block; line-height: 0; } .image.left { margin-right: 0.625em; } .image.right { margin-left: 0.625em; } a.image { text-decoration: none; display: inline-block; } a.image object { pointer-events: none; } sup.footnote, sup.footnoteref { font-size: 0.875em; position: static; vertical-align: super; } sup.footnote a, sup.footnoteref a { text-decoration: none; } sup.footnote a:active, sup.footnoteref a:active { text-decoration: underline; } #footnotes { padding-top: 0.75em; padding-bottom: 0.75em; margin-bottom: 0.625em; } #footnotes hr { width: 20%; min-width: 6.25em; margin: -0.25em 0 0.75em 0; border-width: 1px 0 0 0; } #footnotes .footnote { padding: 0 0.375em 0 0.225em; line-height: 1.3334; font-size: 0.875em; margin-left: 1.2em; text-indent: -1.05em; margin-bottom: 0.2em; } #footnotes .footnote a:first-of-type { font-weight: bold; text-decoration: none; } #footnotes .footnote:last-of-type { margin-bottom: 0; } #content #footnotes { margin-top: -0.625em; margin-bottom: 0; padding: 0.75em 0; } .gist .file-data>table { border: 0; background: var(--white-color); width: 100%; margin-bottom: 0; } .gist .file-data>table td.line-data { width: 99%; } div.unbreakable { page-break-inside: avoid; } .big { font-size: larger; } .small { font-size: smaller; } .underline { text-decoration: underline; } .overline { text-decoration: overline; } .line-through { text-decoration: line-through; } .green { color: #006000; } .red { color: #bf0000; } .yellow { color: #bfbf00; } span.icon>.fa { cursor: default; } .conum[data-value] { display: inline-block; color: var(--white-color) !important; background-color: var(--num-color); -webkit-border-radius: 100px; border-radius: 100px; text-align: center; font-size: 0.75em; width: 1.67em; height: 1.67em; line-height: 1.67em; font-family: "Open Sans", "DejaVu Sans", sans-serif; font-style: normal; font-weight: bold; } .conum[data-value] * { color: var(--white-color) !important; } .conum[data-value]+b { display: none; } .conum[data-value]:after { content: attr(data-value); } pre .conum[data-value] { position: relative; top: -0.125em; } b.conum * { color: inherit !important; } .conum:not([data-value]):empty { display: none; } dt, th.tableblock, td.content, div.footnote { text-rendering: optimizeLegibility; } h1, h2, p, td.content, span.alt { letter-spacing: -0.01em; } p strong, td.content strong, div.footnote strong { letter-spacing: -0.005em; } p, blockquote, dt, td.content, span.alt { font-size: 1.0625rem; } p { margin-bottom: 1.25rem; } .sidebarblock p, .sidebarblock dt, .sidebarblock td.content, p.tableblock { font-size: 1em; } .exampleblock>.content { background-color: #fffef7; border-color: #e0e0dc; -webkit-box-shadow: 0 1px 4px #e0e0dc; box-shadow: 0 1px 4px #e0e0dc; } .print-only { display: none !important; } @media print { @page { margin: 1.25cm 0.75cm; } * { -webkit-box-shadow: none !important; box-shadow: none !important; text-shadow: none !important; } a { color: inherit !important; text-decoration: underline !important; } a.bare, a[href^="#"], a[href^="mailto:"] { text-decoration: none !important; } a[href^="http:"]:not(.bare):after, a[href^="https:"]:not(.bare):after { content: "(" attr(href) ")"; display: inline-block; font-size: 0.875em; padding-left: 0.25em; } abbr[title]:after { content: " (" attr(title) ")"; } pre, blockquote, tr, img, object, svg { page-break-inside: avoid; } thead { display: table-header-group; } svg { max-width: 100%; } p, blockquote, dt, td.content { font-size: 1em; orphans: 3; widows: 3; } h2, h3, #toctitle, .sidebarblock>.content>.title, #toctitle, .sidebarblock>.content>.title { page-break-after: avoid; } #toc, .sidebarblock, .exampleblock>.content { background: none !important; } #toc { border-bottom: 1px solid #ddddd8 !important; padding-bottom: 0 !important; } .sect1 { padding-bottom: 0 !important; } .sect1+.sect1 { border: 0 !important; } #header>h1:first-child { margin-top: 1.25rem; } body.book #header { text-align: center; } body.book #header>h1:first-child { border: 0 !important; margin: 2.5em 0 1em 0; } body.book #header .details { border: 0 !important; display: block; padding: 0 !important; } body.book #header .details span:first-child { margin-left: 0 !important; } body.book #header .details br { display: block; } body.book #header .details br+span:before { content: none !important; } body.book #toc { border: 0 !important; text-align: left !important; padding: 0 !important; margin: 0 !important; } body.book #toc, body.book #preamble, body.book h1.sect0, body.book .sect1>h2 { page-break-before: always; } .listingblock code[data-lang]:before { display: block; } #footer { background: none !important; padding: 0 0.9375em; } #footer-text { color: rgba(0, 0, 0, 0.6) !important; font-size: 0.9em; } .hide-on-print { display: none !important; } .print-only { display: block !important; } .hide-for-print { display: none !important; } .show-for-print { display: inherit !important; } } /* END asciidoc.css */ html, body { margin: 0; padding: 0; } html { font-size: 16px; font-weight: 400; line-height: 1.5; } body { color: var(--text-color); background-color: var(--white-color); font-family: "Lato", "Helvetica Neue", Arial, sans-serif; line-height: 1.5; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; } /* Links */ a { color: #1DA2BD; text-decoration: none; } a:hover, a:focus { text-decoration: underline; } #content a[href^='../dsl/'], #content a[href^='../kotlin-dsl/'], #content a[href^='../javadoc/'] { font-family: 'Inconsolata', monospace; font-style: normal; border-bottom: 1px dotted rgba(29, 162, 189, 0.5); padding: 0 1px; } #content a[href^='../dsl/']:hover, #content a[href^='../dsl/']:focus, #content a[href^='../kotlin-dsl/']:hover, #content a[href^='../kotlin-dsl/']:focus, #content a[href^='../javadoc/']:hover, #content a[href^='../javadoc/']:focus { text-decoration: none; } /* Copy */ p { font-size: 1rem; } pre, pre>code, code { font-family: 'Inconsolata', monospace; } h1, h2, h3, h4, h5, h6, #toctitle, .sidebarblock>.content>.title { font-family: inherit; font-weight: 500; color: inherit; } h1 { font-size: 2rem; } h2 { font-size: 1.5rem; } h3 { font-size: 1.125rem; } h4 { font-size: 1.0625rem; } h5, h6 { font-size: 1rem; } b, strong { font-weight: 500; } dl { margin: 0 0 1.25rem 1.5rem; } .dlist dt code { color: var(--text-color); font-size: 1em; font-weight: bold; } .dlist p { margin-bottom: 0.625rem; } .sr-only { border: 0; clip: rect(0, 0, 0, 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; } /* Layout */ .main-content>.appendix, .main-content>.book, .main-content>.chapter, .main-content>.footer { background-color: var(--white-color); border-radius: 5px; max-width: 45rem; padding: 1.5rem; } @media screen and (max-width: 45em) { .footer { max-width: 100%; } .main-content>.appendix, .main-content>.book, .main-content>.chapter { margin-top: 0; margin-bottom: 0; } } /* Override asciidoc styles */ #header { position: static; } #header, #content { padding: 0; } #header .details { /* TODO: Pretty sure there's a way to avoid Asciidoc generating details */ display: none; } p { color: var(--text-color); } h1, h2, p, p strong, td.content, td.content strong, div.footnote strong, span.alt { letter-spacing: normal; } .subheader, .admonitionblock td.content>.title, .audioblock>.title, .exampleblock>.title, .imageblock>.title, .listingblock>.title, .literalblock>.title, .stemblock>.title, .openblock>.title, .paragraph>.title, .quoteblock>.title, table.tableblock>.title, .verseblock>.title, .videoblock>.title, .dlist>.title, .olist>.title, .ulist>.title, .qlist>.title, .hdlist>.title { color: inherit; font-family: inherit; } .listingblock .title, .listingblock .title code { font-style: normal; font-weight: bold; } .imageblock, .videoblock { padding: 0.25em; } p.lead, .paragraph.lead>p, #preamble>.sectionbody>.paragraph:first-of-type p { font-size: 1.0625rem; } .paragraph.lead>p, #preamble>.sectionbody>.paragraph:first-of-type p { color: inherit; } .sect1 { padding-bottom: 0; } .sect1+.sect1 { border: 0 none; } .verseblock pre { font-family: "Lato", Arial, sans-serif; } td.hdlist1 { padding-bottom: 0.625rem; } td.hdlist2 p { margin-bottom: 0.625rem; } body.book #header>h1 { border: 0; } #header>h1:first-child { margin-top: 0; } #content a.link { color: var(--title-color); } .highlight .com { color: #777; } .listingblock pre.highlightjs>code { overflow-x: auto; } .listingblock pre.highlight { overflow-x: auto; } .listingblock pre.highlight>code { white-space: pre; } .conum[data-value] { font-family: "Lato", Arial, sans-serif; } .colist>table tr>td:first-of-type { padding-top: 0.25em; padding-bottom: 0.25em; line-height: 1.4; vertical-align: baseline; } /* * Samples */ .exampleblock>.content { background-color: inherit; border: 0 none; box-shadow: none; padding: 0; padding-bottom: 0.7rem; margin-bottom: 0; } .exampleblock>.content .title { background-color: var(--code-color); border-top: 1px solid #ccc; font-family: 'Inconsolata', monospace; margin: 0; padding: 1em 1em 0; } .exampleblock>.title>a { text-decoration: none; color: var(--num-color); } .exampleblock .listingblock { margin: 0; } /* * Ensure that blocks of code do not wrap by applying the behavior of `[listing%nowrap]` by default. * * These styles are copied from a CSS ruleset in asciidoctor.css that has the same group of * selectors except that they end with `.nowrap`. */ .openblock .content { background: var(--admonition-background); margin-bottom: 1.25em; padding: 1em 1em 0em 1em; border-radius: 4px; overflow: auto !important; } .literalblock pre, .literalblock pre[class], .listingblock pre, .listingblock pre[class] { overflow-x: auto; white-space: pre; word-wrap: normal; } /* * This CSS ruleset solves: https://github.com/gradle/guides/issues/113#issuecomment-314826749. */ .literalblock pre::after, .literalblock pre[class]::after, .listingblock pre::after, .listingblock pre[class]::after { content: ""; } .quoteblock blockquote, .quoteblock blockquote p { text-align: left; text-align: start; } div.screenshot { box-shadow: 0 0 20px 1px rgba(0, 0, 0, 0.2); margin-left: auto; margin-right: auto; width: 90%; } .inset { box-shadow: 0 0 1px 1px rgba(0, 0, 0, 0.1); padding: 1em; } .image.inline-icon img { vertical-align: sub; } /* TOC */ #header>h1:first-child+#toc { background: none; border: 0 none; margin-top: 0; } #toc, #content #toc { border: 0 none; } #toc>ul { margin-left: 0; font-family: inherit; } #toc>ul>li { line-height: 1.25; margin-top: 0; padding-bottom: 0.5rem; } #toc>ul>li:last-of-type { padding-bottom: 0; } #toc a { font-style: normal; } #toc a:hover, #toc a:focus, #toc a:hover code, #toc a:focus code { color: #1DA2BD; } #toc a:active { text-decoration: none; } /* Site header specific styles */ .hamburger { background-color: transparent; background-image: none; border: none; border-radius: 4px; cursor: pointer; margin-left: auto; padding: 11px 10px; } .hamburger:focus { outline: 0; } .hamburger__bar { display: block; width: 22px; height: 2px; background-color: var(--black-color); border-radius: 1px; } .hamburger__bar+.hamburger__bar { margin-top: 4px; } .site-header { background-color: var(--top-header-color); } /* Override javadoc styles */ .site-header div { font-family: 'Lato', Arial, sans-serif; } .site-header__navigation-header a { align-self: center; border-bottom: 0 none; height: 36px; } .site-header .site-header-version { align-self: center; color: #1da2bd; font-size: 20px; padding-left: 1px; margin-top: 22px; } .site-header__navigation { z-index: 2; display: flex; flex-direction: column; } .site-header__navigation-header { display: flex; flex: 0 0 auto; margin-left: 12px; } .site-header__navigation-collapsible { flex: 1 1 auto; height: 210px; overflow: visible; transition: height 0.3s ease; } .site-header__navigation-items { display: flex; flex-direction: column; flex-wrap: wrap; align-items: flex-start; max-height: 210px; /* This matches the collapsible height above */ margin: 0 20px; padding-top: 12px; padding-left: 0; list-style-type: none; } .site-header__navigation-item { flex: 0 1 auto; font-size: 16px; width: 250px; } .site-header__navigation-item .site-header__navigation-link { position: relative; display: inline-block; cursor: pointer; width: 100%; padding: 5px; line-height: 20px; border: 0 none; color: var(--text-color); text-decoration: none; transition: none; -o-transition: none; -moz-transition: none; -webkit-transition: none; } .site-header__navigation-item .site-header__navigation-link:hover { color: #1DA2BD; } .site-header__navigation-item .site-header__navigation-link.active { font-weight: 500; } /* Navigation submenu styles */ .site-header__navigation-submenu-section { position: relative; } .site-header__navigation-submenu-section .site-header__down-arrow { width: 8px; height: 8px; margin-left: 2px; margin-top: 0; } .site-header__navigation-submenu-section .site-header__navigation-link:hover path { fill: none; } .site-header__navigation-submenu-section .site-header__navigation-submenu .site-header__navigation-submenu-item-link:hover { color: #1DA2BD; } .site-header__navigation-submenu-section .site-header__navigation-submenu { display: none; width: 170px; background-color: var(--menu-burger-color); top: 40px; left: 7px; /* NOTE: This must match the padding of .site-header__navigation-link */ padding: 3px 10px 6px 10px; z-index: 100; } .site-header__navigation-submenu-section .site-header__navigation-submenu .site-header__navigation-submenu-item-link { width: 100%; color: var(--text-color); white-space: nowrap; display: inline-block; padding-top: 3px; border: 0 none; transition: none; -o-transition: none; -moz-transition: none; -webkit-transition: none; } .site-header__navigation-submenu-section .site-header__navigation-submenu .site-header__navigation-submenu-item-link .site-header__navigation-submenu-item-link-text { display: inline-block; font-size: 16px; } .site-header__navigation-submenu-section.open .site-header__navigation-submenu { display: block; } /* Top navigation mobile styles */ @media (max-width: 1023px) { .site-header__navigation-collapsible--collapse { height: 0; overflow-y: hidden; } .site-header__navigation-submenu-section .site-header__navigation-submenu { padding: 0 1rem 0.5rem 1.5rem; display: block; top: 30px !important; left: 0 !important; } .site-header__navigation-item, .site-header__navigation-submenu-section .site-header__navigation-submenu .site-header__navigation-submenu-item-link .site-header__navigation-submenu-item-link-text { font-size: 18px; } .site-header { padding: 5px 12px; } .site-header-version { display: none; } .site-footer__navigation { flex-direction: column; } .site-footer__links { flex-wrap: wrap; } .site-footer__link-group { margin-bottom: 1rem; } } /* Top navigation desktop styles */ @media (min-width: 1024px) { .site-header { -webkit-box-shadow: 0 2px 4px 0 var(--box-shadow-color); -moz-box-shadow: 0 2px 4px 0 var(--box-shadow-color); box-shadow: 0 2px 4px 0 var(--box-shadow-color); z-index: 2; } body.dark-theme { .site-header { -webkit-box-shadow: none; -moz-box-shadow: none; box-shadow: none; z-index: 2; } } @media (prefers-color-scheme: dark) { .site-header { -webkit-box-shadow: none; -moz-box-shadow: none; box-shadow: none; z-index: 2; } body.light-theme { .site-header { -webkit-box-shadow: 0 2px 4px 0 var(--box-shadow-color); -moz-box-shadow: 0 2px 4px 0 var(--box-shadow-color); box-shadow: 0 2px 4px 0 var(--box-shadow-color); z-index: 2; } } } /* Pushes the section headings to just below the top nav bar when a user navigates directly to section anchors. */ #content h2[id], #content h3[id], #content h4[id], #content h5[id] { padding-top: 60px; } #content h2[id] { /* Little extra room above h2s */ margin-top: -1em; } #content h3[id], #content h4[id], #content h5[id] { margin-top: -60px; } .site-header__navigation { flex-direction: row; } .site-header__navigation-button { display: none; } .site-header__navigation-items { flex-direction: row; align-items: center; float: right; width: auto; padding-top: 0; } .site-header__navigation-item { width: auto; } .site-header__navigation-item .site-header__navigation-link { padding: 15px 18px; } .site-header__navigation-item:last-of-type .site-header__navigation-link { padding-right: 0; } .site-header__navigation-link--button { padding: 6px 12px; } .site-header__navigation-collapsible { height: auto; } .site-header__navigation-submenu-section .site-header__navigation-submenu { position: absolute; border: 1px solid #9a9a9a; border-radius: 3px; } .site-header__navigation-submenu-section:hover .site-header__navigation-submenu { display: block; } /* Pushes the section headings to just below the top nav bar when a user navigates directly to section anchors. It doesn't work if you try to apply the padding and margin to the `h` elements directly. */ .chapter a[name], .chapter .anchor { padding-top: 60px; margin-top: -60px; text-decoration: none; border: none; display: inline-block; } } /* Side Navigation styles */ /* Docs Navigation */ .docs-navigation { border-right: 1px solid var(--various-border-color); } .docs-navigation .search-container { display: none; margin-bottom: 1rem; } .docs-navigation a { color: var(--text-color); display: block; font-size: .95rem; position: relative; } .docs-navigation a:focus { outline: none; } .docs-navigation a:hover { color: #35c1e4; text-decoration: none; } .docs-navigation a code { color: var(--text-color); overflow-wrap: break-word; padding: 0; word-break: break-all; } .docs-navigation a.active { color: #06A0CE; outline: 0; border: none; -moz-outline-style: none; } .docs-navigation a.active:hover { color: #35c1e4; text-decoration: underline; } .docs-navigation ul { list-style-type: none; margin: 0; padding: 0; } .docs-navigation li>ul>li a { font-size: 14px; color: #7d7d7d; } .docs-navigation ul:last-of-type { margin-bottom: 0; } .docs-navigation li { margin-top: 0.3334em; line-height: 1.3334; } .docs-navigation li:last-of-type { margin-bottom: 0; } .docs-navigation .nav-dropdown:before { content: '\2023'; font-size: 28px; position: absolute; margin-left: -14px; margin-top: -8px; } .docs-navigation .nav-dropdown.expanded:before { transform: rotate(90deg); } .docs-navigation>ul ul, .docs-navigation>ul ul ul { display: none; height: 0; margin-left: 1rem; } .docs-navigation>ul ul:target, .docs-navigation>ul ul:target ul, .docs-navigation>ul .nav-dropdown.expanded~ul { display: block; height: auto; } .docs-navigation h3 { font-size: .95rem; font-weight: 600; line-height: 1.5; margin: 1.5em 0 0; } .docs-navigation .docs-home-link { position: relative; } @media screen and (min-width: 45rem) { .main-content { display: flex; } } /* User guide navigation appears for desktops */ @media screen and (min-width: 64rem) { .docs-navigation { flex: 0 0 auto; width: 13.75rem; } .main-content>.appendix, .main-content>.book, .main-content>.chapter { flex: 0 0 auto; margin: 0 auto; } } /** * For mobile devices, we show navigation at bottom of page. * * This is the simplest solution to this issue. */ @media not screen and (min-width: 64rem) { /* Repeat the class twice to prioritize our mobile classes! */ .content.content { /* Make the height equal to the real height of content */ overflow: visible; } .main-content { /* Main content show first */ flex-direction: column-reverse; } .docs-navigation.docs-navigation { /* Fill the main container */ width: 100%; /* Don't clip the navigation container */ overflow: visible; } } /* Userguide Meta */ .chapter-meta { float: right; text-align: right; } .chapter-meta .edit-link { color: #999; font-size: 0.9em; padding-right: 3px; } .chapter-meta .edit-link svg { margin-right: 1px; } /* Clever use of RTL to fill in all stars to left of hover position */ .rating { direction: rtl; } .rating>.star { cursor: pointer; display: table-cell; padding: 3px; } .rating>.star:hover>svg>g, .rating>.star:hover~.star>svg>g, .rating>.star.selected>svg>g, .rating>.star.selected~.star>svg>g { fill: #999; } /* Footer styles */ .site-footer {} .site-footer__navigation { display: flex; padding: 30px 12px; max-width: 62.5rem; margin: 0 auto; padding-left: 5rem; } @media not screen and (min-width: 64rem) { .site-footer__navigation { /* same to nav.docs-navigation for mobiles */ padding: 20px 20px 20px 26px; } } .site-footer__links { display: flex; flex: 1 1 auto; } .site-footer__links .site-footer__links-list { list-style-type: none; margin: 0; } .site-footer__links .site-footer__links-list a { color: var(--footer-other-text-color); } .site-footer__link-group { flex: 1 1 auto; flex-basis: 175px; } .site-footer__link-group header { color: var(--text-color); } .site-footer__subscribe-newsletter .newsletter-form__header h5 { color: var(--text-color); margin-top: 0; } .site-footer__subscribe-newsletter p { font-size: 0.875rem; margin: 2px 0 0 2px; opacity: 0.7; } .site-footer__subscribe-newsletter .disclaimer { color: var(--footer-other-text-color); font-size: 0.75rem; opacity: 0.55; } .site-footer__subscribe-newsletter .newsletter-form { padding-top: 6px; display: flex; justify-content: flex-start; } .site-footer__subscribe-newsletter .email, .site-footer__subscribe-newsletter .submit { height: 40px; } .site-footer__subscribe-newsletter .email { line-height: 40px; width: 250px; color: #1DA2BD; font-size: 16px; padding-left: 20px; border-top-left-radius: 4px; border-bottom-left-radius: 4px; border: 1px solid var(--footer-form-color); } .site-footer__subscribe-newsletter .submit { font-family: inherit; font-size: inherit; line-height: inherit; width: 100px; background-color: #1BA8CB; color: #fff; font-weight: 500; border-top-right-radius: 4px; border-bottom-right-radius: 4px; border-style: none; cursor: pointer; transition: all .3s ease; } /* Secondary footer (below) */ .site-footer-secondary { background-color: var(--footer-white-color); border-top: 1px solid var(--various-border-color); width: 100%; z-index: 1; } body.dark-theme { .site-footer-secondary { background-color: var(--footer-white-color); border-top: none; width: 100%; z-index: 1; } } @media (prefers-color-scheme: dark) { .site-footer-secondary { background-color: var(--footer-white-color); border-top: none; width: 100%; z-index: 1; } body.light-theme { .site-footer-secondary { background-color: var(--footer-white-color); border-top: 1px solid var(--various-border-color); width: 100%; z-index: 1; } } } .site-footer-secondary__contents { display: flex; align-items: center; justify-content: space-between; max-width: 75rem; margin-left: auto; margin-right: auto; font-size: 0.875rem; padding: 0.5rem 0.75rem; } /* * 1. Value is the largest computed width among 'site-footer__copy' and 'site-footer__links'. */ .site-footer__copy, .site-footer__secondary-links { flex-grow: 0; flex-basis: 280px; /* 1. */ } /* * 1. 'flex-shrink: 1' is applied to the element with the smallest computed width among * 'site-footer__copy' and 'site-footer__links'. */ .site-footer__copy { flex-shrink: 1; /* 1. */ } .site-footer__logo { flex: 0 0 auto; margin-right: 10px; margin-left: 10px; } .site-footer__logo svg { width: 35px; height: 35px; } /* * 1. 'flex-shrink: 0' is applied to the element with the largest computed width among * 'site-footer__copy' and 'site-footer__links'. */ .site-footer__secondary-links { flex-shrink: 0; /* 1 */ text-align: right; white-space: nowrap; } .site-footer-secondary a { color: #999; } .site-footer-secondary__links a:not(:last-child) { padding-right: 10px; } .site-footer-secondary__links a:not(:first-child) { padding-left: 10px; } @media all and (max-width: 29.99rem) { .site-footer__rights, .site-footer-secondary__links { display: none; } .site-footer__logo { order: 1; text-align: left; } .site-footer__copy { order: 2; text-align: right; } } /* Avoid the footer taking up much of the screen on short displays */ @media all and (max-height: 56.25rem) { .site-footer__navigation { margin: 1.5rem auto 0 auto; padding-top: 0; padding-bottom: 0; } } @media screen and (min-width: 84.375rem) { .ui-logos .ui-logo { box-shadow: 0 6px 15px 1px rgba(0, 0, 0, 0.56); } } /* User Manual Home */ .technology-logos, .ui-logos { display: flex; flex-direction: row; flex-wrap: wrap; justify-content: space-around; } .technology-logo, .ui-logo { flex: 0 1 auto; } .ui-logo { width: 224px; height: 135px; margin: 12px; } /* Samples download button */ .download { display: flex; } .download a { border-style: solid; border-width: 1px; text-decoration: none; padding: 5px; display: block; width: 10em; margin: 5px; } .download ul { list-style: none; list-style-type: none; } .download li { float: right; } .docs-navigation { width: 18rem; padding: 20px 20px 20px 26px; background: var(--nav-color); overflow-y: scroll; overflow-x: auto; } .layout { display: flex; flex-direction: column; overflow: hidden; height: 100vh; } .main-content { overflow-y: auto; overflow-x: auto; display: flex; } .content { flex: 1 1 auto; overflow: auto; padding-left: 0; padding-right: 0; } .content .chapter { padding: 2rem 2.4rem; } #toc a:active { font-weight: 500; } .site-header { margin-bottom: 1rem; } .site-header__navigation-submenu-item { padding: 2px 0; } .site-footer { background-color: var(--footer-color); padding: 20px 0 40px 0; border-top: 1px solid var(--various-border-color); } #header { margin-left: 0; } #header>h1:first-child { margin-bottom: 40px; } @media screen and (min-width: 64rem) { #header { margin-bottom: 20px; } .site-header { margin-bottom: 0; z-index: 2; } .site-header__navigation-header { margin-top: -7px; } .site-header__navigation-submenu-section:after { content: '\2023'; font-size: 28px; position: absolute; transform: rotate(90deg); margin-right: 10px; top: 5px; right: -7px; } .site-footer__navigation { flex-wrap: wrap; } .site-footer__link-group { flex: 1 1 auto; } .site-footer__links { margin-bottom: 1rem; } } @media screen and (min-width: 75rem) { .content .chapter { box-sizing: content-box; } #content { padding-right: 260px; margin: 0; } /* #toc here must be referenced as #header #toc since we don't want to change single page #toc */ #header #toc { position: fixed; margin: 0 auto; padding-bottom: 0; right: 0; top: 65px; width: 260px; z-index: 1; overflow: auto; border-radius: 0 0 5px 0; max-height: calc(100% - 118px); margin-right: 15px; } #header #toctitle { margin-top: 1.3em; } #header #toc>ul { /* margin-left have to increase if you change border thickness of active toc item */ margin-left: 1px; border-left: 1px solid #666; margin-bottom: 0; padding-right: 10px; padding-bottom: 0.5rem; background-color: var(--white-color); } #header #toc>ul>li, #toc>ul>li:last-of-type { padding: 0.5rem 0; margin: 0; } #header #toc a { padding-left: 10px; font-weight: 400; color: var(--text-color); font-size: .95rem; display: inline-block; } #header #toc a.active { font-weight: 500; border-left: 3px solid #01303a; margin-left: -2px; padding-left: 9px; } .site-footer__navigation { flex-wrap: wrap; margin-left: auto; padding-left: 3rem; } .site-footer__link-group { flex: 0.15 1 auto; } .site-footer__subscribe-newsletter { /* A fix so subscribe disclaimer does not go under long ToC */ max-width: calc(100% - 17rem); } } @media screen and (min-width: 80rem) { .site-footer__subscribe-newsletter { max-height: none; } } @media screen and (min-width: 100rem) { .content .chapter { max-width: 60.5rem; } #header { margin: 0 auto; } #content { padding-right: 0; margin: 0 auto; } #header #toc { right: initial; margin-left: 62.5rem; } .site-footer__navigation { padding-left: 0; } .site-footer__link-group { flex: 0.2 1 auto; } } @media screen and (min-width: 112rem) { .content .chapter { max-width: 62.5rem; margin: 0 auto; padding-right: 3.5rem; position: relative; left: -130px; } #header #toc { right: initial; margin-left: 64.5rem; } .site-footer__link-group { flex: 0.2 1 auto; } } @supports (-moz-appearance:meterbar) and (background-blend-mode:difference, normal) { /* Firefox only */ .site-header__navigation-submenu-section:after { top: 2px; right: -4px; } } /* Added dark mode and other items for outdated Prettify.css */ code[data-lang="text"] .pln, code[data-lang="text"] .str, code[data-lang="text"] .kwd, code[data-lang="text"] .com, code[data-lang="text"] .typ, code[data-lang="text"] .lit, code[data-lang="text"] .pun, code[data-lang="text"] .opn, code[data-lang="text"] .clo, code[data-lang="text"] .tag, code[data-lang="text"] .atn, code[data-lang="text"] .atv, code[data-lang="text"] .dec, code[data-lang="text"] .var, code[data-lang="text"] .fun { color: #000; } body.dark-theme { code[data-lang="text"] .pln, code[data-lang="text"] .str, code[data-lang="text"] .kwd, code[data-lang="text"] .com, code[data-lang="text"] .typ, code[data-lang="text"] .lit, code[data-lang="text"] .pun, code[data-lang="text"] .opn, code[data-lang="text"] .clo, code[data-lang="text"] .tag, code[data-lang="text"] .atn, code[data-lang="text"] .atv, code[data-lang="text"] .dec, code[data-lang="text"] .var, code[data-lang="text"] .fun { color: #fff !important; } .com { color: #909090 !important; } .str, .tag { color: #90a959 !important; } .kwd, .atv { color: #d28445 !important; } .typ { color: #f4bf75 !important; } .lit, .atn { color: #6a9fb5 !important; } .pun, .pln, .opn, .clo { color: #d0d0d0 !important; } .dec, .var { color: #aa759f !important; } li.L1, li.L3, li.L5, li.L7, li.L9 { background: #111 !important; } } @media (prefers-color-scheme: dark) { code[data-lang="text"] .pln, code[data-lang="text"] .str, code[data-lang="text"] .kwd, code[data-lang="text"] .com, code[data-lang="text"] .typ, code[data-lang="text"] .lit, code[data-lang="text"] .pun, code[data-lang="text"] .opn, code[data-lang="text"] .clo, code[data-lang="text"] .tag, code[data-lang="text"] .atn, code[data-lang="text"] .atv, code[data-lang="text"] .dec, code[data-lang="text"] .var, code[data-lang="text"] .fun { color: #fff !important; } .com { color: #909090 !important; } .str, .tag { color: #90a959 !important; } .kwd, .atv { color: #d28445 !important; } .typ { color: #f4bf75 !important; } .lit, .atn { color: #6a9fb5 !important; } .pun, .pln, .opn, .clo { color: #d0d0d0 !important; } .dec, .var { color: #aa759f !important; } li.L1, li.L3, li.L5, li.L7, li.L9 { background: #111 !important; } body.light-theme { code[data-lang="text"] .pln, code[data-lang="text"] .str, code[data-lang="text"] .kwd, code[data-lang="text"] .com, code[data-lang="text"] .typ, code[data-lang="text"] .lit, code[data-lang="text"] .pun, code[data-lang="text"] .opn, code[data-lang="text"] .clo, code[data-lang="text"] .tag, code[data-lang="text"] .atn, code[data-lang="text"] .atv, code[data-lang="text"] .dec, code[data-lang="text"] .var, code[data-lang="text"] .fun { color: #000; } .pln { color: #000 !important;; } .com { color: #800 !important;; } .str, .tag { color: #080 !important;; } .kwd, .atv { color: #008 !important;; } .typ { color: #606 !important;; } .lit, .atn { color: #066 !important;; } .pun, .opn, .clo { color: #660 !important;; } .dec, .var { color: #606 !important;; } li.L1, li.L3, li.L5, li.L7, li.L9 { background: #eee; } } } /* DPE University button*/ /* CSS */ .badge-wrapper { padding-top: 0px; padding-bottom: 20px; a { text-decoration: none; } a:link { text-decoration: none; } a:visited { text-decoration: none; } a:hover { text-decoration: none; } a:active { text-decoration: none; } } .badge { background-color: var(--black-color); height: 24px; border-radius: 12px; border-color: var(--black-color); border-style: solid; border-width: 1px; padding: 5px; a { color: var(--gradle-blue); } } .badge-type { border-radius: 8px; margin-right: 10px; padding-left: 10px; padding-right: 10px; } .badge-text { color: var(--white-color); } .button--blue { color: white; border-color: transparent; &:hover { color: white; } } .button--blue { background: var(--gradle-blue); background: linear-gradient(var(--button-gradient-angle), var(--gradle-blue) 0%, var(--gradle-blue-lite) 100%); &:hover { background: var(--gradle-blue-lite); } } /* Custom Download button*/ /* CSS */ .button-9 { appearance: button; backface-visibility: hidden; background-color: #209BC4; border-radius: 6px; border-width: 0; box-shadow: rgba(50, 50, 93, .1) 0 0 0 1px inset, rgba(50, 50, 93, .1) 0 2px 5px 0, rgba(0, 0, 0, .07) 0 1px 1px 0; box-sizing: border-box; color: #fff; cursor: pointer; font-family: -apple-system, system-ui, "Segoe UI", Roboto, "Helvetica Neue", Ubuntu, sans-serif; font-size: 100%; height: 44px; line-height: 1.15; margin: 12px 12px 12px 0px; outline: none; overflow: hidden; padding: 0 25px; position: relative; text-align: center; text-transform: none; transform: translateZ(0); transition: all .2s, box-shadow .08s ease-in; user-select: none; -webkit-user-select: none; touch-action: manipulation; width: 25%; } .button-9:disabled { cursor: default; } .button-9:focus { box-shadow: rgba(50, 50, 93, .1) 0 0 0 1px inset, rgba(50, 50, 93, .2) 0 6px 15px 0, rgba(0, 0, 0, .1) 0 2px 2px 0, rgba(50, 151, 211, .3) 0 0 0 4px; } .button-9-sect { padding-bottom: 1.25em; } /* Theme toggle switch button */ /* Switch */ .switch { position: relative; display: inline-block; width: 60px; height: 34px; align-self: center; } .switch input { opacity: 0; width: 0; height: 0; } .slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: #ccc; -webkit-transition: 0.4s; transition: 0.4s; } .slider:before { position: absolute; content: ""; height: 26px; width: 26px; left: 4px; bottom: 4px; background-color: white; -webkit-transition: 0.4s; transition: 0.4s; } input:checked+.slider { background-color: #2196f3; } input:checked+.slider:before { -webkit-transform: translateX(26px); -ms-transform: translateX(26px); transform: translateX(26px); } /* Rounded sliders */ .slider { border-radius: 30px; } .slider:before { border-radius: 50%; } </style> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css"> <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/prettify/r298/prettify.min.css"> <meta name="adoc-src-path" content="releases/upgrading/upgrading_version_5.adoc"> <link crossorigin href="//assets.gradle.com" rel="preconnect"> <link href="https://fonts.googleapis.com/css?family=Inconsolata:400,700" rel="stylesheet"/> <style type="text/css">.multi-language-selector .language-option[data-lang='groovy'], .exampleblock[data-lang=groovy] > .content .title { background-image: url(''); background-position: 16px 80%; background-repeat: no-repeat; background-size: 20px 12px; padding-left: 2.5em; } .multi-language-selector .language-option[data-lang='kotlin'], .exampleblock[data-lang=kotlin] > .content .title { background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 8 8' xmlns='http://www.w3.org/2000/svg'><linearGradient id='g' gradientUnits='userSpaceOnUse' x1='8' y1='0' x2='0' y2='8'><stop offset='0' stop-color='%23e44857'/><stop offset='.4689' stop-color='%23c711e1'/><stop offset='1' stop-color='%237f52ff'/></linearGradient><polygon fill='url(%23g)' points='8 8 0 8 0 0 8 0 4 4'/></svg>"); background-position: 17px 80%; background-repeat: no-repeat; background-size: 11px 11px; padding-left: 2.3em; } .multi-language-selector { display: block; } .multi-language-selector .language-option[data-lang='groovy'] { background-position: 20px center; padding-left: 32px; } .multi-language-selector .language-option[data-lang='kotlin'] { background-position: 30px center; padding-left: 27px; } .multi-language-selector .language-option { background-color: white; border: 1px solid #f7f7f8; border-radius: 4px 4px 0 0; cursor: pointer; display: inline-block; font-weight: normal; font-family: 'Lato', Arial, sans-serif; margin: 0; padding: 4px 20px; min-width: 130px; max-width: 320px; text-align: center; filter: grayscale(1); -webkit-filter: grayscale(1); opacity: 0.7; } .multi-language-selector .language-option.selected { background-color: #f7f7f8; color: #02303a; filter: none; -webkit-filter: none; opacity: 1; } .multi-language-text.hidden, .multi-language-selector ~ .multi-language-sample.hidden { display: none; } .multi-language-sample { border-radius: 0 0 4px 4px; } body.dark-theme { .multi-language-selector .language-option { background-color: #1f1f1f; border: 1px solid #1e1e22; } .multi-language-selector .language-option.selected { background-color: #2c2c2c; color: white; } } @media (prefers-color-scheme: dark) { .multi-language-selector .language-option { background-color: #1f1f1f; border: 1px solid #1e1e22; } .multi-language-selector .language-option.selected { background-color: #2c2c2c; color: white; } body.light-theme { .multi-language-selector .language-option { background-color: #white; border: 1px solid #f7f7f8; } .multi-language-selector .language-option.selected { background-color: #f7f7f8; color: #02303a; } } } </style><script type="text/javascript">function postProcessCodeBlocks() { // Assumptions: // 1) All siblings that are marked with class="multi-language-sample" should be grouped // 2) Only one language can be selected per domain (to allow selection to persist across all docs pages) // 3) There is exactly 1 small set of languages to choose from. This does not allow for multiple language preferences. For example, users cannot prefer both Kotlin and ZSH. // 4) Only 1 sample of each language can exist in the same collection. var GRADLE_DSLs = ["kotlin", "groovy"]; var preferredBuildScriptLanguage = initPreferredBuildScriptLanguage(); // Ensure preferred DSL is valid, defaulting to Kotlin DSL function initPreferredBuildScriptLanguage() { var lang = window.localStorage.getItem("preferred-gradle-dsl"); if (GRADLE_DSLs.indexOf(lang) === -1) { window.localStorage.setItem("preferred-gradle-dsl", "kotlin"); lang = "kotlin"; } return lang; } function capitalizeFirstLetter(string) { return string.charAt(0).toUpperCase() + string.slice(1); } function processSampleEl(sampleEl, prefLangId) { var codeEl = sampleEl.querySelector("code[data-lang]"); if (codeEl != null) { sampleEl.setAttribute("data-lang", codeEl.getAttribute("data-lang")); if (codeEl.getAttribute("data-lang") !== prefLangId) { sampleEl.classList.add("hidden"); } else { sampleEl.classList.remove("hidden"); } } } function switchSampleLanguage(languageId) { var multiLanguageSampleElements = [].slice.call( document.querySelectorAll(".multi-language-sample") ); // Array of Arrays, each top-level array representing a single collection of samples var multiLanguageSets = []; for (var i = 0; i < multiLanguageSampleElements.length; i++) { var currentCollection = [multiLanguageSampleElements[i]]; var currentSampleElement = multiLanguageSampleElements[i]; processSampleEl(currentSampleElement, languageId); while ( currentSampleElement.nextElementSibling != null && currentSampleElement.nextElementSibling.classList.contains( "multi-language-sample" ) ) { currentCollection.push(currentSampleElement.nextElementSibling); currentSampleElement = currentSampleElement.nextElementSibling; processSampleEl(currentSampleElement, languageId); i++; } multiLanguageSets.push(currentCollection); } multiLanguageSets.forEach(function (sampleCollection) { // Create selector element if not existing if ( sampleCollection.length > 1 && (sampleCollection[0].previousElementSibling == null || !sampleCollection[0].previousElementSibling.classList.contains( "multi-language-selector" )) ) { var languageSelectorFragment = document.createDocumentFragment(); var multiLanguageSelectorElement = document.createElement("div"); multiLanguageSelectorElement.classList.add("multi-language-selector"); languageSelectorFragment.appendChild(multiLanguageSelectorElement); sampleCollection.forEach(function (sampleEl) { var optionEl = document.createElement("code"); var sampleLanguage = sampleEl.getAttribute("data-lang"); optionEl.setAttribute("data-lang", sampleLanguage); optionEl.setAttribute("role", "button"); optionEl.classList.add("language-option"); optionEl.innerText = capitalizeFirstLetter(sampleLanguage); optionEl.addEventListener( "click", function updatePreferredLanguage(evt) { var preferredLanguageId = optionEl.getAttribute("data-lang"); window.localStorage.setItem( "preferred-gradle-dsl", preferredLanguageId ); // Record how far down the page the clicked element is before switching all samples var beforeOffset = evt.target.offsetTop; switchSampleLanguage(preferredLanguageId); // Scroll the window to account for content height differences between different sample languages window.scrollBy(0, evt.target.offsetTop - beforeOffset); } ); multiLanguageSelectorElement.appendChild(optionEl); }); sampleCollection[0].parentNode.insertBefore( languageSelectorFragment, sampleCollection[0] ); } }); [].slice .call( document.querySelectorAll(".multi-language-selector .language-option") ) .forEach(function (optionEl) { if (optionEl.getAttribute("data-lang") === languageId) { optionEl.classList.add("selected"); } else { optionEl.classList.remove("selected"); } }); [].slice .call(document.querySelectorAll(".multi-language-text")) .forEach(function (el) { if (!el.classList.contains("lang-" + languageId)) { el.classList.add("hidden"); } else { el.classList.remove("hidden"); } }); } switchSampleLanguage(preferredBuildScriptLanguage); } document.addEventListener("DOMContentLoaded", function () { postProcessCodeBlocks(); }); </script> <!-- Prefetch header and footer if on Gradle 4.4 and lower only --> <!-- Load build-tool.css if on Gradle<=4.4 or release notes --> <!-- Load build-tool.css if on Gradle<8.0 and javadoc --> <!-- Load build-tool-modern.css if on Gradle>=8.0 and javadoc --> <!-- Load decorate.css if on Gradle<=4.3 for user manual, Gradle<=4.4 for DSL Reference, or Gradle<=4.5 for Javadoc --> <style type="text/css"> cloudflare-app[app="cookiless"] cookiless-div { font-family: "Lato","Helvetica Neue",Arial,sans-serif; font-weight: 300; background-color: #02303A !important; opacity: 1 !important; } cloudflare-app[app="cookiless"] cookiless-div .iAccept { font-weight: 400; } @media (max-width: 1023px) { .notification { display: none; } } @media (min-width: 1024px) { cloudflare-app[app="cookiless"] { position: fixed !important; width: 400px !important; left: auto !important; right: 0 !important; bottom: 0 !important; } /* Overrides for banner */ .notification { height: 44px; line-height: 44px; vertical-align: middle; background-color: #02303A; text-align: center; color: white; z-index: 1; } .notification a { color: white; text-decoration: underline; } .notification ~ .main-content #header #toc, .notification ~ .main-content .toc { top: 98px; } } </style> <!-- Load common JS for all Gradle versions --> <script src="/build-tool.js" type="text/javascript" defer></script> <!-- Google Tag Manager --> <script> (function(w,d,s,l,i){w[l]=w[l]||[];w[l].push({'gtm.start': new Date().getTime(),event:'gtm.js'});var f=d.getElementsByTagName(s)[0], j=d.createElement(s),dl=l!='dataLayer'?'&l='+l:'';j.async=true;j.src= 'https://www.googletagmanager.com/gtm.js?id='+i+dl;f.parentNode.insertBefore(j,f); })(window,document,'script','dataLayer','GTM-WRTQKGT'); </script> <!-- End Google Tag Manager --> <!-- Inject new header and footer for Gradle<=4.4 or release notes--> <script type="text/javascript" defer> window.siteDecorateVersion = "8.11.1"; </script> <!-- Load DocSearch assets if on current manual, dsl, or samples --> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@algolia/autocomplete-theme-classic"> <script src="https://cdn.jsdelivr.net/npm/algoliasearch@4.23.3/dist/algoliasearch-lite.umd.js"></script> <script src="https://cdn.jsdelivr.net/npm/instantsearch.js@4.69.0/dist/instantsearch.production.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/@algolia/autocomplete-js"></script> <script src="/build-tool-search.js" type="text/javascript" defer></script> <link rel="stylesheet" href="/build-tool-search.css"> <!--Load ratings css and js if on current user manual --> <link rel="stylesheet" href="/build-tool-rating.css"> <script src="/build-tool-rating.js" type="text/javascript" defer></script> <!--Load banner css, html and js if on current user manual --> <link rel="stylesheet" href="/build-tool-banner.css"> <script src="/build-tool-banner.js" type="text/javascript" defer></script> <!-- Canonical Link and Structured Data for SEO --> <link rel="canonical" href="https://docs.gradle.org/current/userguide/upgrading_version_5.html" /> <script type="application/ld+json"> { "@context": "http://schema.org", "@type": "WebPage", "name": "Gradle Documentation", "url": "https://docs.gradle.org/current/userguide/upgrading_version_5.html" } </script> <meta name="google-site-verification" content="kCnBfMu0lbnMpfg3t1-ZgJHbSOSYRSquWsxQ4HgqLkA" /></head> <body id="upgrading_version_5" class="book"><!-- Google Tag Manager (noscript) --> <noscript><iframe src="https://www.googletagmanager.com/ns.html?id=GTM-WRTQKGT" height="0" width="0" style="display:none;visibility:hidden"></iframe></noscript> <!-- End Google Tag Manager (noscript) --> <div class="layout"> <header class="site-layout__header site-header" itemscope="itemscope" itemtype="https://schema.org/WPHeader"> <nav class="site-header__navigation" itemscope="itemscope" itemtype="https://schema.org/SiteNavigationElement"> <div class="site-header__navigation-header"> <a target="_top" class="logo" href="https://docs.gradle.org" title="Gradle Docs"> <svg width="139px" height="43px" viewBox="0 0 278 86" version="1.1" xmlns="http://www.w3.org/2000/svg"> <title>Gradle</title> <path class="cls-1" d="M155,56.32V70.27a18.32,18.32,0,0,1-5.59,2.83,21.82,21.82,0,0,1-6.36.89,21.08,21.08,0,0,1-7.64-1.31A17.12,17.12,0,0,1,129.59,69a16.14,16.14,0,0,1-3.73-5.58,18.78,18.78,0,0,1-1.31-7.08,19.58,19.58,0,0,1,1.26-7.14A15.68,15.68,0,0,1,135,40a20.39,20.39,0,0,1,7.45-1.29,22,22,0,0,1,3.92.33,20.43,20.43,0,0,1,3.39.92,15.16,15.16,0,0,1,2.85,1.42A17.3,17.3,0,0,1,155,43.25l-1.84,2.91a1.72,1.72,0,0,1-1.12.84,2,2,0,0,1-1.5-.34L149,45.75a10.49,10.49,0,0,0-1.75-.79,14.33,14.33,0,0,0-2.17-.54,15.29,15.29,0,0,0-2.78-.22,11.91,11.91,0,0,0-4.61.86,9.66,9.66,0,0,0-3.52,2.46,10.9,10.9,0,0,0-2.24,3.84,14.88,14.88,0,0,0-.79,5,15.23,15.23,0,0,0,.85,5.28,11.06,11.06,0,0,0,2.38,3.94A10.15,10.15,0,0,0,138.05,68a14.28,14.28,0,0,0,8.25.44,17.1,17.1,0,0,0,2.94-1.09V61.14h-4.35a1.3,1.3,0,0,1-1-.35,1.15,1.15,0,0,1-.35-.85V56.32Zm10.47-2.93a10.53,10.53,0,0,1,2.72-3.45,5.77,5.77,0,0,1,3.72-1.25,4.5,4.5,0,0,1,2.72.74l-.38,4.41a1.18,1.18,0,0,1-.34.61,1,1,0,0,1-.61.18,6.76,6.76,0,0,1-1.06-.12,8.22,8.22,0,0,0-1.38-.12,5,5,0,0,0-1.74.28,4.37,4.37,0,0,0-1.37.83,5.55,5.55,0,0,0-1.07,1.3,12.26,12.26,0,0,0-.87,1.74V73.61H160V49.14h3.45a1.94,1.94,0,0,1,1.27.32,1.9,1.9,0,0,1,.48,1.16Zm11.36-.84A14.49,14.49,0,0,1,187,48.69a9.92,9.92,0,0,1,3.84.7,8.06,8.06,0,0,1,2.86,2,8.38,8.38,0,0,1,1.78,3,11.64,11.64,0,0,1,.61,3.82V73.61h-2.68a2.64,2.64,0,0,1-1.28-.25,1.72,1.72,0,0,1-.72-1l-.52-1.77a20.25,20.25,0,0,1-1.82,1.47,10.86,10.86,0,0,1-1.83,1.06,10.36,10.36,0,0,1-2,.66,12,12,0,0,1-2.4.22,9.64,9.64,0,0,1-2.86-.41,6.28,6.28,0,0,1-2.27-1.26,5.6,5.6,0,0,1-1.48-2.07,7.38,7.38,0,0,1-.52-2.89,5.7,5.7,0,0,1,.31-1.85,5.3,5.3,0,0,1,1-1.75,8.25,8.25,0,0,1,1.83-1.57,11.17,11.17,0,0,1,2.75-1.29,23.28,23.28,0,0,1,3.81-.9,36.77,36.77,0,0,1,5-.41V58.16a5.35,5.35,0,0,0-1.05-3.64,3.83,3.83,0,0,0-3-1.18,7.3,7.3,0,0,0-2.38.33,9.39,9.39,0,0,0-1.65.75l-1.3.75a2.52,2.52,0,0,1-1.3.34,1.7,1.7,0,0,1-1.05-.32,2.61,2.61,0,0,1-.69-.76Zm13.5,10.61a31.66,31.66,0,0,0-4.3.45,11,11,0,0,0-2.79.82,3.57,3.57,0,0,0-1.5,1.17,2.89,2.89,0,0,0,.47,3.67,3.93,3.93,0,0,0,2.39.67,7,7,0,0,0,3.14-.66,9.52,9.52,0,0,0,2.59-2Zm32.53-25V73.61h-3.6a1.39,1.39,0,0,1-1.48-1.07l-.5-2.36a12.4,12.4,0,0,1-3.4,2.74,9.17,9.17,0,0,1-4.47,1,7.95,7.95,0,0,1-6.55-3.26A11.61,11.61,0,0,1,201,66.79a19.71,19.71,0,0,1-.66-5.34,16.77,16.77,0,0,1,.74-5.06,12.21,12.21,0,0,1,2.13-4,9.88,9.88,0,0,1,3.31-2.69,9.64,9.64,0,0,1,4.34-1,8.63,8.63,0,0,1,3.51.64,9,9,0,0,1,2.6,1.74V38.17ZM217,55.39a5.94,5.94,0,0,0-2.18-1.72,6.54,6.54,0,0,0-2.54-.5,5.68,5.68,0,0,0-2.41.5A4.87,4.87,0,0,0,208,55.19a7.19,7.19,0,0,0-1.17,2.57,14.83,14.83,0,0,0-.4,3.69,16.34,16.34,0,0,0,.34,3.63,7.14,7.14,0,0,0,1,2.44,3.79,3.79,0,0,0,1.58,1.36,5,5,0,0,0,2.07.41,6,6,0,0,0,3.13-.76A9.19,9.19,0,0,0,217,66.36Zm17.67-17.22V73.61h-5.89V38.17ZM245.1,62.11a11.37,11.37,0,0,0,.67,3.26,6.54,6.54,0,0,0,1.38,2.27,5.39,5.39,0,0,0,2,1.33,7.26,7.26,0,0,0,2.61.44,8.21,8.21,0,0,0,2.47-.33,11.51,11.51,0,0,0,1.81-.74c.52-.27,1-.52,1.36-.74a2.31,2.31,0,0,1,1.13-.33,1.21,1.21,0,0,1,1.1.55L261.36,70a9.45,9.45,0,0,1-2.19,1.92,12.18,12.18,0,0,1-2.54,1.24,14,14,0,0,1-2.7.66,18.78,18.78,0,0,1-2.65.19,12.93,12.93,0,0,1-4.75-.85,10.65,10.65,0,0,1-3.82-2.5,11.8,11.8,0,0,1-2.55-4.1,15.9,15.9,0,0,1-.93-5.67,13.55,13.55,0,0,1,.81-4.71,11.34,11.34,0,0,1,2.33-3.84,11,11,0,0,1,3.69-2.59,12.31,12.31,0,0,1,4.93-1,11.86,11.86,0,0,1,4.27.74,9.25,9.25,0,0,1,3.36,2.16,9.84,9.84,0,0,1,2.21,3.48,13,13,0,0,1,.8,4.71,3.82,3.82,0,0,1-.29,1.8,1.19,1.19,0,0,1-1.1.46Zm11.23-3.55A7.28,7.28,0,0,0,256,56.4a5.16,5.16,0,0,0-1-1.77,4.44,4.44,0,0,0-1.63-1.21,5.68,5.68,0,0,0-2.3-.44,5.46,5.46,0,0,0-4,1.45,7.13,7.13,0,0,0-1.87,4.13ZM112.26,14a13.72,13.72,0,0,0-19.08-.32,1.27,1.27,0,0,0-.41.93,1.31,1.31,0,0,0,.38.95l1.73,1.73a1.31,1.31,0,0,0,1.71.12,7.78,7.78,0,0,1,4.71-1.57,7.87,7.87,0,0,1,5.57,13.43C96,40.2,81.41,9.66,48.4,25.37a4.48,4.48,0,0,0-2,6.29l5.66,9.79a4.49,4.49,0,0,0,6.07,1.67l.14-.08-.11.08,2.51-1.41a57.72,57.72,0,0,0,7.91-5.89,1.37,1.37,0,0,1,1.8-.06h0a1.29,1.29,0,0,1,0,2A59.79,59.79,0,0,1,62.11,44l-.09.05-2.51,1.4a7,7,0,0,1-3.47.91,7.19,7.19,0,0,1-6.23-3.57l-5.36-9.24C34.17,40.81,27.93,54.8,31.28,72.5a1.31,1.31,0,0,0,1.29,1.06h6.09A1.3,1.3,0,0,0,40,72.42a8.94,8.94,0,0,1,17.73,0A1.3,1.3,0,0,0,59,73.56h5.94a1.31,1.31,0,0,0,1.3-1.14,8.93,8.93,0,0,1,17.72,0,1.3,1.3,0,0,0,1.29,1.14h5.87a1.3,1.3,0,0,0,1.3-1.28c.14-8.28,2.37-17.79,8.74-22.55C123.15,33.25,117.36,19.12,112.26,14ZM89.79,38.92l-4.2-2.11h0a2.64,2.64,0,1,1,4.2,2.12Z"/> </svg> </a> <div class="site-header__doc-type sr-only">User Manual</div> <div class="site-header-version"></div> <button type="button" aria-label="Navigation Menu" class="site-header__navigation-button hamburger"> <span class="hamburger__bar"></span> <span class="hamburger__bar"></span> <span class="hamburger__bar"></span> </button> </div> <div class="site-header__navigation-collapsible site-header__navigation-collapsible--collapse"> <ul class="site-header__navigation-items"> <li id="theme-toggle" class="site-header__navigation-item"> <a class="site-header__navigation-link theme-toggle" title="Theme"> <svg width="24" height="24" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"> <title>Theme</title> <path d="m12 22c5.5228475 0 10-4.4771525 10-10s-4.4771525-10-10-10-10 4.4771525-10 10 4.4771525 10 10 10zm0-1.5v-17c4.6944204 0 8.5 3.80557963 8.5 8.5 0 4.6944204-3.8055796 8.5-8.5 8.5z"/> </svg> </a> <script type="text/javascript"> const btn = document.querySelector(".theme-toggle"); const prefersDarkScheme = window.matchMedia("(prefers-color-scheme: dark)"); const currentTheme = localStorage.getItem("theme"); if (currentTheme == "dark") { document.body.classList.toggle("dark-theme"); } else if (currentTheme == "light") { document.body.classList.toggle("light-theme"); } btn.addEventListener("click", function () { if (prefersDarkScheme.matches) { document.body.classList.toggle("light-theme"); var theme = document.body.classList.contains("light-theme")? "light" : "dark"; } else { document.body.classList.toggle("dark-theme"); var theme = document.body.classList.contains("dark-theme")? "dark" : "light"; } localStorage.setItem("theme", theme); }); </script> </li> <li class="site-header__navigation-item site-header__navigation-submenu-section" tabindex="0"> <span class="site-header__navigation-link"> Community </span> <div class="site-header__navigation-submenu"> <div class="site-header__navigation-submenu-item" itemprop="name"> <a target="_top" class="site-header__navigation-submenu-item-link" href="https://gradle.org/" itemprop="url"> <span class="site-header__navigation-submenu-item-link-text">Community Home</span> </a> </div> <div class="site-header__navigation-submenu-item" itemprop="name"> <a target="_top" class="site-header__navigation-submenu-item-link" href="https://discuss.gradle.org/" itemprop="url"> <span class="site-header__navigation-submenu-item-link-text">Community Forums</span> </a> </div> <div class="site-header__navigation-submenu-item" itemprop="name"> <a target="_top" class="site-header__navigation-submenu-item-link" href="https://plugins.gradle.org" itemprop="url"> <span class="site-header__navigation-submenu-item-link-text">Community Plugins</span> </a> </div> </div> </li> <li class="site-header__navigation-item" itemprop="name"> <a target="_top" class="site-header__navigation-link" href="https://dpeuniversity.gradle.com/" itemprop="url">DPE University</a> </li> <li class="site-header__navigation-item" itemprop="name"> <a target="_top" class="site-header__navigation-link" href="https://gradle.org/training/" itemprop="url">Events</a> </li> <li class="site-header__navigation-item site-header__navigation-submenu-section" tabindex="0"> <span class="site-header__navigation-link"> News </span> <div class="site-header__navigation-submenu"> <div class="site-header__navigation-submenu-item" itemprop="name"> <a class="site-header__navigation-submenu-item-link" href="https://newsletter.gradle.org" itemprop="url"> <span class="site-header__navigation-submenu-item-link-text">Newsletter</span> </a> </div> <div class="site-header__navigation-submenu-item" itemprop="name"> <a class="site-header__navigation-submenu-item-link" href="https://blog.gradle.org" itemprop="url"> <span class="site-header__navigation-submenu-item-link-text">Blog</span> </a> </div> <div class="site-header__navigation-submenu-item"> <a class="site-header__navigation-submenu-item-link" href="https://twitter.com/gradle"> <span class="site-header__navigation-submenu-item-link-text">Twitter</span> </a> </div> </div> </li> <li class="site-header__navigation-item" itemprop="name"> <a target="_top" class="site-header__navigation-link" href="https://gradle.com/develocity" itemprop="url">Develocity</a> </li> <li class="site-header__navigation-item"> <a class="site-header__navigation-link" title="Gradle on GitHub" href="https://github.com/gradle/gradle"> <svg width="20" height="20" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg"> <title>Github</title> <path d="M10 0C4.477 0 0 4.477 0 10c0 4.418 2.865 8.166 6.839 9.489.5.092.682-.217.682-.482 0-.237-.008-.866-.013-1.7-2.782.603-3.369-1.342-3.369-1.342-.454-1.155-1.11-1.462-1.11-1.462-.908-.62.069-.608.069-.608 1.003.07 1.531 1.03 1.531 1.03.892 1.529 2.341 1.087 2.91.831.092-.646.35-1.086.636-1.336-2.22-.253-4.555-1.11-4.555-4.943 0-1.091.39-1.984 1.029-2.683-.103-.253-.446-1.27.098-2.647 0 0 .84-.268 2.75 1.026A9.578 9.578 0 0 1 10 4.836c.85.004 1.705.114 2.504.337 1.909-1.294 2.747-1.026 2.747-1.026.546 1.377.203 2.394.1 2.647.64.699 1.028 1.592 1.028 2.683 0 3.842-2.339 4.687-4.566 4.935.359.309.678.919.678 1.852 0 1.336-.012 2.415-.012 2.743 0 .267.18.579.688.481C17.137 18.163 20 14.418 20 10c0-5.523-4.478-10-10-10" fill-rule="evenodd";/> </svg> </a> </li> </ul> </div> </nav> </header> <main class="main-content"> <!-- Primary Navigation --> <nav class="docs-navigation"> <div class="search-container"></div> <h3 id="overview">Overview</h3> <ul> <li><a href="../userguide/userguide.html">What is Gradle?</a></li> <li><a href="../userguide/quick_start.html">Quick Start</a></li> </ul> <h3 id="what-is-new">Releases</h3> <ul> <li><a href="https://gradle.org/releases/">All Releases</a></li> <li><a href="../release-notes.html">Release Notes</a></li> <li><a href="../userguide/installation.html">Installing Gradle</a></li> <li><a class="nav-dropdown" data-toggle="collapse" href="#upgrading-gradle" aria-expanded="false" aria-controls="upgrading-gradle">Upgrading Gradle</a> <ul id="upgrading-gradle"> <li><a href="../userguide/upgrading_version_8.html">version 8.X to latest</a></li> <li><a href="../userguide/upgrading_version_7.html">version 7.X to 8.0</a></li> <li><a href="../userguide/upgrading_version_6.html">version 6.X to 7.0</a></li> <li><a href="../userguide/upgrading_version_5.html">version 5.X to 6.0</a></li> <li><a href="../userguide/upgrading_version_4.html">version 4.X to 5.0</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#migrating-to-gradle" aria-expanded="false" aria-controls="migrating-to-gradle">Migrating to Gradle</a> <ul id="migrating-to-gradle"> <li><a href="../userguide/migrating_from_maven.html">from Maven</a></li> <li><a href="../userguide/migrating_from_ant.html">from Ant</a></li> </ul> </li> <li><a href="../userguide/troubleshooting.html">Troubleshooting</a></li> <li><a href="../userguide/compatibility.html">Compatibility Notes</a></li> <li><a href="../userguide/feature_lifecycle.html">Gradle's Feature Lifecycle</a></li> </ul> <h3 id="running-gradle-builds">Running Gradle Builds</h3> <ul> <li><a href="../userguide/getting_started_eng.html">Getting Started</a></li> <li><a class="nav-dropdown" data-toggle="collapse" href="#running-introduction" aria-expanded="false" aria-controls="introduction">Core Concepts</a> <ul id="running-introduction"> <li><a href="../userguide/gradle_basics.html">1. Gradle Basics</a></li> <li><a href="../userguide/gradle_wrapper_basics.html">2. Gradle Wrapper Basics</a></li> <li><a href="../userguide/command_line_interface_basics.html">3. Command-Line Interface Basics</a></li> <li><a href="../userguide/settings_file_basics.html">4. Settings File Basics</a></li> <li><a href="../userguide/build_file_basics.html">5. Build File Basics</a></li> <li><a href="../userguide/dependency_management_basics.html">6. Dependency Management Basics</a></li> <li><a href="../userguide/task_basics.html">7. Task Basics</a></li> <li><a href="../userguide/plugin_basics.html">8. Plugins Basics</a></li> <li><a href="../userguide/gradle_optimizations.html">9. Incremental Builds + Caching</a></li> <li><a href="../userguide/build_scans.html">10. Build Scans</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" aria-expanded="false">Tutorial</a> <ul id="running-tutorial"> <li><a href="../userguide/part1_gradle_init.html">1. Initializing the Project</a></li> <li><a href="../userguide/part2_gradle_tasks.html">2. Running Tasks</a></li> <li><a href="../userguide/part3_gradle_dep_man.html">3. Understanding Dependencies</a></li> <li><a href="../userguide/part4_gradle_plugins.html">4. Applying Plugins</a></li> <li><a href="../userguide/part5_gradle_inc_builds.html">5. Exploring Incremental Builds</a></li> <li><a href="../userguide/part6_gradle_caching.html">6. Enabling the Build Cache</a></li> <li><a href="../userguide/part7_gradle_refs.html">7. Using Reference Materials</a></li> </ul> </li> <li><a href="../userguide/gradle_ides.html">Gradle in the IDE</a></li> <li><a href="../userguide/continuous_builds.html">Continuous Build</a></li> </ul> <h3 id="authoring-gradle-builds">Authoring Gradle Builds</h3> <ul> <li><a href="../userguide/getting_started_dev.html">Getting Started</a></li> <li><a class="nav-dropdown" data-toggle="collapse" href="#learning-the-basics" aria-expanded="false" aria-controls="learning-the-basics">Learning the Basics</a> <ul id="authoring-introduction"> <li><a href="../userguide/gradle_directories.html">1. Gradle Directories</a></li> <li><a href="../userguide/intro_multi_project_builds.html">2. Multi-Project Builds</a></li> <li><a href="../userguide/build_lifecycle.html">3. Gradle Build Lifecycle</a></li> <li><a href="../userguide/writing_settings_files.html">4. Writing Settings Files</a></li> <li><a href="../userguide/writing_build_scripts.html">5. Writing Build Scripts</a></li> <li><a href="../userguide/tutorial_using_tasks.html">6. Using Tasks</a></li> <li><a href="../userguide/writing_tasks.html">7. Writing Tasks</a></li> <li><a href="../userguide/plugins.html">8. Using Plugins</a></li> <li><a href="../userguide/writing_plugins.html">9. Writing Plugins</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" aria-expanded="false">Tutorial</a> <ul id="authoring-tutorial"> <li><a href="../userguide/partr1_gradle_init.html">1. Initializing the Project</a></li> <li><a href="../userguide/partr2_build_lifecycle.html">2. Understanding the Build Lifecycle</a></li> <li><a href="../userguide/partr3_multi_project_builds.html">3. Multi-Project Builds</a></li> <li><a href="../userguide/partr4_settings_file.html">4. Writing the Settings File</a></li> <li><a href="../userguide/partr5_build_scripts.html">5. Writing a Build Script</a></li> <li><a href="../userguide/partr6_writing_tasks.html">6. Writing Tasks</a></li> <li><a href="../userguide/partr7_writing_plugins.html">7. Writing Plugins</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#authoring-multi-project-builds" aria-expanded="false" aria-controls="authoring-multi-project-builds">Structuring Builds</a> <ul id="authoring-multi-project-builds"> <li><a href="../userguide/multi_project_builds.html">Structuring Projects with Gradle</a></li> <li><a href="../userguide/declaring_dependencies_between_subprojects.html">Declaring Dependencies between Subprojects</a></li> <li><a href="../userguide/sharing_build_logic_between_subprojects.html">Sharing Build Logic between Subprojects</a></li> <li><a href="../userguide/composite_builds.html">Composite Builds</a></li> <li><a href="../userguide/multi_project_configuration_and_execution.html">Configuration on Demand</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#developing-tasks" aria-expanded="false" aria-controls="developing-tasks">Developing Tasks</a> <ul id="developing-tasks"> <li><a href="../userguide/more_about_tasks.html">Understanding Tasks</a></li> <li><a href="../userguide/controlling_task_execution.html">Controlling Task Execution</a></li> <li><a href="../userguide/organizing_tasks.html">Organizing Tasks</a></li> <li><a href="../userguide/implementing_custom_tasks.html">Implementing Custom Tasks</a></li> <li><a href="../userguide/lazy_configuration.html">Configuring Tasks Lazily</a></li> <li><a href="../userguide/worker_api.html">Developing Parallel Tasks</a></li> <li><a href="../userguide/custom_tasks.html">Developing Advanced Tasks</a></li> <li><a href="../userguide/build_services.html">Using Shared Build Services</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#developing-plugins" aria-expanded="false" aria-controls="developing-plugins">Developing Plugins</a> <ul id="developing-plugins"> <li><a href="../userguide/custom_plugins.html">Understanding Plugins</a></li> <li><a href="../userguide/implementing_gradle_plugins.html">Understanding Implementation Options</a></li> <li><a href="../userguide/implementing_gradle_plugins_precompiled.html">Implementing Pre-compiled Script Plugins</a></li> <li><a href="../userguide/implementing_gradle_plugins_binary.html">Implementing Binary Plugins</a></li> <li><a href="../userguide/testing_gradle_plugins.html">Testing Plugins</a></li> <li><a href="../userguide/publishing_gradle_plugins.html">Publishing Plugins</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#gradle-properties" aria-expanded="false" aria-controls="gradle-properties">Understanding Gradle Types</a> <ul id="gradle-properties-topics"> <li><a href="../userguide/properties_providers.html">Understanding Properties and Providers</a></li> <li><a href="../userguide/collections.html">Understanding Collections</a></li> <li><a href="../userguide/service_injection.html">Understanding Services and Service Injection</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#other-developing-topics" aria-expanded="false" aria-controls="other-developing-topics">Other Topics</a> <ul id="other-developing-topics"> <li><a href="../userguide/working_with_files.html">Working with Files</a></li> <li><a href="../userguide/init_scripts.html">Initialization Scripts</a></li> <li><a href="../userguide/dataflow_actions.html">Dataflow Actions</a></li> <li><a href="../userguide/test_kit.html">Testing with TestKit</a></li> <li><a href="../userguide/ant.html">Using Ant from Gradle</a></li> </ul> </li> <li><a href="../userguide/directory_layout.html">Gradle-managed Directories</a></li> <li><a href="../userguide/build_environment.html">Configuring the Build Environment</a></li> <li><a href="../userguide/logging.html">Logging with Gradle</a></li> </ul> <h3 id="managing-dependencies">Dependency Management</h3> <ul> <li><a href="../userguide/getting_started_dep_man.html">Getting Started</a></li> <li><a class="nav-dropdown" data-toggle="collapse" href="#learning-the-basics-dependency-management" aria-expanded="false" aria-controls="learning-the-basics-dependency-management">Learning the Basics</a> <ul id="learning-the-basics-dependency-management"> <li><a href="../userguide/declaring_dependencies.html">1. Declaring Dependencies</a></li> <li><a href="../userguide/dependency_configurations.html">2. Dependency Configurations</a></li> <li><a href="../userguide/declaring_repositories.html">3. Declaring Repositories</a></li> <li><a href="../userguide/centralizing_dependencies.html">4. Centralizing Dependencies</a></li> <li><a href="../userguide/dependency_constraints_conflicts.html">5. Dependency Constraints and Conflict Resolution</a></li> <li><a href="../userguide/dependency_resolution.html">6. Dependency Resolution</a></li> <li><a href="../userguide/variant_aware_resolution.html">7. Variant Aware Dependency Resolution</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#declaring-dependencies" aria-expanded="false" aria-controls="declaring-dependencies">Declaring Dependencies</a> <ul id="declaring-dependencies"> <li><a href="../userguide/declaring_dependencies_basics.html">Declaring Dependencies Basics</a></li> <li><a href="../userguide/viewing_debugging_dependencies.html">Viewing Dependencies</a></li> <li><a href="../userguide/dependency_versions.html">Declaring Versions and Ranges</a></li> <li><a href="../userguide/dependency_constraints.html">Declaring Dependency Constraints</a></li> <li><a href="../userguide/declaring_configurations.html">Creating Dependency Configurations</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#declaring-repositories" aria-expanded="false" aria-controls="declaring-repositories">Declaring Repositories</a> <ul id="declaring-repositories"> <li><a href="../userguide/declaring_repositories_basics.html">Declaring Repositories Basics</a></li> <li><a href="../userguide/centralizing_repositories.html">Centralizing Repository Declarations</a></li> <li><a href="../userguide/supported_repository_types.html">Repository Types</a></li> <li><a href="../userguide/supported_metadata_formats.html">Metadata Formats</a></li> <li><a href="../userguide/supported_repository_protocols.html">Supported Protocols</a></li> <li><a href="../userguide/filtering_repository_content.html">Filtering Repository Content</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#centralizing-dependencies" aria-expanded="false" aria-controls="centralizing-dependencies">Centralizing Dependencies</a> <ul id="centralizing-dependencies"> <li><a href="../userguide/platforms.html">Creating Platforms</a></li> <li><a href="../userguide/version_catalogs.html">Creating Version Catalogs</a></li> <li><a href="../userguide/centralizing_catalog_platform.html">Using Catalogs with Platforms</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#dependency-management" aria-expanded="false" aria-controls="dependency-management">Managing Dependencies</a> <ul id="dependency-management"> <li><a href="../userguide/dependency_locking.html">Locking Versions</a></li> <li><a href="../userguide/resolution_rules.html">Using Resolution Rules</a></li> <li><a href="../userguide/component_metadata_rules.html">Modifying Dependency Metadata</a></li> <li><a href="../userguide/dependency_caching.html">Caching Dependencies</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#understanding_dep_res" aria-expanded="false" aria-controls="understanding_dep_res">Understanding Dependency Resolution</a> <ul id="understanding_dep_res"> <li><a href="../userguide/variant_model.html">Understanding The Model</a></li> <li><a href="../userguide/component_capabilities.html">Capabilities</a></li> <li><a href="../userguide/variant_attributes.html">Variants and Attributes</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#dependency-resolution" aria-expanded="false" aria-controls="dependency-resolution">Controlling Dependency Resolution</a> <ul id="dependency-resolution"> <li><a href="../userguide/dependency_resolution_basics.html">Dependency Resolution Basics</a></li> <li><a href="../userguide/dependency_graph_resolution.html">Graph Resolution</a></li> <li><a href="../userguide/artifact_resolution.html">Artifact Resolution</a></li> <li><a href="../userguide/artifact_transforms.html">Artifact Transforms</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#publishing" aria-expanded="false" aria-controls="publishing">Publishing Libraries</a> <ul id="publishing"> <li><a href="../userguide/publishing_setup.html">Setting up Publishing</a></li> <li><a href="../userguide/publishing_gradle_module_metadata.html">Understanding Gradle Module Metadata</a></li> <li><a href="../userguide/publishing_signing.html">Signing Artifacts</a></li> <li><a href="../userguide/publishing_customization.html">Customizing Publishing</a></li> <li><a href="../userguide/publishing_maven.html">Maven Publish Plugin</a></li> <li><a href="../userguide/publishing_ivy.html">Ivy Publish Plugin</a></li> </ul> </li> <li><a class="nav-dropdown" data-toggle="collapse" href="#other" aria-expanded="false" aria-controls="other">Other Topics</a> <ul id="other"> <li><a href="../userguide/dependency_verification.html">Verifying Dependencies</a></li> <li><a href="../userguide/dependency_version_alignment.html">Aligning Dependencies</a></li> <li><a href="../userguide/feature_variants.html">Modeling Feature Variants and Optional Dependencies</a></li> </ul> </li> </ul> <h3 id="authoring-gradle-builds-java">Authoring JVM Builds</h3> <ul> <li><a href="../userguide/building_java_projects.html">Building Java & JVM projects</a></li> <li><a href="../userguide/java_testing.html">Testing Java & JVM projects</a></li> <li><a class="nav-dropdown" data-toggle="collapse" href="#java-toolchains" aria-expanded="false" aria-controls="java-toolchains">Java Toolchains</a> <ul id="java-toolchains"> <li><a href="../userguide/toolchains.html">Toolchains for JVM projects</a></li> <li><a href="../userguide/toolchain_plugins.html">Toolchain Resolver Plugins</a></li> </ul> </li> <li><a href="../userguide/dependency_management_for_java_projects.html">Managing Dependencies</a></li> <li><a class="nav-dropdown" data-toggle="collapse" href="#jvm-plugins" aria-expanded="false" aria-controls="jvm-plugins">JVM Plugins</a> <ul id="jvm-plugins"> <li><a href="../userguide/java_library_plugin.html">Java Library Plugin</a></li> <li><a href="../userguide/application_plugin.html">Java Application Plugin</a></li> <li><a href="../userguide/java_platform_plugin.html">Java Platform Plugin</a></li> <li><a href="../userguide/groovy_plugin.html">Groovy Plugin</a></li> <li><a href="../userguide/scala_plugin.html">Scala Plugin</a></li> </ul> </li> </ul> <h3 id="optimizing-build-performance">Optimizing Build Performance</h3> <ul> <li><a href="../userguide/performance.html">Improving Performance of Gradle Builds</a></li> <li><a href="../userguide/gradle_daemon.html">Gradle Daemon</a></li> <li><a href="../userguide/file_system_watching.html">File System Watching</a></li> <li><a href="../userguide/incremental_build.html">Incremental Build</a></li> <li><a class="nav-dropdown" data-toggle="collapse" href="#build-cache" aria-expanded="false" aria-controls="optimizing-build-performance">Using the Build Cache</a> <ul id="build-cache"> <li><a href="../userguide/build_cache.html">Enabling and Configuring</a></li> <li><a href="../userguide/build_cache_use_cases.html">Why use the Build Cache?</a></li> <li><a href="../userguide/build_cache_performance.html">Understanding the Impact</a></li> <li><a href="../userguide/build_cache_concepts.html">Learning Basic Concepts</a></li> <li><a href="../userguide/caching_java_projects.html">Caching Java Project</a></li> <li><a href="../userguide/caching_android_projects.html">Caching Android Project</a></li> <li><a href="../userguide/build_cache_debugging.html">Debugging Caching Issues</a></li> <li><a href="../userguide/common_caching_problems.html">Troubleshooting</a></li> </ul> </li> <li><a href="../userguide/configuration_cache.html">Using the Configuration Cache</a></li> <li><a href="../userguide/inspect.html">Inspecting Gradle Builds</a></li> <li><a href="../userguide/config_gradle.html">Configuring Gradle</a></li> <li><a href="../userguide/project_properties.html">Project Properties</a></li> <li><a href="../userguide/networking.html">Gradle Networking</a></li> </ul> <h3 id="authoring-gradle-builds-native">Authoring C++/Swift Builds</h3> <ul> <li><a href="../userguide/building_cpp_projects.html">Building C++ projects</a></li> <li><a href="../userguide/cpp_testing.html">Testing C++ projects</a></li> <li><a href="../userguide/building_swift_projects.html">Building Swift projects</a></li> <li><a href="../userguide/swift_testing.html">Testing Swift projects</a></li> </ul> <h3 id="reference">Reference</h3> <ul> <li><a class="nav-dropdown" data-toggle="collapse" href="#gradle-api" aria-expanded="false" aria-controls="gradle-api">Gradle DSLs and API</a> <ul id="gradle-api"> <li><a href="../javadoc/index.html?overview-summary.html">Javadoc</a></li> <li><a href="../userguide/groovy_build_script_primer.html">Groovy DSL Primer</a></li> <li><a href="../dsl/index.html">Groovy DSL Reference</a></li> <li><a href="../userguide/kotlin_dsl.html">Kotlin DSL Primer</a></li> <li><a href="../kotlin-dsl/index.html" target="_blank">Kotlin DSL API</a></li> <li><a href="../userguide/migrating_from_groovy_to_kotlin_dsl.html">Groovy to Kotlin DSL Migration</a></li> <li><a href="../samples/index.html">Samples</a></li> <li><a href="../userguide/glossary.html">Glossary</a></li> </ul> </li> <li><a href="https://community.gradle.org/cookbook/">Gradle Cookbook</a></li> <li><a href="../userguide/command_line_interface.html">Command-Line Interface</a></li> <li><a href="../userguide/gradle_wrapper.html">Gradle Wrapper</a></li> <li><a href="../userguide/plugin_reference.html">Core Plugins</a></li> <li id="third-party-integration"><a href="../userguide/third_party_integration.html">Gradle & Third-party Tools</a></li> <li><a href="../userguide/userguide_single.html">User Manual Single Page</a></li> <li><a href="../userguide/userguide.pdf">User Manual PDF</a></li> </ul> </nav> <!-- End Primary Navigation --> <div class="content"> <div class="chapter"> <div id="header"> <h1>Upgrading your build from Gradle 5.x to 6.0</h1> <div class="details"> <span id="revnumber">version 8.11.1</span> </div> <div id="toc" class="toc"> <div id="toctitle">Contents</div> <ul class="sectlevel1"> <li><a href="#changes_6.0">Upgrading from 5.6 and earlier</a></li> <li><a href="#changes_5.6">Upgrading from 5.5 and earlier</a></li> <li><a href="#changes_5.5">Upgrading from 5.4 and earlier</a></li> <li><a href="#changes_5.4">Upgrading from 5.3 and earlier</a></li> <li><a href="#changes_5.3">Upgrading from 5.2 and earlier</a></li> <li><a href="#changes_5.2">Upgrading from 5.1 and earlier</a></li> <li><a href="#changes_5.1">Upgrading from 5.0 and earlier</a></li> </ul> </div> </div> <div id="content"> <div id="preamble"> <div class="sectionbody"> <div class="paragraph"> <p>This chapter provides the information you need to migrate your Gradle 5.x builds to Gradle 6.0. For migrating from Gradle 4.x, complete the <a href="upgrading_version_4.html#upgrading_version_4">4.x to 5.0 guide</a> first.</p> </div> <div class="paragraph"> <p>We recommend the following steps for all users:</p> </div> <div class="olist arabic"> <ol class="arabic"> <li> <p>Try running <code>gradle help --scan</code> and view the <a href="https://gradle.com/enterprise/releases/2018.4/#identify-usages-of-deprecated-gradle-functionality">deprecations view</a> of the generated build scan.</p> <div class="imageblock"> <div class="content"> <img src="img/deprecations.png" alt="Deprecations View of a Gradle Build Scan"> </div> </div> <div class="paragraph"> <p>This is so that you can see any deprecation warnings that apply to your build.</p> </div> <div class="paragraph"> <p>Alternatively, you can run <code>gradle help --warning-mode=all</code> to see the deprecations in the console, though it may not report as much detailed information.</p> </div> </li> <li> <p>Update your plugins.</p> <div class="paragraph"> <p>Some plugins will break with this new version of Gradle, for example because they use internal APIs that have been removed or changed. The previous step will help you identify potential problems by issuing deprecation warnings when a plugin does try to use a deprecated part of the API.</p> </div> </li> <li> <p>Run <code>gradle wrapper --gradle-version 6.0</code> to update the project to 6.0.</p> </li> <li> <p>Try to run the project and debug any errors using the <a href="troubleshooting.html#troubleshooting">Troubleshooting Guide</a>.</p> </li> </ol> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.0"><a class="anchor" href="#changes_6.0"></a><a class="link" href="#changes_6.0">Upgrading from 5.6 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="deprecations"><a class="anchor" href="#deprecations"></a><a class="link" href="#deprecations">Deprecations</a></h3> <div class="sect3"> <h4 id="dependencies_should_no_longer_be_declared_using_the_compile_and_runtime_configurations"><a class="anchor" href="#dependencies_should_no_longer_be_declared_using_the_compile_and_runtime_configurations"></a><a class="link" href="#dependencies_should_no_longer_be_declared_using_the_compile_and_runtime_configurations">Dependencies should no longer be declared using the <code>compile</code> and <code>runtime</code> configurations</a></h4> <div class="paragraph"> <p>The usage of the <code>compile</code> and <code>runtime</code> configurations in the Java ecosystem plugins has been discouraged since <a href="https://docs.gradle.org/3.4/release-notes.html#the-java-library-plugin">Gradle 3.4</a>.</p> </div> <div class="paragraph"> <p>These configurations are used for compiling and running code from the <code>main</code> source set. Other sources sets create similar configurations (e.g. <code>testCompile</code> and <code>testRuntime</code> for the <code>test</code> source set), should not be used either. The <code>implementation</code>, <code>api</code>, <code>compileOnly</code> and <code>runtimeOnly</code> configurations should be used to declare dependencies and the <code>compileClasspath</code> and <code>runtimeClasspath</code> configurations to resolve dependencies. See <a href="java_library_plugin.html#sec:java_library_configurations_graph">the relationship of these configurations</a>.</p> </div> </div> <div class="sect3"> <h4 id="legacy_publication_system_is_deprecated_and_replaced_with_the_publish_plugins"><a class="anchor" href="#legacy_publication_system_is_deprecated_and_replaced_with_the_publish_plugins"></a><a class="link" href="#legacy_publication_system_is_deprecated_and_replaced_with_the_publish_plugins">Legacy publication system is deprecated and replaced with the <code>*-publish</code> plugins</a></h4> <div class="paragraph"> <p>The <code>uploadArchives</code> task and the <code>maven</code> plugin are deprecated.</p> </div> <div class="paragraph"> <p>Users should migrate to the <a href="publishing_setup.html#publishing_components">publishing system</a> of Gradle by using either the <a href="publishing_maven.html#publishing_maven"><code>maven-publish</code></a> or <a href="publishing_ivy.html#publishing_ivy"><code>ivy-publish</code></a> plugins. These plugins have been stable since Gradle 4.8.</p> </div> <div class="paragraph"> <p>The publishing system is also the only way to ensure the publication of <a href="publishing_gradle_module_metadata.html#sec:understanding-gradle-module-md">Gradle Module Metadata</a>.</p> </div> </div> <div class="sect3"> <h4 id="problems_with_tasks_emit_deprecation_warnings"><a class="anchor" href="#problems_with_tasks_emit_deprecation_warnings"></a><a class="link" href="#problems_with_tasks_emit_deprecation_warnings">Problems with tasks emit deprecation warnings</a></h4> <div class="paragraph"> <p>When Gradle detects problems with task definitions (such as incorrectly defined inputs or outputs) it will show the following message on the console:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>Deprecated Gradle features were used in this build, making it incompatible with Gradle 7.0. Use '--warning-mode all' to show the individual deprecation warnings. See https://docs.gradle.org/6.0/userguide/command_line_interface.html#sec:command_line_warnings</code></pre> </div> </div> <div class="paragraph"> <p>The deprecation warnings show up in <a href="https://scans.gradle.com/s/txrptciitl2ha/deprecations">build scans</a> for every build, regardless of the command-line switches used.</p> </div> <div class="paragraph"> <p>When the build is executed with <code>--warning-mode all</code>, the individual warnings will be shown:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>> Task :myTask Property 'inputDirectory' is declared without normalization specified. Properties of cacheable work must declare their normalization via @PathSensitive, @Classpath or @CompileClasspath. Defaulting to PathSensitivity.ABSOLUTE. This behavior is scheduled to be removed in Gradle 7.0. Property 'outputFile' is not annotated with an input or output annotation. This behavior is scheduled to be removed in Gradle 7.0.</code></pre> </div> </div> <div class="paragraph"> <p>If you own the code of the tasks in question, you can fix them by <a href="incremental_build.html#sec:task_input_validation">following the suggestions</a>. You can also use <code>--stacktrace</code> to see where in the code each warning originates from.</p> </div> <div class="paragraph"> <p>Otherwise, you’ll need to report the problems to the maintainer of the relevant task or plugin.</p> </div> </div> <div class="sect3"> <h4 id="old_api_for_incremental_tasks_incrementaltaskinputs_has_been_deprecated"><a class="anchor" href="#old_api_for_incremental_tasks_incrementaltaskinputs_has_been_deprecated"></a><a class="link" href="#old_api_for_incremental_tasks_incrementaltaskinputs_has_been_deprecated">Old API for incremental tasks, <code>IncrementalTaskInputs</code>, has been deprecated</a></h4> <div class="paragraph"> <p>In Gradle 5.4 we introduced a new API for implementing <a href="custom_tasks.html#incremental_tasks">incremental tasks</a>: <a href="../dsl/org.gradle.work.InputChanges.html">InputChanges</a>. The old API based on <code>IncrementalTaskInputs</code> has been deprecated.</p> </div> </div> <div class="sect3"> <h4 id="forced_dependencies"><a class="anchor" href="#forced_dependencies"></a><a class="link" href="#forced_dependencies">Forced dependencies</a></h4> <div class="paragraph"> <p>Forcing dependency versions using <code>force = true</code> on a first-level dependency has been deprecated.</p> </div> <div class="paragraph"> <p>Force has both a semantic and ordering issue which can be avoided by using a <a href="dependency_versions.html#sec:rich-version-constraints">strict version constraint</a>.</p> </div> </div> <div class="sect3"> <h4 id="search_upwards_related_apis_in_startparameter_have_been_deprecated"><a class="anchor" href="#search_upwards_related_apis_in_startparameter_have_been_deprecated"></a><a class="link" href="#search_upwards_related_apis_in_startparameter_have_been_deprecated">Search upwards related APIs in <code>StartParameter</code> have been deprecated</a></h4> <div class="paragraph"> <p>In Gradle 5.0, we removed the <code>--no-search-upward</code> CLI parameter.</p> </div> <div class="paragraph"> <p>The related APIs in <code>StartParameter</code> (like <code>isSearchUpwards()</code>) are now deprecated.</p> </div> </div> <div class="sect3"> <h4 id="apis_buildlistener_buildstarted_and_gradle_buildstarted_have_been_deprecated"><a class="anchor" href="#apis_buildlistener_buildstarted_and_gradle_buildstarted_have_been_deprecated"></a><a class="link" href="#apis_buildlistener_buildstarted_and_gradle_buildstarted_have_been_deprecated">APIs <code>BuildListener.buildStarted</code> and <code>Gradle.buildStarted</code> have been deprecated</a></h4> <div class="paragraph"> <p>These methods currently do not work as expected since the callbacks will never be called after the build has started.</p> </div> <div class="paragraph"> <p>The methods are being deprecated to avoid confusion.</p> </div> </div> <div class="sect3"> <h4 id="implicit_duplicate_strategy_for_copy_or_archive_tasks_has_been_deprecated"><a class="anchor" href="#implicit_duplicate_strategy_for_copy_or_archive_tasks_has_been_deprecated"></a><a class="link" href="#implicit_duplicate_strategy_for_copy_or_archive_tasks_has_been_deprecated">Implicit duplicate strategy for <code>Copy</code> or archive tasks has been deprecated</a></h4> <div class="paragraph"> <p>Archive tasks <code>Tar</code> and <code>Zip</code> by default allow multiple entries for the same path to exist in the created archive. This can cause <a href="https://github.com/gradle/gradle/issues/9990">"grossly invalid zip files" that can trigger zip bomb detection</a>.</p> </div> <div class="paragraph"> <p>To prevent this from happening accidentally, encountering duplicates while creating an archive now produces a deprecation message and will fail the build starting with Gradle 7.0.</p> </div> <div class="paragraph"> <p><code>Copy</code> tasks also happily copy multiple sources with the same relative path to the destination directory. This behavior has also been deprecated.</p> </div> <div class="paragraph"> <p>If you want to allow duplicates, you can specify that explicitly:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>task archive(type: Zip) { duplicatesStrategy = DuplicatesStrategy.INCLUDE // allow duplicates ... }</code></pre> </div> </div> </div> <div class="sect3"> <h4 id="executing_gradle_without_a_settings_file_has_been_deprecated"><a class="anchor" href="#executing_gradle_without_a_settings_file_has_been_deprecated"></a><a class="link" href="#executing_gradle_without_a_settings_file_has_been_deprecated">Executing Gradle without a settings file has been deprecated</a></h4> <div class="paragraph"> <p>A Gradle build is defined by a <code>settings.gradle[.kts]</code> file in the current or parent directory. Without a settings file, a Gradle build is undefined and will emit a deprecation warning.</p> </div> <div class="paragraph"> <p>In Gradle 7.0, Gradle will only allow you to invoke the <code>init</code> task or diagnostic command line flags, such as <code>--version</code>, with undefined builds.</p> </div> </div> <div class="sect3"> <h4 id="calling_project_afterevaluate_on_an_evaluated_project_has_been_deprecated"><a class="anchor" href="#calling_project_afterevaluate_on_an_evaluated_project_has_been_deprecated"></a><a class="link" href="#calling_project_afterevaluate_on_an_evaluated_project_has_been_deprecated">Calling <code>Project.afterEvaluate</code> on an evaluated project has been deprecated</a></h4> <div class="paragraph"> <p>Once a project is evaluated, Gradle ignores all configuration passed to <code>Project#afterEvaluate</code> and emits a deprecation warning. This scenario will become an error in Gradle 7.0.</p> </div> </div> <div class="sect3"> <h4 id="deprecated_plugins"><a class="anchor" href="#deprecated_plugins"></a><a class="link" href="#deprecated_plugins">Deprecated plugins</a></h4> <div class="paragraph"> <p>The following bundled plugins were never announced and will be removed in the next major release of Gradle:</p> </div> <div class="ulist"> <ul> <li> <p><code>org.gradle.coffeescript-base</code></p> </li> <li> <p><code>org.gradle.envjs</code></p> </li> <li> <p><code>org.gradle.javascript-base</code></p> </li> <li> <p><code>org.gradle.jshint</code></p> </li> <li> <p><code>org.gradle.rhino</code></p> </li> </ul> </div> <div class="paragraph"> <p>Some of these plugins may have replacements on the <a href="https://plugins.gradle.org/">Plugin Portal</a>.</p> </div> </div> </div> <div class="sect2"> <h3 id="potential_breaking_changes"><a class="anchor" href="#potential_breaking_changes"></a><a class="link" href="#potential_breaking_changes">Potential breaking changes</a></h3> <div class="sect3"> <h4 id="android_gradle_plugin_3_3_and_earlier_is_no_longer_supported"><a class="anchor" href="#android_gradle_plugin_3_3_and_earlier_is_no_longer_supported"></a><a class="link" href="#android_gradle_plugin_3_3_and_earlier_is_no_longer_supported">Android Gradle Plugin 3.3 and earlier is no longer supported</a></h4> <div class="paragraph"> <p>Gradle 6.0 supports Android Gradle Plugin versions 3.4 and later.</p> </div> </div> <div class="sect3"> <h4 id="build_scan_plugin_2_x_is_no_longer_supported"><a class="anchor" href="#build_scan_plugin_2_x_is_no_longer_supported"></a><a class="link" href="#build_scan_plugin_2_x_is_no_longer_supported">Build scan plugin 2.x is no longer supported</a></h4> <div class="paragraph"> <p>For Gradle 6, usage of the build scan plugin must be replaced with the Develocity plugin. This also requires changing how the plugin is applied. Please see <a href="https://gradle.com/help/gradle-6-build-scan-plugin" class="bare">https://gradle.com/help/gradle-6-build-scan-plugin</a> for more information.</p> </div> </div> <div class="sect3"> <h4 id="updates_to_bundled_gradle_dependencies"><a class="anchor" href="#updates_to_bundled_gradle_dependencies"></a><a class="link" href="#updates_to_bundled_gradle_dependencies">Updates to bundled Gradle dependencies</a></h4> <div class="ulist"> <ul> <li> <p>Groovy has been updated to <a href="http://groovy-lang.org/changelogs/changelog-2.5.8.html">Groovy 2.5.8</a>.</p> </li> <li> <p>Kotlin has been updated to <a href="https://blog.jetbrains.com/kotlin/2019/08/kotlin-1-3-50-released/">Kotlin 1.3.50</a>.</p> </li> <li> <p>Ant has been updated to <a href="https://archive.apache.org/dist/ant/RELEASE-NOTES-1.10.7.html">Ant 1.10.7</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="updates_to_default_integration_versions"><a class="anchor" href="#updates_to_default_integration_versions"></a><a class="link" href="#updates_to_default_integration_versions">Updates to default integration versions</a></h4> <div class="ulist"> <ul> <li> <p>Checkstyle has been updated to <a href="https://checkstyle.org/releasenotes.html#Release_8.24">Checkstyle 8.24</a>.</p> </li> <li> <p>CodeNarc has been updated to <a href="https://github.com/CodeNarc/CodeNarc/blob/master/CHANGELOG.md#version-14---may-2019">CodeNarc 1.4</a>.</p> </li> <li> <p>PMD has been updated to <a href="https://pmd.github.io/latest/pmd_release_notes.html#28-july-2019---6170">PMD 6.17.0</a>.</p> </li> <li> <p>JaCoCo has been updated to <a href="http://www.jacoco.org/jacoco/trunk/doc/changes.html">0.8.5</a>. Contributed by <a href="https://github.com/Godin">Evgeny Mandrikov</a></p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="changes_to_build_and_task_names_in_composite_builds"><a class="anchor" href="#changes_to_build_and_task_names_in_composite_builds"></a><a class="link" href="#changes_to_build_and_task_names_in_composite_builds">Changes to build and task names in composite builds</a></h4> <div class="paragraph"> <p>Previously, Gradle used the name of the root project as the build name for an included build. Now, the name of the build’s root directory is used and the root project name is not considered if different. A different name for the build can be specified if the build is being included via a settings file.</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code data-lang="kotlin">includeBuild("some-other-build") { name = "another-name" }</code></pre> </div> </div> <div class="paragraph"> <p>The previous behavior was problematic as it caused different names to be used at different times during the build.</p> </div> </div> <div class="sect3"> <h4 id="buildsrc_is_now_reserved_as_a_project_and_subproject_build_name"><a class="anchor" href="#buildsrc_is_now_reserved_as_a_project_and_subproject_build_name"></a><a class="link" href="#buildsrc_is_now_reserved_as_a_project_and_subproject_build_name">buildSrc is now reserved as a project and subproject build name</a></h4> <div class="paragraph"> <p>Previously, Gradle did not prevent using the name “buildSrc” for a subproject of a multi-project build or as the name of an included build. Now, this is not allowed. The name “buildSrc” is now reserved for the conventional buildSrc project that builds extra build logic.</p> </div> <div class="paragraph"> <p>Typical use of buildSrc is unaffected by this change. You will only be affected if your settings file specifies <code>include("buildSrc")</code> or <code>includeBuild("buildSrc")</code>.</p> </div> </div> <div class="sect3"> <h4 id="scala_zinc_compiler"><a class="anchor" href="#scala_zinc_compiler"></a><a class="link" href="#scala_zinc_compiler">Scala Zinc compiler</a></h4> <div class="paragraph"> <p>The Zinc compiler has been upgraded to version 1.3.0. Gradle no longer supports building for Scala 2.9.</p> </div> <div class="paragraph"> <p>The minimum Zinc compiler supported by Gradle is 1.2.0 and the maximum tested version is 1.3.0.</p> </div> <div class="paragraph"> <p>To make it easier to select the version of the Zinc compiler, you can now configure a <code>zincVersion</code> property:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>scala { zincVersion = "1.2.1" }</code></pre> </div> </div> <div class="paragraph"> <p>Please remove any explicit dependencies you’ve added to the <code>zinc</code> configuration and use this property instead. If you try to use the <code>com.typesafe.zinc:zinc</code> dependency, Gradle will switch to the new Zinc implementation.</p> </div> </div> <div class="sect3"> <h4 id="changes_to_build_cache"><a class="anchor" href="#changes_to_build_cache"></a><a class="link" href="#changes_to_build_cache">Changes to Build Cache</a></h4> </div> <div class="sect3"> <h4 id="local_build_cache_is_always_a_directory_cache"><a class="anchor" href="#local_build_cache_is_always_a_directory_cache"></a><a class="link" href="#local_build_cache_is_always_a_directory_cache">Local build cache is always a directory cache</a></h4> <div class="paragraph"> <p>In the past, it was possible to use any build cache implementation as the <code>local</code> cache. This is no longer allowed as the local cache must always be a <code>DirectoryBuildCache</code>.</p> </div> <div class="paragraph"> <p>Calls to <code>BuildCacheConfiguration.local(Class)</code> with anything other than <code>DirectoryBuildCache</code> as the type will fail the build. Calling these methods with the <code>DirectoryBuildCache</code> type will produce a deprecation warning.</p> </div> <div class="paragraph"> <p>Use <code>getLocal()</code> and <code>local(Action)</code> instead.</p> </div> </div> <div class="sect3"> <h4 id="failing_to_pack_or_unpack_cached_results_will_now_fail_the_build"><a class="anchor" href="#failing_to_pack_or_unpack_cached_results_will_now_fail_the_build"></a><a class="link" href="#failing_to_pack_or_unpack_cached_results_will_now_fail_the_build">Failing to pack or unpack cached results will now fail the build</a></h4> <div class="paragraph"> <p>In the past, when Gradle encountered a problem while packing the results of a cached task, Gradle would ignore the problem and continue running the build.</p> </div> <div class="paragraph"> <p>When encountering a corrupt cached artifact, Gradle would remove whatever was already unpacked and re-execute the task to make sure the build had a chance to succeed.</p> </div> <div class="paragraph"> <p>While this behavior was intended to make a build successful, this had the adverse effect of hiding problems and led to reduced cache performance.</p> </div> <div class="paragraph"> <p>In Gradle 6.0, both pack and unpack errors will cause the build to fail, so that these problems will be surfaced more easily.</p> </div> </div> <div class="sect3"> <h4 id="buildsrc_projects_automatically_use_build_cache_configuration"><a class="anchor" href="#buildsrc_projects_automatically_use_build_cache_configuration"></a><a class="link" href="#buildsrc_projects_automatically_use_build_cache_configuration">buildSrc projects automatically use build cache configuration</a></h4> <div class="paragraph"> <p>Previously, in order to use the build cache for the buildSrc build you needed to duplicate your build cache config in the buildSrc build. Now, it automatically uses the build cache configuration defined by the top level settings script.</p> </div> </div> <div class="sect3"> <h4 id="changes_to_dependency_management"><a class="anchor" href="#changes_to_dependency_management"></a><a class="link" href="#changes_to_dependency_management">Changes to Dependency Management</a></h4> </div> <div class="sect3"> <h4 id="gradle_module_metadata_is_always_published"><a class="anchor" href="#gradle_module_metadata_is_always_published"></a><a class="link" href="#gradle_module_metadata_is_always_published">Gradle Module Metadata is always published</a></h4> <div class="paragraph"> <p>Officially introduced in Gradle 5.3, <a href="https://blog.gradle.org/gradle-metadata-1.0">Gradle Module Metadata</a> was created to solve many of the problems that have plagued dependency management for years, in particular, but not exclusively, in the Java ecosystem.</p> </div> <div class="paragraph"> <p>With Gradle 6.0, Gradle Module Metadata is enabled by default.</p> </div> <div class="paragraph"> <p>This means, if you are publishing libraries with Gradle and using the <a href="publishing_maven.html#publishing_maven">maven-publish</a> or <a href="publishing_ivy.html#publishing_ivy">ivy-publish</a> plugin, the Gradle Module Metadata file is always published <strong>in addition</strong> to traditional metadata.</p> </div> <div class="paragraph"> <p>The traditional metadata file will contain a marker so that Gradle knows that there is additional metadata to consume.</p> </div> </div> <div class="sect3"> <h4 id="gradle_module_metadata_has_stricter_validation"><a class="anchor" href="#gradle_module_metadata_has_stricter_validation"></a><a class="link" href="#gradle_module_metadata_has_stricter_validation">Gradle Module Metadata has stricter validation</a></h4> <div class="paragraph"> <p>The following rules are verified when publishing Gradle Module Metadata:</p> </div> <div class="ulist"> <ul> <li> <p>Variant names must be unique,</p> </li> <li> <p>Each variant must have at least <a href="variant_attributes.html#variant-attributes">one attribute</a>,</p> </li> <li> <p>Two variants cannot have the <a href="variant_model.html#sec:understanding-variant-selection">exact same attributes and capabilities</a>,</p> </li> <li> <p>If there are dependencies, at least one, across all variants, must carry <a href="dependency_versions.html#sec:rich-version-constraints">version information</a>.</p> </li> </ul> </div> <div class="paragraph"> <p>These are documented in the <a href="https://github.com/gradle/gradle/blob/master/platforms/documentation/docs/src/docs/design/gradle-module-metadata-latest-specification.md">specification</a> as well.</p> </div> </div> <div class="sect3"> <h4 id="maven_or_ivy_repositories_are_no_longer_queried_for_artifacts_without_metadata_by_default"><a class="anchor" href="#maven_or_ivy_repositories_are_no_longer_queried_for_artifacts_without_metadata_by_default"></a><a class="link" href="#maven_or_ivy_repositories_are_no_longer_queried_for_artifacts_without_metadata_by_default">Maven or Ivy repositories are no longer queried for artifacts without metadata by default</a></h4> <div class="paragraph"> <p>If Gradle fails to locate the metadata file (<code>.pom</code> or <code>ivy.xml</code>) of a module in a repository defined in the <code>repositories { }</code> section, it now assumes that the module does not exist in that repository.</p> </div> <div class="paragraph"> <p>For dynamic versions, the <code>maven-metadata.xml</code> for the corresponding module needs to be present in a Maven repository.</p> </div> <div class="paragraph"> <p>Previously, Gradle would also look for a default artifact (<code>.jar</code>). This behavior often caused a large number of unnecessary requests when using multiple repositories that slowed builds down.</p> </div> <div class="paragraph"> <p>You can opt into the old behavior for selected repositories by adding the <code>artifact()</code> <a href="supported_metadata_formats.html#sec:supported-metadata-sources">metadata source</a>.</p> </div> </div> <div class="sect3"> <h4 id="changing_the_pom_packaging_property_no_longer_changes_the_artifact_extension"><a class="anchor" href="#changing_the_pom_packaging_property_no_longer_changes_the_artifact_extension"></a><a class="link" href="#changing_the_pom_packaging_property_no_longer_changes_the_artifact_extension">Changing the pom <code>packaging</code> property no longer changes the artifact extension</a></h4> <div class="paragraph"> <p>Previously, if the pom packaging was not <em>jar</em>, <em>ejb</em>, <em>bundle</em> or <em>maven-plugin</em>, the extension of the main artifact published to a Maven repository was changed during publishing to match the pom packaging.</p> </div> <div class="paragraph"> <p>This behavior led to broken Gradle Module Metadata and was difficult to understand due to handling of different packaging types.</p> </div> <div class="paragraph"> <p>Build authors can change the artifact name when the artifact is created to obtain the same result as before — e.g. by setting <code>jar.archiveExtension.set(pomPackaging)</code> explicitly.</p> </div> </div> <div class="sect3"> <h4 id="an_ivy_xml_published_for_java_libraries_contains_more_information"><a class="anchor" href="#an_ivy_xml_published_for_java_libraries_contains_more_information"></a><a class="link" href="#an_ivy_xml_published_for_java_libraries_contains_more_information">An <code>ivy.xml</code> published for Java libraries contains more information</a></h4> <div class="paragraph"> <p>A number of fixes were made to produce more correct <code>ivy.xml</code> metadata in the <code>ivy-publish</code> plugin.</p> </div> <div class="paragraph"> <p>As a consequence, the internal structure of the <code>ivy.xml</code> file has changed. The <code>runtime</code> configuration now contains more information, which corresponds to the <em>runtimeElements</em> variant of a Java library. The <code>default</code> configuration should yield the same result as before.</p> </div> <div class="paragraph"> <p>In general, users are advised to migrate from <code>ivy.xml</code> to the new Gradle Module Metadata format.</p> </div> </div> <div class="sect3"> <h4 id="changes_to_plugins_and_build_scripts"><a class="anchor" href="#changes_to_plugins_and_build_scripts"></a><a class="link" href="#changes_to_plugins_and_build_scripts">Changes to Plugins and Build scripts</a></h4> </div> <div class="sect3"> <h4 id="classes_from_buildsrc_are_no_longer_visible_to_settings_scripts"><a class="anchor" href="#classes_from_buildsrc_are_no_longer_visible_to_settings_scripts"></a><a class="link" href="#classes_from_buildsrc_are_no_longer_visible_to_settings_scripts">Classes from <code>buildSrc</code> are no longer visible to settings scripts</a></h4> <div class="paragraph"> <p>Previously, the buildSrc project was built before applying the project’s settings script and its classes were visible within the script. Now, buildSrc is built after the settings script and its classes are not visible to it. The buildSrc classes remain visible to project build scripts and script plugins.</p> </div> <div class="paragraph"> <p>Custom logic can be used from a settings script by <a href="tutorial_using_tasks.html#sec:build_script_external_dependencies">declaring external dependencies</a>.</p> </div> </div> <div class="sect3"> <h4 id="the_pluginmanagement_block_in_settings_scripts_is_now_isolated"><a class="anchor" href="#the_pluginmanagement_block_in_settings_scripts_is_now_isolated"></a><a class="link" href="#the_pluginmanagement_block_in_settings_scripts_is_now_isolated">The <code>pluginManagement</code> block in settings scripts is now isolated</a></h4> <div class="paragraph"> <p>Previously, any <code>pluginManagement {}</code> blocks inside a settings script were executed during the normal execution of the script.</p> </div> <div class="paragraph"> <p>Now, they are executed earlier in a similar manner to <code>buildscript {}</code> or <code>plugins {}</code>. This means that code inside such a block cannot reference anything declared elsewhere in the script.</p> </div> <div class="paragraph"> <p>This change has been made so that <code>pluginManagement</code> configuration can also be applied when resolving plugins for the settings script itself.</p> </div> </div> <div class="sect3"> <h4 id="plugins_and_classes_loaded_in_settings_scripts_are_visible_to_project_scripts_and_buildsrc"><a class="anchor" href="#plugins_and_classes_loaded_in_settings_scripts_are_visible_to_project_scripts_and_buildsrc"></a><a class="link" href="#plugins_and_classes_loaded_in_settings_scripts_are_visible_to_project_scripts_and_buildsrc">Plugins and classes loaded in settings scripts are visible to project scripts and <code>buildSrc</code></a></h4> <div class="paragraph"> <p>Previously, any classes added to the a settings script by using <code>buildscript {}</code> were not visible outside of the script. Now, they are visible to all of the project build scripts.</p> </div> <div class="paragraph"> <p>They are also visible to the <code>buildSrc</code> build script and its settings script.</p> </div> <div class="paragraph"> <p>This change has been made so that plugins applied to the settings script can contribute logic to the entire build.</p> </div> </div> <div class="sect3"> <h4 id="plugin_validation_changes"><a class="anchor" href="#plugin_validation_changes"></a><a class="link" href="#plugin_validation_changes">Plugin validation changes</a></h4> <div class="ulist"> <ul> <li> <p>The <code>validateTaskProperties</code> task is now deprecated, use <code>validatePlugins</code> instead. The new name better reflects the fact that it also validates artifact transform parameters and other non-property definitions.</p> </li> <li> <p>The <code>ValidateTaskProperties</code> type is replaced by <code>ValidatePlugins</code>.</p> </li> <li> <p>The <code>setClasses()</code> method is now removed. Use <code>getClasses().setFrom()</code> instead.</p> </li> <li> <p>The <code>setClasspath()</code> method is also removed. use <code>getClasspath().setFrom()</code> instead.</p> </li> <li> <p>The <a href="../javadoc/org/gradle/plugin/devel/tasks/ValidatePlugins.html#getFailOnWarning--">failOnWarning</a> option is now enabled by default.</p> </li> <li> <p>The following task validation errors now fail the build at runtime and are promoted to errors for <a href="../javadoc/org/gradle/plugin/devel/tasks/ValidatePlugins.html">ValidatePlugins</a>:</p> <div class="ulist"> <ul> <li> <p>A task property is annotated with a property annotation not allowed for tasks, like <code>@InputArtifact</code>.</p> </li> </ul> </div> </li> </ul> </div> </div> <div class="sect3"> <h4 id="changes_to_kotlin_dsl"><a class="anchor" href="#changes_to_kotlin_dsl"></a><a class="link" href="#changes_to_kotlin_dsl">Changes to Kotlin DSL</a></h4> </div> <div class="sect3"> <h4 id="using_the_embedded_kotlin_plugin_now_requires_a_repository"><a class="anchor" href="#using_the_embedded_kotlin_plugin_now_requires_a_repository"></a><a class="link" href="#using_the_embedded_kotlin_plugin_now_requires_a_repository">Using the <code>embedded-kotlin</code> plugin now requires a repository</a></h4> <div class="paragraph"> <p>Just like when using the <code>kotlin-dsl</code> plugin, it is now required to declare a repository where Kotlin dependencies can be found if you apply the <code>embedded-kotlin</code> plugin.</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code data-lang="kotlin">plugins { `embedded-kotlin` } repositories { mavenCentral() }</code></pre> </div> </div> </div> <div class="sect3"> <h4 id="kotlin_dsl_ide_support_now_requires_kotlin_intellij_plugin_1_3_50"><a class="anchor" href="#kotlin_dsl_ide_support_now_requires_kotlin_intellij_plugin_1_3_50"></a><a class="link" href="#kotlin_dsl_ide_support_now_requires_kotlin_intellij_plugin_1_3_50">Kotlin DSL IDE support now requires Kotlin IntelliJ Plugin >= 1.3.50</a></h4> <div class="paragraph"> <p>With Kotlin IntelliJ plugin versions prior to 1.3.50, Kotlin DSL scripts will be wrongly highlighted when the <em>Gradle JVM</em> is set to a version different from the one in <em>Project SDK</em>. Simply upgrade your IDE plugin to a version >= 1.3.50 to restore the correct Kotlin DSL script highlighting behavior.</p> </div> </div> <div class="sect3"> <h4 id="kotlin_dsl_script_base_types_no_longer_extend_project_settings_or_gradle"><a class="anchor" href="#kotlin_dsl_script_base_types_no_longer_extend_project_settings_or_gradle"></a><a class="link" href="#kotlin_dsl_script_base_types_no_longer_extend_project_settings_or_gradle">Kotlin DSL script base types no longer extend <code>Project</code>, <code>Settings</code> or <code>Gradle</code></a></h4> <div class="paragraph"> <p>In previous versions, Kotlin DSL scripts were compiled to classes that implemented one of the three core Gradle configuration interfaces in order to implicitly expose their APIs to scripts. <code>org.gradle.api.Project</code> for project scripts, <code>org.gradle.api.initialization.Settings</code> for settings scripts and <code>org.gradle.api.invocation.Gradle</code> for init scripts.</p> </div> <div class="paragraph"> <p>Having the script instance implement the core Gradle interface of the model object it was supposed to configure was convenient because it made the model object API immediately available to the body of the script but it was also a lie that could cause all sorts of trouble whenever the script itself was used in place of the model object, a project script <strong>was not</strong> a proper <code>Project</code> instance just because it implemented the core <code>Project</code> interface and the same was true for settings and init scripts.</p> </div> <div class="paragraph"> <p>In 6.0 all Kotlin DSL scripts are compiled to classes that implement the newly introduced <code>org.gradle.kotlin.dsl.KotlinScript</code> interface and the corresponding model objects are now available as <em>implicit receivers</em> in the body of the scripts. In other words, a project script behaves as if the body of the script is enclosed within a <code>with(project) { …​ }</code> block, a settings script as if the body of the script is enclosed within a <code>with(settings) { …​ }</code> block and an init script as if the body of the script is enclosed within a <code>with(gradle) { …​ }</code> block. This implies the corresponding model object is also available as a property in the body of the script, the <code>project</code> property for project scripts, the <code>settings</code> property for settings scripts and the <code>gradle</code> property for init scripts.</p> </div> <div class="paragraph"> <p>As part of the change, the <code>SettingsScriptApi</code> interface is no longer implemented by settings scripts and the <code>InitScriptApi</code> interface is no longer implemented by init scripts. They should be replaced with the corresponding model object interfaces, <code>Settings</code> and <code>Gradle</code>.</p> </div> </div> <div class="sect3"> <h4 id="miscellaneous"><a class="anchor" href="#miscellaneous"></a><a class="link" href="#miscellaneous">Miscellaneous</a></h4> </div> <div class="sect3"> <h4 id="javadoc_and_groovydoc_dont_include_timestamps_by_default"><a class="anchor" href="#javadoc_and_groovydoc_dont_include_timestamps_by_default"></a><a class="link" href="#javadoc_and_groovydoc_dont_include_timestamps_by_default">Javadoc and Groovydoc don’t include timestamps by default</a></h4> <div class="paragraph"> <p>Timestamps in the generated documentation have very limited practical use, however they make it impossible to have repeatable documentation builds. Therefore, the <code>Javadoc</code> and <code>Groovydoc</code> tasks are now configured to not include timestamps by default any more.</p> </div> </div> <div class="sect3"> <h4 id="user_provided_config_loc_properties_are_ignored_by_checkstyle"><a class="anchor" href="#user_provided_config_loc_properties_are_ignored_by_checkstyle"></a><a class="link" href="#user_provided_config_loc_properties_are_ignored_by_checkstyle">User provided 'config_loc' properties are ignored by Checkstyle</a></h4> <div class="paragraph"> <p>Gradle always uses <code>configDirectory</code> as the value for 'config_loc' when running Checkstyle.</p> </div> </div> <div class="sect3"> <h4 id="new_tooling_api_progress_event"><a class="anchor" href="#new_tooling_api_progress_event"></a><a class="link" href="#new_tooling_api_progress_event">New Tooling API progress event</a></h4> <div class="paragraph"> <p>In Gradle 6.0, we introduced a new progress event (<a href="../javadoc/org/gradle/tooling/events/test/TestOutputEvent.html">org.gradle.tooling.events.test.TestOutputEvent</a>) to expose the output of test execution. This new event breaks the convention of having a <code>StartEvent</code>-<code>FinishEvent</code> pair to express progress. <code>TaskOutputEvent</code> is a simple <code>ProgressEvent</code>.</p> </div> </div> <div class="sect3"> <h4 id="changes_to_the_task_container_behavior"><a class="anchor" href="#changes_to_the_task_container_behavior"></a><a class="link" href="#changes_to_the_task_container_behavior">Changes to the task container behavior</a></h4> <div class="paragraph"> <p>The following deprecated methods on the task container now result in errors:</p> </div> <div class="ulist"> <ul> <li> <p><code>TaskContainer.add()</code></p> </li> <li> <p><code>TaskContainer.addAll()</code></p> </li> <li> <p><code>TaskContainer.remove()</code></p> </li> <li> <p><code>TaskContainer.removeAll()</code></p> </li> <li> <p><code>TaskContainer.retainAll()</code></p> </li> <li> <p><code>TaskContainer.clear()</code></p> </li> <li> <p><code>TaskContainer.iterator().remove()</code></p> </li> </ul> </div> <div class="paragraph"> <p>Additionally, the following deprecated functionality now results in an error:</p> </div> <div class="ulist"> <ul> <li> <p>Replacing a task that has already been realized.</p> </li> <li> <p>Replacing a registered (unrealized) task with an incompatible type. A compatible type is the same type or a sub-type of the registered type.</p> </li> <li> <p>Replacing a task that has never been registered.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="replaced_and_removed_apis"><a class="anchor" href="#replaced_and_removed_apis"></a><a class="link" href="#replaced_and_removed_apis">Replaced and Removed APIs</a></h4> </div> <div class="sect3"> <h4 id="methods_on_defaulttask_and_projectlayout_replaced_with_objectfactory"><a class="anchor" href="#methods_on_defaulttask_and_projectlayout_replaced_with_objectfactory"></a><a class="link" href="#methods_on_defaulttask_and_projectlayout_replaced_with_objectfactory">Methods on <code>DefaultTask</code> and <code>ProjectLayout</code> replaced with <code>ObjectFactory</code></a></h4> <div class="paragraph"> <p>Use <code>ObjectFactory.fileProperty()</code> instead of the following methods that are now removed:</p> </div> <div class="ulist"> <ul> <li> <p><code>DefaultTask.newInputFile()</code></p> </li> <li> <p><code>DefaultTask.newOutputFile()</code></p> </li> <li> <p><code>ProjectLayout.fileProperty()</code></p> </li> </ul> </div> <div class="paragraph"> <p>Use <code>ObjectFactory.directoryProperty()</code> instead of the following methods that are now removed:</p> </div> <div class="ulist"> <ul> <li> <p><code>DefaultTask.newInputDirectory()</code></p> </li> <li> <p><code>DefaultTask.newOutputDirectory()</code></p> </li> <li> <p><code>ProjectLayout.directoryProperty()</code></p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="annotation_nullable_has_been_removed"><a class="anchor" href="#annotation_nullable_has_been_removed"></a><a class="link" href="#annotation_nullable_has_been_removed">Annotation <code>@Nullable</code> has been removed</a></h4> <div class="paragraph"> <p>The <code>org.gradle.api.Nullable</code> annotation type has been removed. Use <code>javax.annotation.Nullable</code> from JSR-305 instead.</p> </div> </div> <div class="sect3"> <h4 id="the_findbugs_plugin_has_been_removed"><a class="anchor" href="#the_findbugs_plugin_has_been_removed"></a><a class="link" href="#the_findbugs_plugin_has_been_removed">The FindBugs plugin has been removed</a></h4> <div class="paragraph"> <p>The deprecated FindBugs plugin has been removed. As an alternative, you can use the <a href="https://plugins.gradle.org/plugin/com.github.spotbugs">SpotBugs plugin</a> from the <a href="https://plugins.gradle.org/search?term=spotbugs">Gradle Plugin Portal</a>.</p> </div> </div> <div class="sect3"> <h4 id="the_jdepend_plugin_has_been_removed"><a class="anchor" href="#the_jdepend_plugin_has_been_removed"></a><a class="link" href="#the_jdepend_plugin_has_been_removed">The JDepend plugin has been removed</a></h4> <div class="paragraph"> <p>The deprecated JDepend plugin has been removed. There are a number of community-provided plugins for code and architecture analysis available on the <a href="https://plugins.gradle.org">Gradle Plugin Portal</a>.</p> </div> </div> <div class="sect3"> <h4 id="the_osgi_plugin_has_been_removed"><a class="anchor" href="#the_osgi_plugin_has_been_removed"></a><a class="link" href="#the_osgi_plugin_has_been_removed">The OSGI plugin has been removed</a></h4> <div class="paragraph"> <p>The deprecated OSGI plugin has been removed. There are a number of community-provided OSGI plugins available on the <a href="https://plugins.gradle.org/search?term=osgi">Gradle Plugin Portal</a>.</p> </div> </div> <div class="sect3"> <h4 id="the_announce_and_build_announcements_plugins_have_been_removed"><a class="anchor" href="#the_announce_and_build_announcements_plugins_have_been_removed"></a><a class="link" href="#the_announce_and_build_announcements_plugins_have_been_removed">The announce and build-announcements plugins have been removed</a></h4> <div class="paragraph"> <p>The deprecated announce and build-announcements plugins have been removed. There are a number of community-provided plugins for sending out notifications available on the <a href="https://plugins.gradle.org">Gradle Plugin Portal</a>.</p> </div> </div> <div class="sect3"> <h4 id="the_compare_gradle_builds_plugin_has_been_removed"><a class="anchor" href="#the_compare_gradle_builds_plugin_has_been_removed"></a><a class="link" href="#the_compare_gradle_builds_plugin_has_been_removed">The Compare Gradle Builds plugin has been removed</a></h4> <div class="paragraph"> <p>The deprecated Compare Gradle Builds plugin has been removed. Please use <a href="https://scans.gradle.com/">build scans</a> for build analysis and comparison.</p> </div> </div> <div class="sect3"> <h4 id="the_play_plugins_have_been_removed"><a class="anchor" href="#the_play_plugins_have_been_removed"></a><a class="link" href="#the_play_plugins_have_been_removed">The Play plugins have been removed</a></h4> <div class="paragraph"> <p>The deprecated Play plugin has been removed. An external replacement, the <a href="https://gradle.github.io/playframework">Play Framework plugin</a>, is available from the plugin portal.</p> </div> </div> <div class="sect3"> <h4 id="method_abstractcompile_compile_method_has_been_removed"><a class="anchor" href="#method_abstractcompile_compile_method_has_been_removed"></a><a class="link" href="#method_abstractcompile_compile_method_has_been_removed">Method <code>AbstractCompile.compile()</code> method has been removed</a></h4> <div class="paragraph"> <p>The abstract method <code>compile()</code> is no longer declared by <code>AbstractCompile</code>.</p> </div> <div class="paragraph"> <p>Tasks extending <code>AbstractCompile</code> can implement their own <code>@TaskAction</code> method with the name of their choosing.</p> </div> <div class="paragraph"> <p>They are also free to add a method annotated with <code>@TaskAction</code> using an <code>InputChanges</code> parameter without having to implement a parameter-less one as well.</p> </div> </div> <div class="sect3"> <h4 id="other_deprecated_behaviors_and_apis"><a class="anchor" href="#other_deprecated_behaviors_and_apis"></a><a class="link" href="#other_deprecated_behaviors_and_apis">Other Deprecated Behaviors and APIs</a></h4> <div class="ulist"> <ul> <li> <p>The <code>org.gradle.util.internal.GUtil.savePropertiesNoDateComment</code> has been removed. There is no public replacement for this internal method.</p> </li> <li> <p>The deprecated class <code>org.gradle.api.tasks.compile.CompilerArgumentProvider</code> has been removed. Use <a href="../javadoc/org/gradle/process/CommandLineArgumentProvider.html">org.gradle.process.CommandLineArgumentProvider</a> instead.</p> </li> <li> <p>The deprecated class <code>org.gradle.api.ConventionProperty</code> has been removed. Use <a href="../javadoc/org/gradle/api/provider/Provider.html">Providers</a> instead of convention properties.</p> </li> <li> <p>The deprecated class <code>org.gradle.reporting.DurationFormatter</code> has been removed.</p> </li> <li> <p>The bridge method <code>org.gradle.api.tasks.TaskInputs.property(String name, @Nullable Object value)</code> returning <code>TaskInputs</code> has been removed. A plugin using the method must be compiled with Gradle 4.3 to work on Gradle 6.0.</p> </li> <li> <p>The following setters have been removed from <code>JacocoReportBase</code>:</p> <div class="ulist"> <ul> <li> <p><a href="../dsl/org.gradle.testing.jacoco.tasks.JacocoReport.html#org.gradle.testing.jacoco.tasks.JacocoReport:executionData">executionData</a> - use <code>getExecutionData().setFrom()</code> instead.</p> </li> <li> <p><a href="../dsl/org.gradle.testing.jacoco.tasks.JacocoReport.html#org.gradle.testing.jacoco.tasks.JacocoReport:sourceDirectories">sourceDirectories</a> - use <code>getSourceDirectories().setFrom()</code> instead.</p> </li> <li> <p><a href="../dsl/org.gradle.testing.jacoco.tasks.JacocoReport.html#org.gradle.testing.jacoco.tasks.JacocoReport:classDirectories">classDirectories</a> - use <code>getClassDirectories().setFrom()</code> instead.</p> </li> <li> <p><a href="../dsl/org.gradle.testing.jacoco.tasks.JacocoReport.html#org.gradle.testing.jacoco.tasks.JacocoReport:additionalClassDirs">additionalClassDirs</a> - use <code>getAdditionalClassDirs().setFrom()</code> instead.</p> </li> <li> <p><a href="../dsl/org.gradle.testing.jacoco.tasks.JacocoReport.html#org.gradle.testing.jacoco.tasks.JacocoReport:additionalSourceDirs">additionalSourceDirs</a> - use <code>getAdditionalSourceDirs().setFrom()</code> instead.</p> </li> </ul> </div> </li> <li> <p>The <code>append</code> property on <code>JacocoTaskExtension</code> has been removed. <code>append</code> is now always configured to be true for the Jacoco agent.</p> </li> <li> <p>The <code>configureDefaultOutputPathForJacocoMerge</code> method on <code>JacocoPlugin</code> has been removed. The method was never meant to be public.</p> </li> <li> <p>File paths in <a href="../javadoc/org/gradle/plugins/ear/descriptor/DeploymentDescriptor.html#getFileName--">deployment descriptor file name</a> for the ear plugin are not allowed any more. Use a simple name, like <code>application.xml</code>, instead.</p> </li> <li> <p>The <code>org.gradle.testfixtures.ProjectBuilder</code> constructor has been removed. Please use <code>ProjectBuilder.builder()</code> instead.</p> </li> <li> <p>When <a href="groovy_plugin.html#sec:incremental_groovy_compilation">incremental Groovy compilation</a> is enabled, a wrong configuration of the source roots or enabling Java annotation for Groovy now fails the build. Disable incremental Groovy compilation when you want to compile in those cases.</p> </li> <li> <p><code>ComponentSelectionRule</code> no longer can inject the metadata or ivy descriptor. Use the methods on the <a href="resolution_rules.html#sec:component-selection-rules"><code>ComponentSelection</code> parameter</a> instead.</p> </li> <li> <p>Declaring an <a href="custom_tasks.html#incremental_tasks">incremental task</a> without declaring outputs is now an error. Declare file outputs or use <a href="../javadoc/org/gradle/api/tasks/TaskOutputs.html#upToDateWhen-groovy.lang.Closure-">TaskOutputs.upToDateWhen()</a> instead.</p> </li> <li> <p>The <code>getEffectiveAnnotationProcessorPath()</code> method is removed from the <code>JavaCompile</code> and <code>ScalaCompile</code> tasks.</p> </li> <li> <p>Changing the value of a task property with type <code>Property<T></code> after the task has started execution now results in an error.</p> </li> <li> <p>The <code>isLegacyLayout()</code> method is removed from <code>SourceSetOutput</code>.</p> </li> <li> <p>The map returned by <code>TaskInputs.getProperties()</code> is now unmodifiable. Trying to modify it will result in an <code>UnsupportedOperationException</code> being thrown.</p> </li> <li> <p>There are slight changes in the incubating <a href="component_capabilities.html#sec:selecting-between-candidates">capabilities resolution</a> API, which has been introduced in 5.6, to also allow variant selection based on variant name</p> </li> </ul> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_5.6"><a class="anchor" href="#changes_5.6"></a><a class="link" href="#changes_5.6">Upgrading from 5.5 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="deprecations_2"><a class="anchor" href="#deprecations_2"></a><a class="link" href="#deprecations_2">Deprecations</a></h3> <div class="sect3"> <h4 id="changing_the_contents_of_configurablefilecollection_task_properties_after_task_starts_execution"><a class="anchor" href="#changing_the_contents_of_configurablefilecollection_task_properties_after_task_starts_execution"></a><a class="link" href="#changing_the_contents_of_configurablefilecollection_task_properties_after_task_starts_execution">Changing the contents of <code>ConfigurableFileCollection</code> task properties after task starts execution</a></h4> <div class="paragraph"> <p>When a task property has type <code>ConfigurableFileCollection</code>, then the file collection referenced by the property will ignore changes made to the contents of the collection once the task starts execution. This has two benefits. Firstly, this prevents accidental changes to the property value during task execution which can cause Gradle up-to-date checks and build cache lookup using different values to those used by the task action. Secondly, this improves performance as Gradle can calculate the value once and cache the result.</p> </div> <div class="paragraph"> <p>This will become an error in Gradle 6.0.</p> </div> </div> <div class="sect3"> <h4 id="creating_signoperation_instances"><a class="anchor" href="#creating_signoperation_instances"></a><a class="link" href="#creating_signoperation_instances">Creating <code>SignOperation</code> instances</a></h4> <div class="paragraph"> <p>Creating <code>SignOperation</code> instances directly is now deprecated. Instead, the methods of <code>SigningExtension</code> should be used to create these instances.</p> </div> <div class="paragraph"> <p>This will become an error in Gradle 6.0.</p> </div> </div> <div class="sect3"> <h4 id="declaring_an_incremental_task_without_outputs"><a class="anchor" href="#declaring_an_incremental_task_without_outputs"></a><a class="link" href="#declaring_an_incremental_task_without_outputs">Declaring an incremental task without outputs</a></h4> <div class="paragraph"> <p>Declaring an <a href="custom_tasks.html#incremental_tasks">incremental task</a> without declaring outputs is now deprecated. Declare file outputs or use <a href="../javadoc/org/gradle/api/tasks/TaskOutputs.html#upToDateWhen-groovy.lang.Closure-">TaskOutputs.upToDateWhen()</a> instead.</p> </div> <div class="paragraph"> <p>This will become an error in Gradle 6.0.</p> </div> </div> <div class="sect3"> <h4 id="method_workerexecutor_submit_is_deprecated"><a class="anchor" href="#method_workerexecutor_submit_is_deprecated"></a><a class="link" href="#method_workerexecutor_submit_is_deprecated">Method <code>WorkerExecutor.submit()</code> is deprecated</a></h4> <div class="paragraph"> <p>The <code>WorkerExecutor.submit()</code> method is now deprecated. The new <code>noIsolation()</code>, <code>classLoaderIsolation()</code> and <code>processIsolation()</code> methods should now be used to submit work. See <a href="worker_api.html#tasks_parallel_worker">the section on the Worker API</a> for more information on using these methods.</p> </div> <div class="paragraph"> <p><code>WorkerExecutor.submit()</code> will be removed in Gradle 8.0.</p> </div> </div> </div> <div class="sect2"> <h3 id="potential_breaking_changes_2"><a class="anchor" href="#potential_breaking_changes_2"></a><a class="link" href="#potential_breaking_changes_2">Potential breaking changes</a></h3> <div class="sect3"> <h4 id="task_dependencies_are_honored_for_task_input_properties_whose_value_is_a_property"><a class="anchor" href="#task_dependencies_are_honored_for_task_input_properties_whose_value_is_a_property"></a><a class="link" href="#task_dependencies_are_honored_for_task_input_properties_whose_value_is_a_property">Task dependencies are honored for task <code>@Input</code> properties whose value is a <code>Property</code></a></h4> <div class="paragraph"> <p>Previously, task dependencies would be ignored for task <code>@Input</code> properties of type <code>Property<T></code>. These are now honored, so that it is possible to attach a task output property to a task <code>@Input</code> property.</p> </div> <div class="paragraph"> <p>This may introduce unexpected cycles in the task dependency graph, where the value of an output property is mapped to produce a value for an input property.</p> </div> </div> <div class="sect3"> <h4 id="declaring_task_dependencies_using_a_file_provider_that_does_not_represent_a_task_output"><a class="anchor" href="#declaring_task_dependencies_using_a_file_provider_that_does_not_represent_a_task_output"></a><a class="link" href="#declaring_task_dependencies_using_a_file_provider_that_does_not_represent_a_task_output">Declaring task dependencies using a file <code>Provider</code> that does not represent a task output</a></h4> <div class="paragraph"> <p>Previously, it was possible to pass <code>Task.dependsOn()</code> a <code>Provider<File></code>, <code>Provider<RegularFile></code> or <code>Provider<Directory></code> instance that did not represent a task output. These providers would be silently ignored.</p> </div> <div class="paragraph"> <p>This is now an error because Gradle does not know how to build files that are not task outputs.</p> </div> <div class="paragraph"> <p><strong>Note</strong> that it is still possible to pass <code>Task.dependsOn()</code> a <code>Provider</code> that returns a file and that represents a task output, for example <code>myTask.dependsOn(jar.archiveFile)</code> or <code>myTask.dependsOn(taskProvider.flatMap { it.outputDirectory })</code>, when the <code>Provider</code> is an annotated <code>@OutputFile</code> or <code>@OutputDirectory</code> property of a task.</p> </div> </div> <div class="sect3"> <h4 id="setting_property_value_to_null_uses_the_property_convention"><a class="anchor" href="#setting_property_value_to_null_uses_the_property_convention"></a><a class="link" href="#setting_property_value_to_null_uses_the_property_convention">Setting <code>Property</code> value to <code>null</code> uses the property convention</a></h4> <div class="paragraph"> <p>Previously, calling <code>Property.set(null)</code> would always reset the value of the property to 'not defined'. Now, the convention that is associated with the property using the <code>convention()</code> method will be used to determine the value of the property.</p> </div> </div> <div class="sect3"> <h4 id="enhanced_validation_of_names_for_publishing_publications_and_publishing_repositories"><a class="anchor" href="#enhanced_validation_of_names_for_publishing_publications_and_publishing_repositories"></a><a class="link" href="#enhanced_validation_of_names_for_publishing_publications_and_publishing_repositories">Enhanced validation of names for <code>publishing.publications</code> and <code>publishing.repositories</code></a></h4> <div class="paragraph"> <p>The repository and publication names are used to construct task names for publishing. It was possible to supply a name that would result in an invalid task name. Names for publications and repositories are now restricted to <code>[A-Za-z0-9_\\-.]+</code>.</p> </div> </div> <div class="sect3"> <h4 id="restricted_worker_api_classloader_and_process_classpath"><a class="anchor" href="#restricted_worker_api_classloader_and_process_classpath"></a><a class="link" href="#restricted_worker_api_classloader_and_process_classpath">Restricted Worker API classloader and process classpath</a></h4> <div class="paragraph"> <p>Gradle now prevents internal dependencies (like Guava) from leaking into the classpath used by Worker API actions. This fixes <a href="https://github.com/gradle/gradle/issues/3698">an issue</a> where a worker needs to use a dependency that is also used by Gradle internally.</p> </div> <div class="paragraph"> <p>In previous releases, it was possible to rely on these leaked classes. Plugins relying on this behavior will now fail. To fix the plugin, the worker should explicitly include all required dependencies in its classpath.</p> </div> </div> <div class="sect3"> <h4 id="default_pmd_version_upgraded_to_6_15_0"><a class="anchor" href="#default_pmd_version_upgraded_to_6_15_0"></a><a class="link" href="#default_pmd_version_upgraded_to_6_15_0">Default PMD version upgraded to 6.15.0</a></h4> <div class="paragraph"> <p><a href="pmd_plugin.html#pmd_plugin">The PMD plugin</a> has been upgraded to use <a href="https://pmd.github.io/pmd-6.15.0/pmd_release_notes.html">PMD version 6.15.0</a> instead of 6.8.0 by default.</p> </div> <div class="paragraph"> <p>Contributed by <a href="https://github.com/wreulicke">wreulicke</a></p> </div> </div> <div class="sect3"> <h4 id="configuration_copies_have_unique_names"><a class="anchor" href="#configuration_copies_have_unique_names"></a><a class="link" href="#configuration_copies_have_unique_names">Configuration copies have unique names</a></h4> <div class="paragraph"> <p>Previously, all copies of a configuration always had the name <code><OriginConfigurationName>Copy</code>. Now when creating multiple copies, each will have a unique name by adding an index starting from the second copy. (e.g. <code>CompileOnlyCopy2</code>)</p> </div> </div> <div class="sect3"> <h4 id="changed_classpath_filtering_for_eclipse"><a class="anchor" href="#changed_classpath_filtering_for_eclipse"></a><a class="link" href="#changed_classpath_filtering_for_eclipse">Changed classpath filtering for Eclipse</a></h4> <div class="paragraph"> <p>Gradle 5.6 no longer supplies custom classpath attributes in the Eclipse model. Instead, it provides the attributes for <a href="https://www.eclipse.org/eclipse/news/4.8/jdt.php#jdt-test-sources">Eclipse test sources</a>. This change requires Buildship version 3.1.1 or later.</p> </div> </div> <div class="sect3"> <h4 id="embedded_kotlin_upgraded_to_1_3_41"><a class="anchor" href="#embedded_kotlin_upgraded_to_1_3_41"></a><a class="link" href="#embedded_kotlin_upgraded_to_1_3_41">Embedded Kotlin upgraded to 1.3.41</a></h4> <div class="paragraph"> <p>Gradle Kotlin DSL scripts and Gradle Plugins authored using the <code>kotlin-dsl</code> plugin are now compiled using Kotlin 1.3.41.</p> </div> <div class="paragraph"> <p>Please see the Kotlin <a href="https://blog.jetbrains.com/kotlin/2019/06/kotlin-1-3-40-released/">blog post</a> and <a href="https://github.com/JetBrains/kotlin/blob/1.3.40/ChangeLog.md">changelog</a> for more information about the included changes.</p> </div> <div class="paragraph"> <p>The minimum supported Kotlin Gradle Plugin version is now 1.2.31. Previously it was 1.2.21.</p> </div> </div> <div class="sect3"> <h4 id="automatic_capability_conflict_resolution"><a class="anchor" href="#automatic_capability_conflict_resolution"></a><a class="link" href="#automatic_capability_conflict_resolution">Automatic capability conflict resolution</a></h4> <div class="paragraph"> <p>Previous versions of Gradle would automatically select, in case of capability conflicts, the module which has the highest capability version. Starting from 5.6, this is an opt-in behavior that can be activated using:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>configurations.all { resolutionStrategy.capabilitiesResolution.all { selectHighestVersion() } }</code></pre> </div> </div> <div class="paragraph"> <p>See <a href="component_capabilities.html#capabilities">the capabilities section of the documentation</a> for more options.</p> </div> </div> <div class="sect3"> <h4 id="file_removal_operations_dont_follow_symlinked_directories"><a class="anchor" href="#file_removal_operations_dont_follow_symlinked_directories"></a><a class="link" href="#file_removal_operations_dont_follow_symlinked_directories">File removal operations don’t follow symlinked directories</a></h4> <div class="paragraph"> <p>When Gradle has to remove the output files of a task for various reasons, it will not follow symlinked directories. The symlink itself will be deleted, but the contents of the linked directory will stay intact.</p> </div> </div> </div> <div class="sect2"> <h3 id="disabled_debug_argument_parsing_in_javaexec"><a class="anchor" href="#disabled_debug_argument_parsing_in_javaexec"></a><a class="link" href="#disabled_debug_argument_parsing_in_javaexec">Disabled debug argument parsing in JavaExec</a></h3> <div class="paragraph"> <p>Gradle 5.6 introduced a new DSL element (<code>JavaForkOptions.debugOptions(Action<JavaDebugOptions>)</code>) to configure debug properties for forked Java processes. Due to this change, Gradle no longer parses debug-related JVM arguments. Consequently, <code>JavaForkOptions.getDebu()</code> no longer returns <code>true</code> if the <code>-Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=5005</code> or the <code>-agentlib:jdwp=transport=dt_socket,server=y,suspend=y,address=5005</code> argument is specified to the process.</p> </div> </div> <div class="sect2"> <h3 id="scala_2_9_and_zinc_compiler"><a class="anchor" href="#scala_2_9_and_zinc_compiler"></a><a class="link" href="#scala_2_9_and_zinc_compiler">Scala 2.9 and Zinc compiler</a></h3> <div class="paragraph"> <p>Gradle no longer supports building applications using Scala 2.9.</p> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_5.5"><a class="anchor" href="#changes_5.5"></a><a class="link" href="#changes_5.5">Upgrading from 5.4 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="deprecations_3"><a class="anchor" href="#deprecations_3"></a><a class="link" href="#deprecations_3">Deprecations</a></h3> <div class="sect3"> <h4 id="play"><a class="anchor" href="#play"></a><a class="link" href="#play">Play</a></h4> <div class="paragraph"> <p>The built-in <a href="play_plugin.html#play_plugin">Play plugin</a> has been deprecated and will be replaced by a new <a href="https://gradle.github.io/playframework">Play Framework plugin</a> available from the plugin portal.</p> </div> </div> <div class="sect3"> <h4 id="build_comparison"><a class="anchor" href="#build_comparison"></a><a class="link" href="#build_comparison">Build Comparison</a></h4> <div class="paragraph"> <p>The <em>build comparison</em> plugin has been deprecated and will be removed in the next major version of Gradle.</p> </div> <div class="paragraph"> <p><a href="https://gradle.com/build-scans">Build scans</a> show much deeper insights into your build and you can use <a href="https://gradle.com/develocity">Develocity</a> to directly compare two build’s build-scans.</p> </div> </div> </div> <div class="sect2"> <h3 id="potential_breaking_changes_3"><a class="anchor" href="#potential_breaking_changes_3"></a><a class="link" href="#potential_breaking_changes_3">Potential breaking changes</a></h3> <div class="sect3"> <h4 id="user_supplied_eclipse_project_names_may_be_ignored_on_conflict"><a class="anchor" href="#user_supplied_eclipse_project_names_may_be_ignored_on_conflict"></a><a class="link" href="#user_supplied_eclipse_project_names_may_be_ignored_on_conflict">User supplied Eclipse project names may be ignored on conflict</a></h4> <div class="paragraph"> <p>Project names configured via <a href="../javadoc/org/gradle/plugins/ide/eclipse/model/EclipseProject.html"><code>EclipseProject.setName(…​)</code></a> were honored by Gradle and Buildship in all cases, even when the names caused conflicts and import/synchronization errors.</p> </div> <div class="paragraph"> <p>Gradle can now deduplicate these names if they conflict with other project names in an Eclipse workspace. This may lead to different Eclipse project names for projects with user-specified names.</p> </div> <div class="paragraph"> <p>The upcoming 3.1.1 version of Buildship is required to take advantage of this behavior.</p> </div> <div class="paragraph"> <p>Contributed by <a href="https://github.com/fraenkelc">Christian Fränkel</a></p> </div> </div> <div class="sect3"> <h4 id="default_jacoco_version_upgraded_to_0_8_4"><a class="anchor" href="#default_jacoco_version_upgraded_to_0_8_4"></a><a class="link" href="#default_jacoco_version_upgraded_to_0_8_4">Default JaCoCo version upgraded to 0.8.4</a></h4> <div class="paragraph"> <p><a href="jacoco_plugin.html#jacoco_plugin">The JaCoCo plugin</a> has been upgraded to use <a href="http://www.jacoco.org/jacoco/trunk/doc/changes.html">JaCoCo version 0.8.4</a> instead of 0.8.3 by default.</p> </div> <div class="paragraph"> <p>Contributed by <a href="https://github.com/Godin">Evgeny Mandrikov</a></p> </div> </div> <div class="sect3"> <h4 id="embedded_ant_version_upgraded_to_1_9_14"><a class="anchor" href="#embedded_ant_version_upgraded_to_1_9_14"></a><a class="link" href="#embedded_ant_version_upgraded_to_1_9_14">Embedded Ant version upgraded to 1.9.14</a></h4> <div class="paragraph"> <p>The version of Ant distributed with Gradle has been upgraded to <a href="https://archive.apache.org/dist/ant/RELEASE-NOTES-1.9.14.html">1.9.14</a> from 1.9.13.</p> </div> </div> <div class="sect3"> <h4 id="type_dependencyhandler_now_statically_exposes_extensionaware"><a class="anchor" href="#type_dependencyhandler_now_statically_exposes_extensionaware"></a><a class="link" href="#type_dependencyhandler_now_statically_exposes_extensionaware">Type <code>DependencyHandler</code> now statically exposes <code>ExtensionAware</code></a></h4> <div class="paragraph"> <p>This affects Kotlin DSL build scripts that make use of <code>ExtensionAware</code> extension members such as the <code>extra</code> properties accessor inside the <code>dependencies {}</code> block. The receiver for those members will no longer be the enclosing <code>Project</code> instance but the <code>dependencies</code> object itself, the innermost <code>ExtensionAware</code> conforming receiver. In order to address <code>Project</code> extra properties inside <code>dependencies {}</code> the receiver must be explicitly qualified i.e. <code>project.extra</code> instead of just <code>extra</code>. Affected extensions also include <code>the<T>()</code> and <code>configure<T>(T.() → Unit)</code>.</p> </div> </div> <div class="sect3"> <h4 id="improved_processing_of_dependency_excludes"><a class="anchor" href="#improved_processing_of_dependency_excludes"></a><a class="link" href="#improved_processing_of_dependency_excludes">Improved processing of dependency excludes</a></h4> <div class="paragraph"> <p>Previous versions of Gradle could, in some complex dependency graphs, have a wrong result or a randomized dependency order when lots of excludes were present. To mitigate this, the algorithm that computes exclusions has been rewritten. In some rare cases this may cause some differences in resolution, due to the correctness changes.</p> </div> </div> <div class="sect3"> <h4 id="improved_classpath_separation_for_worker_processes"><a class="anchor" href="#improved_classpath_separation_for_worker_processes"></a><a class="link" href="#improved_classpath_separation_for_worker_processes">Improved classpath separation for worker processes</a></h4> <div class="paragraph"> <p>The system classpath for worker daemons started by the <a href="worker_api.html#worker_api">Worker API</a> when using <code>PROCESS</code> isolation has been reduced to a minimum set of Gradle infrastructure. User code is still segregated into a separate classloader to isolate it from the Gradle runtime. This should be a transparent change for tasks using the worker API, but previous versions of Gradle mixed user code and Gradle internals in the worker process. Worker actions that rely on things like the <code>java.class.path</code> system property may be affected, since <code>java.class.path</code> now represents only the classpath of the Gradle internals.</p> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_5.4"><a class="anchor" href="#changes_5.4"></a><a class="link" href="#changes_5.4">Upgrading from 5.3 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="deprecations_4"><a class="anchor" href="#deprecations_4"></a><a class="link" href="#deprecations_4">Deprecations</a></h3> <div class="sect3"> <h4 id="using_custom_local_build_cache_implementations"><a class="anchor" href="#using_custom_local_build_cache_implementations"></a><a class="link" href="#using_custom_local_build_cache_implementations">Using custom local build cache implementations</a></h4> <div class="paragraph"> <p>Using a custom build cache implementation for the local build cache is now deprecated. The only allowed type will be <code>DirectoryBuildCache</code> going forward. There is no change in the support for using custom build cache implementations as the remote build cache.</p> </div> </div> </div> <div class="sect2"> <h3 id="potential_breaking_changes_4"><a class="anchor" href="#potential_breaking_changes_4"></a><a class="link" href="#potential_breaking_changes_4">Potential breaking changes</a></h3> <div class="sect3"> <h4 id="use_https_when_configuring_google_hosted_libraries_via_googleapis"><a class="anchor" href="#use_https_when_configuring_google_hosted_libraries_via_googleapis"></a><a class="link" href="#use_https_when_configuring_google_hosted_libraries_via_googleapis">Use HTTPS when configuring Google Hosted Libraries via <code>googleApis()</code></a></h4> <div class="paragraph"> <p>The Google Hosted Libraries URL accessible via <code>JavaScriptRepositoriesExtension#GOOGLE_APIS_REPO_URL</code> was changed to use the HTTPS protocol. The change also affect the Ivy repository configured via <code>googleApis()</code>.</p> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_5.3"><a class="anchor" href="#changes_5.3"></a><a class="link" href="#changes_5.3">Upgrading from 5.2 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="potential_breaking_changes_5"><a class="anchor" href="#potential_breaking_changes_5"></a><a class="link" href="#potential_breaking_changes_5">Potential breaking changes</a></h3> <div class="sect3"> <h4 id="bug_fixes_in_platform_resolution"><a class="anchor" href="#bug_fixes_in_platform_resolution"></a><a class="link" href="#bug_fixes_in_platform_resolution">Bug fixes in platform resolution</a></h4> <div class="paragraph"> <p>There was a bug from Gradle 5.0 to 5.2.1 (included) where enforced platforms would potentially include dependencies instead of constraints. This would happen whenever a POM file defined both dependencies and "constraints" (via <code><dependencyManagement></code>) and that you used <code>enforcedPlatform</code>. Gradle 5.3 fixes this bug, meaning that you might have differences in the resolution result if you relied on this broken behavior. Similarly, Gradle 5.3 will no longer try to download jars for <code>platform</code> and <code>enforcedPlatform</code> dependencies (as they should only bring in constraints).</p> </div> </div> <div class="sect3"> <h4 id="automatic_target_jvm_version"><a class="anchor" href="#automatic_target_jvm_version"></a><a class="link" href="#automatic_target_jvm_version">Automatic target JVM version</a></h4> <div class="paragraph"> <p>If you apply any of the Java plugins, Gradle will now do its best to select dependencies which match the target compatibility of the module being compiled. What it means, in practice, is that if you have module A built for Java 8, and module B built for Java 8, then there’s no change. However if B is built for Java 9+, then it’s not binary compatible anymore, and Gradle would complain with an error message like the following:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>Unable to find a matching variant of project :producer: - Variant 'apiElements' capability test:producer:unspecified: - Provides org.gradle.dependency.bundling 'external' - Required org.gradle.jvm.version '8' and found incompatible value '9'. - Required org.gradle.usage 'java-api' and found value 'java-api-jars'. - Variant 'runtimeElements' capability test:producer:unspecified: - Provides org.gradle.dependency.bundling 'external' - Required org.gradle.jvm.version '8' and found incompatible value '9'. - Required org.gradle.usage 'java-api' and found value 'java-runtime-jars'.</code></pre> </div> </div> <div class="paragraph"> <p>In general, this is a sign that your project is misconfigured and that your dependencies are not compatible. However, there are cases where you still may want to do this, for example when only a <em>subset</em> of classes of your module actually need the Java 9 dependencies, and are not intended to be used on earlier releases. Java in general doesn’t encourage you to do this (you should split your module instead), but if you face this problem, you can workaround by disabling this new behavior on the consumer side:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>java { disableAutoTargetJvm() }</code></pre> </div> </div> </div> <div class="sect3"> <h4 id="bug_fix_in_maven_ivy_interoperability_with_dependency_substitution"><a class="anchor" href="#bug_fix_in_maven_ivy_interoperability_with_dependency_substitution"></a><a class="link" href="#bug_fix_in_maven_ivy_interoperability_with_dependency_substitution">Bug fix in Maven / Ivy interoperability with dependency substitution</a></h4> <div class="paragraph"> <p>If you have a Maven dependency pointing to an Ivy dependency where the <code>default</code> configuration dependencies do not match the <code>compile</code> + <code>runtime</code> + <code>master</code> ones <em>and</em> that Ivy dependency was substituted (using a <code>resolutionStrategy.force</code>, <code>resolutionStrategy.eachDependency</code> or <code>resolutionStrategy.dependencySubstitution</code>) then this fix will impact you. The legacy behaviour of Gradle, prior to 5.0, was still in place instead of being replaced by the changes introduced by improved pom support.</p> </div> </div> <div class="sect3"> <h4 id="delete_operations_correctly_handle_symbolic_links_on_windows"><a class="anchor" href="#delete_operations_correctly_handle_symbolic_links_on_windows"></a><a class="link" href="#delete_operations_correctly_handle_symbolic_links_on_windows">Delete operations correctly handle symbolic links on Windows</a></h4> <div class="paragraph"> <p>Gradle no longer ignores the <code>followSymlink</code> option on Windows for the <code>clean</code> task, all <code>Delete</code> tasks, and <code>project.delete {}</code> operations in the presence of junction points and symbolic links.</p> </div> </div> <div class="sect3"> <h4 id="fix_in_publication_of_additional_artifacts"><a class="anchor" href="#fix_in_publication_of_additional_artifacts"></a><a class="link" href="#fix_in_publication_of_additional_artifacts">Fix in publication of additional artifacts</a></h4> <div class="paragraph"> <p>In previous Gradle versions, additional artifacts registered at the project level were not published by <code>maven-publish</code> or <code>ivy-publish</code> unless they were also added as artifacts in the publication configuration.</p> </div> <div class="paragraph"> <p>With Gradle 5.3, these artifacts are now properly accounted for and published.</p> </div> <div class="paragraph"> <p>This means that artifacts that are registered both on the project <em>and</em> the publication, Ivy or Maven, will cause publication to fail since it will create duplicate entries. The fix is to remove these artifacts from the publication configuration.</p> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_5.2"><a class="anchor" href="#changes_5.2"></a><a class="link" href="#changes_5.2">Upgrading from 5.1 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="potential_breaking_changes_6"><a class="anchor" href="#potential_breaking_changes_6"></a><a class="link" href="#potential_breaking_changes_6">Potential breaking changes</a></h3> <div class="paragraph"> <p>none</p> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_5.1"><a class="anchor" href="#changes_5.1"></a><a class="link" href="#changes_5.1">Upgrading from 5.0 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="deprecations_5"><a class="anchor" href="#deprecations_5"></a><a class="link" href="#deprecations_5">Deprecations</a></h3> <div class="paragraph"> <p>Follow the API links to learn how to deal with these deprecations (if no extra information is provided here):</p> </div> <div class="ulist"> <ul> <li> <p>Setters for <code>classes</code> and <code>classpath</code> on <code>org.gradle.plugin.devel.tasks.ValidateTaskProperties</code> (removed)</p> </li> <li> <p>There should not be setters for lazy properties like <a href="../javadoc/org/gradle/api/file/ConfigurableFileCollection.html"><code>ConfigurableFileCollection</code></a>. Use <code>setFrom</code> instead. For example,</p> </li> </ul> </div> <div class="listingblock"> <div class="content"> <pre> validateTaskProperties.getClasses().setFrom(fileCollection) validateTaskProperties.getClasspath().setFrom(fileCollection)</pre> </div> </div> </div> <div class="sect2"> <h3 id="potential_breaking_changes_7"><a class="anchor" href="#potential_breaking_changes_7"></a><a class="link" href="#potential_breaking_changes_7">Potential breaking changes</a></h3> <div class="paragraph"> <p>The following changes were not previously deprecated:</p> </div> <div class="sect3"> <h4 id="signing_api_changes"><a class="anchor" href="#signing_api_changes"></a><a class="link" href="#signing_api_changes">Signing API changes</a></h4> <div class="paragraph"> <p>Input and output files of <code>Sign</code> tasks are now tracked via <code>Signature.getToSign()</code> and <code>Signature.getFile()</code>, respectively.</p> </div> </div> <div class="sect3"> <h4 id="collection_properties_default_to_empty_collection"><a class="anchor" href="#collection_properties_default_to_empty_collection"></a><a class="link" href="#collection_properties_default_to_empty_collection">Collection properties default to empty collection</a></h4> <div class="paragraph"> <p>In Gradle 5.0, the collection property instances created using <code>ObjectFactory</code> would have no value defined, requiring plugin authors to explicitly set an initial value. This proved to be awkward and error prone so <code>ObjectFactory</code> now returns instances with an empty collection as their initial value.</p> </div> </div> <div class="sect3"> <h4 id="worker_api_working_directory_of_a_worker_can_no_longer_be_set"><a class="anchor" href="#worker_api_working_directory_of_a_worker_can_no_longer_be_set"></a><a class="link" href="#worker_api_working_directory_of_a_worker_can_no_longer_be_set">Worker API: working directory of a worker can no longer be set</a></h4> <div class="paragraph"> <p>Since JDK 11 no longer supports changing the working directory of a running process, setting the working directory of a worker via its fork options is now prohibited. All workers now use the same working directory to enable reuse. Please pass files and directories as arguments instead. See examples in the <a href="worker_api.html#worker_api">Worker API documentation</a>.</p> </div> </div> <div class="sect3"> <h4 id="changes_to_native_linking_tasks"><a class="anchor" href="#changes_to_native_linking_tasks"></a><a class="link" href="#changes_to_native_linking_tasks">Changes to native linking tasks</a></h4> <div class="paragraph"> <p>To expand our idiomatic <a href="lazy_configuration.html#lazy_configuration">Provider API</a> practices, the install name property from <code>org.gradle.nativeplatform.tasks.LinkSharedLibrary</code> is affected by this change.</p> </div> <div class="ulist"> <ul> <li> <p><code>getInstallName()</code> was changed to return a <code>Property</code>.</p> </li> <li> <p><code>setInstallName(String)</code> was removed. Use <code>Property.set()</code> instead.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="passing_arguments_to_windows_resource_compiler"><a class="anchor" href="#passing_arguments_to_windows_resource_compiler"></a><a class="link" href="#passing_arguments_to_windows_resource_compiler">Passing arguments to Windows Resource Compiler</a></h4> <div class="paragraph"> <p>To expand our idiomatic <a href="lazy_configuration.html#lazy_configuration">Provider API</a> practices, the <code>WindowsResourceCompile</code> task has been converted to use the Provider API.</p> </div> <div class="paragraph"> <p>Passing additional compiler arguments now follow the same pattern as the <code>CppCompile</code> and other tasks.</p> </div> </div> <div class="sect3"> <h4 id="copied_configuration_no_longer_shares_a_list_of_beforeresolve_actions_with_original"><a class="anchor" href="#copied_configuration_no_longer_shares_a_list_of_beforeresolve_actions_with_original"></a><a class="link" href="#copied_configuration_no_longer_shares_a_list_of_beforeresolve_actions_with_original">Copied configuration no longer shares a list of <code>beforeResolve</code> actions with original</a></h4> <div class="paragraph"> <p>The list of <code>beforeResolve</code> actions are no longer shared between a copied configuration and the original. Instead, a copied configuration receives a copy of the <code>beforeResolve</code> actions at the time the copy is made. Any <code>beforeResolve</code> actions added after copying (to either configuration) will not be shared between the original and the copy. This may break plugins that relied on the previous behaviour.</p> </div> </div> <div class="sect3"> <h4 id="changes_to_incubating_pom_customization_types"><a class="anchor" href="#changes_to_incubating_pom_customization_types"></a><a class="link" href="#changes_to_incubating_pom_customization_types">Changes to incubating POM customization types</a></h4> <div class="ulist"> <ul> <li> <p>The type of <code>MavenPomDeveloper.properties</code> has changed from <code>Property<Map<String, String>></code> to <code>MapProperty<String, String></code>.</p> </li> <li> <p>The type of <code>MavenPomContributor.properties</code> has changed from <code>Property<Map<String, String>></code> to <code>MapProperty<String, String></code>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="changes_to_specifying_operating_system_for_native_projects"><a class="anchor" href="#changes_to_specifying_operating_system_for_native_projects"></a><a class="link" href="#changes_to_specifying_operating_system_for_native_projects">Changes to specifying operating system for native projects</a></h4> <div class="paragraph"> <p>The incubating <code>operatingSystems</code> property on native components has been replaced with the <a href="../javadoc/org/gradle/language/cpp/CppComponent.html#getTargetMachines()">targetMachines</a> property.</p> </div> </div> <div class="sect3"> <h4 id="changes_for_archive_tasks_zip_jar_war_ear_tar"><a class="anchor" href="#changes_for_archive_tasks_zip_jar_war_ear_tar"></a><a class="link" href="#changes_for_archive_tasks_zip_jar_war_ear_tar">Changes for archive tasks (<code>Zip</code>, <code>Jar</code>, <code>War</code>, <code>Ear</code>, <code>Tar</code>)</a></h4> <div class="sect4"> <h5 id="change_in_behavior_for_tasks_extending_abstractarchivetask"><a class="anchor" href="#change_in_behavior_for_tasks_extending_abstractarchivetask"></a><a class="link" href="#change_in_behavior_for_tasks_extending_abstractarchivetask">Change in behavior for tasks extending <code>AbstractArchiveTask</code></a></h5> <div class="paragraph"> <p>The <code>AbstractArchiveTask</code> has several new properties using the <a href="lazy_configuration.html#lazy_configuration_reference">Provider API</a>. Plugins that extend these types and override methods from the base class may no longer behave the same way. Internally, <code>AbstractArchiveTask</code> prefers the new properties and methods like <code>getArchiveName()</code> are façades over the new properties.</p> </div> <div class="paragraph"> <p>If your plugin/build only uses these types (and does not extend them), nothing has changed.</p> </div> </div> </div> </div> </div> </div> </div> <div id="feedback-container" class="feedback-container"> <div class="feedback-buttons"> <label id="feedback-container-label"> Was this page helpful?</label> <button id="thumbs-up" onclick="showFeedbackForm(true)"> <!-- Thumbs Up SVG --> <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24px" height="24px" viewBox="0 0 24 24" version="1.1"> <g id="surface1"> <path style=" stroke:none;fill-rule:nonzero;fill:rgb(10.588235%,65.882353%,79.607843%);fill-opacity:1;" d="M 3 21.375 C 3 21.582031 2.832031 21.75 2.625 21.75 C 2.417969 21.75 2.25 21.582031 2.25 21.375 C 2.25 21.167969 2.417969 21 2.625 21 C 2.832031 21 3 21.167969 3 21.375 Z M 3 21.375 "/> <path style=" stroke:none;fill-rule:nonzero;fill:rgb(10.588235%,65.882353%,79.607843%);fill-opacity:1;" d="M 5.25 9.75 C 5.25 8.921875 4.578125 8.25 3.75 8.25 L 1.5 8.25 C 0.671875 8.25 0 8.921875 0 9.75 L 0 22.5 C 0 23.328125 0.671875 24 1.5 24 L 3.75 24 C 4.578125 24 5.25 23.328125 5.25 22.5 Z M 2.625 22.5 C 2.003906 22.5 1.5 21.996094 1.5 21.375 C 1.5 20.753906 2.003906 20.25 2.625 20.25 C 3.246094 20.25 3.75 20.753906 3.75 21.375 C 3.75 21.996094 3.246094 22.5 2.625 22.5 Z M 2.625 22.5 "/> <path style=" stroke:none;fill-rule:nonzero;fill:rgb(10.588235%,65.882353%,79.607843%);fill-opacity:1;" d="M 24 10.5 C 24 9.257812 22.992188 8.25 21.75 8.25 L 15.367188 8.25 L 15.375 8.25 L 16.125 1.5 C 16.203125 0.679688 15.640625 0 14.8125 0 L 13.3125 0 C 12.375 0 11.984375 0.65625 11.625 1.5 L 8.625 8.25 C 7.816406 10.1875 6.75 10.5 6 10.5 L 6 21.832031 C 6.449219 21.9375 7.019531 22.1875 7.578125 22.761719 C 8.746094 23.960938 10.140625 24 10.875 24 L 19.5 24 C 20.742188 24 21.75 22.992188 21.75 21.75 C 21.75 21.101562 21.472656 20.515625 21.035156 20.105469 C 21.890625 19.789062 22.5 18.964844 22.5 18 C 22.5 17.351562 22.222656 16.765625 21.785156 16.355469 C 22.640625 16.039062 23.25 15.214844 23.25 14.25 C 23.25 13.601562 22.972656 13.015625 22.535156 12.605469 C 23.390625 12.289062 24 11.464844 24 10.5 Z M 24 10.5 "/> </g> </svg> </button> <button id="thumbs-down" onclick="showFeedbackForm(false)"> <!-- Thumbs Down SVG --> <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24px" height="24px" viewBox="0 0 24 24" version="1.1"> <g id="surface1"> <path style=" stroke:none;fill-rule:nonzero;fill:rgb(10.588235%,65.882353%,79.607843%);fill-opacity:1;" d="M 3 13.125 C 3 13.332031 2.832031 13.5 2.625 13.5 C 2.417969 13.5 2.25 13.332031 2.25 13.125 C 2.25 12.917969 2.417969 12.75 2.625 12.75 C 2.832031 12.75 3 12.917969 3 13.125 Z M 3 13.125 "/> <path style=" stroke:none;fill-rule:nonzero;fill:rgb(10.588235%,65.882353%,79.607843%);fill-opacity:1;" d="M 0 1.5 C 0 0.671875 0.671875 0 1.5 0 L 3.75 0 C 4.578125 0 5.25 0.671875 5.25 1.5 L 5.25 14.25 C 5.25 15.078125 4.578125 15.75 3.75 15.75 L 1.5 15.75 C 0.671875 15.75 0 15.078125 0 14.25 Z M 2.625 14.25 C 3.246094 14.25 3.75 13.746094 3.75 13.125 C 3.75 12.503906 3.246094 12 2.625 12 C 2.003906 12 1.5 12.503906 1.5 13.125 C 1.5 13.746094 2.003906 14.25 2.625 14.25 Z M 2.625 14.25 "/> <path style=" stroke:none;fill-rule:nonzero;fill:rgb(10.588235%,65.882353%,79.607843%);fill-opacity:1;" d="M 24 13.5 C 24 14.742188 22.992188 15.75 21.75 15.75 L 15.367188 15.75 L 15.375 15.75 L 16.125 22.5 C 16.203125 23.320312 15.640625 24 14.8125 24 L 13.3125 24 C 12.375 24 11.984375 23.34375 11.625 22.5 L 8.625 15.75 C 7.816406 13.8125 6.75 13.5 6 13.5 L 6 2.167969 C 6.449219 2.0625 7.019531 1.8125 7.578125 1.238281 C 8.746094 0.0390625 10.140625 0 10.875 0 L 19.5 0 C 20.742188 0 21.75 1.007812 21.75 2.25 C 21.75 2.898438 21.472656 3.484375 21.035156 3.894531 C 21.890625 4.210938 22.5 5.035156 22.5 6 C 22.5 6.648438 22.222656 7.234375 21.785156 7.644531 C 22.640625 7.960938 23.25 8.785156 23.25 9.75 C 23.25 10.398438 22.972656 10.984375 22.535156 11.394531 C 23.390625 11.710938 24 12.535156 24 13.5 Z M 24 13.5 "/> </g> </svg> </button> </div> <div id="feedback-form" class="hidden-feedback-form"> <form> <label for="feedback">Additional Feedback:</label> <textarea id="feedback" name="feedback" rows="4" cols="50" placeholder="Tell us more about your experience."></textarea> <div>You can <a href="https://github.com/gradle/gradle/issues/new?assignees=&labels=a%3Adocumentation%2Cto-triage&projects=&template=40_contributor_documentation.yml"> submit issues</a> directly on Github.</div> <button id="feedback-button" type="button" onclick="submitAdditionalFeedback()" disabled> Submit Feedback <div class="animate-flicker"></div> </button> </form> </div> </div><script src="https://cdnjs.cloudflare.com/ajax/libs/prettify/r298/run_prettify.min.js"></script> </div> <!-- end div class="chapter" --> <footer class="site-layout__footer site-footer" itemscope="itemscope" itemtype="https://schema.org/WPFooter"> <nav class="site-footer__navigation" itemtype="https://schema.org/SiteNavigationElement"> <section class="site-footer__links"> <div class="site-footer__link-group"> <header><strong>Docs</strong></header> <ul class="site-footer__links-list"> <li itemprop="name"><a href="/release-notes.html" itemprop="url">Release Notes</a></li> <li itemprop="name"><a href="/dsl/" itemprop="url">Groovy DSL</a></li> <li itemprop="name"><a href="/kotlin-dsl/" itemprop="url">Kotlin DSL</a></li> <li itemprop="name"><a href="/javadoc/" itemprop="url">Javadoc</a></li> </ul> </div> <div class="site-footer__link-group"> <header><strong>News</strong></header> <ul class="site-footer__links-list"> <li itemprop="name"><a href="https://blog.gradle.org/" itemprop="url">Blog</a></li> <li itemprop="name"><a href="https://newsletter.gradle.org/" itemprop="url">Newsletter</a></li> <li itemprop="name"><a href="https://twitter.com/gradle" itemprop="url">Twitter</a></li> <li itemprop="name"><a href="https://status.gradle.com/" itemprop="url">Status</a></li> </ul> </div> <div class="site-footer__link-group"> <header><strong>Products</strong></header> <ul class="site-footer__links-list"> <li itemprop="name"><a href="https://gradle.com/develocity/" itemprop="url">Develocity</a></li> <li itemprop="name"><a href="https://gradle.com/build-scans/" itemprop="url">Build Scan™</a></li> <li itemprop="name"><a href="https://gradle.com/build-cache/" itemprop="url">Build Cache</a></li> <li itemprop="name"><a href="https://gradle.org/services/" itemprop="url">Services</a></li> </ul> </div> <div class="site-footer__link-group"> <header><strong>Get Help</strong></header> <ul class="site-footer__links-list"> <li itemprop="name"><a href="https://discuss.gradle.org/c/help-discuss" itemprop="url">Forums</a></li> <li itemprop="name"><a href="https://github.com/gradle/" itemprop="url">GitHub</a></li> <li itemprop="name"><a href="https://gradle.org/training/" itemprop="url">Events</a></li> <li itemprop="name"><a href="https://dpeuniversity.gradle.com/" itemprop="url">DPE University</a></li> </ul> </div> </section> <section class="site-footer__subscribe-newsletter" id="newsletter-form-container"> <header class="newsletter-form__header"><h5>Stay <code>UP-TO-DATE</code> on new features and news</h5></header> <p class="disclaimer">By entering your email, you agree to our <a href="https://gradle.com/legal/terms-of-service/">Terms</a> and <a href="https://gradle.com/legal/privacy/">Privacy Policy</a>, including receipt of emails. You can unsubscribe at any time.</p> <div class="newsletter-form__container"> <form id="newsletter-form" class="newsletter-form" action="https://go.gradle.com/l/68052/2018-09-07/bk6wml" method="post"> <input id="email" class="email" name="email" type="email" placeholder="name@email.com" pattern="[^@\s]+@[^@\s]+\.[^@\s]+" maxlength="255" required=""/> <button id="submit" class="submit" type="submit">Subscribe</button> </form> </div> </section> </nav> </footer> </div> <!-- end div class="content" --> </main> <div class="site-footer-secondary"> <div class="site-footer-secondary__contents"> <div class="site-footer__copy">© <a href="https://gradle.com">Gradle Inc.</a> <time>2023</time> All rights reserved. </div> <div class="site-footer__logo"><a href="/"> <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 90 66.06"> <title>Gradle</title> <path class="cls-1" d="M85.11,4.18a14.27,14.27,0,0,0-19.83-.34,1.38,1.38,0,0,0,0,2L67,7.6a1.36,1.36,0,0,0,1.78.12A8.18,8.18,0,0,1,79.5,20.06C68.17,31.38,53.05-.36,18.73,16a4.65,4.65,0,0,0-2,6.54l5.89,10.17a4.64,4.64,0,0,0,6.3,1.73l.14-.08-.11.08L31.53,33a60.29,60.29,0,0,0,8.22-6.13,1.44,1.44,0,0,1,1.87-.06h0a1.34,1.34,0,0,1,.06,2A61.61,61.61,0,0,1,33,35.34l-.09,0-2.61,1.46a7.34,7.34,0,0,1-3.61.94,7.45,7.45,0,0,1-6.47-3.71l-5.57-9.61C4,32-2.54,46.56,1,65a1.36,1.36,0,0,0,1.33,1.11H8.61A1.36,1.36,0,0,0,10,64.87a9.29,9.29,0,0,1,18.42,0,1.35,1.35,0,0,0,1.34,1.19H35.9a1.36,1.36,0,0,0,1.34-1.19,9.29,9.29,0,0,1,18.42,0A1.36,1.36,0,0,0,57,66.06H63.1a1.36,1.36,0,0,0,1.36-1.34c.14-8.6,2.46-18.48,9.07-23.43C96.43,24.16,90.41,9.48,85.11,4.18ZM61.76,30.05l-4.37-2.19h0a2.74,2.74,0,1,1,4.37,2.2Z"/> </svg> </a></div> <div class="site-footer-secondary__links"> <a href="https://gradle.com/careers/">Careers</a> | <a href="https://gradle.com/legal/privacy/">Privacy</a> | <a href="https://gradle.com/legal/terms-of-service/">Terms of Service</a> | <a href="https://gradle.org/contact/">Contact</a> </div> </div> </div> </div> <!-- end div class="layout" --> <script type="text/javascript"> // Polyfill Element.matches() if (!Element.prototype.matches) { Element.prototype.matches = Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector; } // Polyfill Element.closest() if (!Element.prototype.closest) { Element.prototype.closest = function (s) { var el = this; if (!document.documentElement.contains(el)) return null; do { if (typeof el.matches === "function" && el.matches(s)) return el; el = el.parentElement || el.parentNode; } while (el !== null); return null; }; } function getCurrentChapterFileName(givenUrl) { var currentChapterFileName = givenUrl.substr(givenUrl.lastIndexOf("/") + 1); if (currentChapterFileName === "index.html" || currentChapterFileName === "") { currentChapterFileName = givenUrl.substr(0, givenUrl.lastIndexOf("/")); currentChapterFileName = currentChapterFileName.substr(currentChapterFileName.lastIndexOf("/") + 1) + "/index.html"; } return currentChapterFileName; } // The media query indicating that a device is a desktop. // The `min-width: 64rem` definition should be aligned to // the one of `css/manual.css`. const desktopMediaQuery = window.matchMedia("screen and (min-width: 64rem)"); [].forEach.call(document.querySelectorAll(".docs-navigation a[href$='/" + getCurrentChapterFileName(window.location.pathname) + "']"), function (link) { // Add "active" to all links same as current URL link.classList.add("active"); // Expand all parent navigation var parentListEl = link.closest("li"); while (parentListEl !== null) { var dropDownEl = parentListEl.querySelector(".nav-dropdown"); if (dropDownEl !== null) { dropDownEl.classList.add("expanded"); } parentListEl = parentListEl.parentNode.closest("li"); } // Only scroll if the device is a desktop. // // Mobile's `docs-navigation` is always at bottom of `content`, // so we should not slide down to where `docs-navigation` lays. if (desktopMediaQuery.matches) { // Scroll to center of the page link.scrollIntoView({behavior: 'auto', block: 'center', inline: 'center'}) } }); // Expand/contract multi-level side navigation [].forEach.call(document.querySelectorAll(".docs-navigation .nav-dropdown"), function registerSideNavActions(collapsibleElement) { collapsibleElement.addEventListener("click", function toggleExpandedSideNav(evt) { evt.preventDefault(); evt.target.classList.toggle("expanded"); evt.target.setAttribute("aria-expanded", evt.target.classList.contains("expanded").toString()); return false; }, false); }); // Fix a weird issue making the initial screen always at the bottom. document.querySelector(".content").scrollIntoView(true); </script> </body> </html>