CINXE.COM

Upgrading your build from Gradle 6.x to 7.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 6.x to 7.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_6.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_6.html" /> <script type="application/ld+json"> { "@context": "http://schema.org", "@type": "WebPage", "name": "Gradle Documentation", "url": "https://docs.gradle.org/current/userguide/upgrading_version_6.html" } </script> <meta name="google-site-verification" content="kCnBfMu0lbnMpfg3t1-ZgJHbSOSYRSquWsxQ4HgqLkA" /></head> <body id="upgrading_version_6" 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 &amp; JVM projects</a></li> <li><a href="../userguide/java_testing.html">Testing Java &amp; 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 &amp; 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 6.x to 7.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_7.0">Upgrading from 6.9 and earlier</a></li> <li><a href="#changes_6.9">Upgrading from 6.8 and earlier</a></li> <li><a href="#changes_6.8">Upgrading from 6.7 and earlier</a></li> <li><a href="#changes_6.7">Upgrading from 6.6 and earlier</a></li> <li><a href="#changes_6.6">Upgrading from 6.5 and earlier</a></li> <li><a href="#changes_6.5">Upgrading from 6.4 and earlier</a></li> <li><a href="#changes_6.4">Upgrading from 6.3 and earlier</a></li> <li><a href="#changes_6.3">Upgrading from 6.2 and earlier</a></li> <li><a href="#changes_6.2">Upgrading from 6.1 and earlier</a></li> <li><a href="#changes_6.1">Upgrading from 6.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 6.x builds to Gradle 7.0. For migrating from Gradle 5.x or earlier, complete the <a href="upgrading_version_5.html#upgrading_version_5">older migration 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 7.0</code> to update the project to 7.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_7.0"><a class="anchor" href="#changes_7.0"></a><a class="link" href="#changes_7.0">Upgrading from 6.9 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="changes_in_the_ide_integration"><a class="anchor" href="#changes_in_the_ide_integration"></a><a class="link" href="#changes_in_the_ide_integration">Changes in the IDE integration</a></h3> <div class="sect3"> <h4 id="changes_in_the_idea_model"><a class="anchor" href="#changes_in_the_idea_model"></a><a class="link" href="#changes_in_the_idea_model">Changes in the IDEA model</a></h4> <div class="paragraph"> <p>The <code>getGeneratedSourceDirectories()</code> and <code>getGeneratedTestDirectories()</code> methods are removed from the <code>IdeaContentRoot</code> interface. Clients should replace these invocations with <code>getSourceDirectories()</code> and <code>getTestDirectories()</code> and use the <code>isGenerated()</code> method on the returned instances.</p> </div> </div> </div> <div class="sect2"> <h3 id="locking_single"><a class="anchor" href="#locking_single"></a><a class="link" href="#locking_single">Dependency locking now defaults to a single file per project</a></h3> <div class="paragraph"> <p>The format of the dependency lockfile has been changed and as a consequence there is only one file per project instead of one file per configuration per project. This change only affects <em>writing</em> lock files. Gradle remains capable of <em>loading</em> lock state saved in the older format.</p> </div> <div class="paragraph"> <p>Head over to <a href="dependency_locking.html#sec:migrate-single-lockfile">the documentation</a> to learn how to migrate to the new format. The migration can be performed per configuration and does not have to be done in a single step. Gradle will automatically clean up previous lock files when migrating them over to the new file format.</p> </div> </div> <div class="sect2"> <h3 id="gradle_module_metadata_is_now_reproducible_by_default"><a class="anchor" href="#gradle_module_metadata_is_now_reproducible_by_default"></a><a class="link" href="#gradle_module_metadata_is_now_reproducible_by_default">Gradle Module Metadata is now reproducible by default</a></h3> <div class="paragraph"> <p>The <code>buildId</code> field will not be populated by default to ensure that the produced metadata file remains unchanged when no build inputs are changed. Users can still opt in to have this unique identifier part of the produced metadata if they want to, see <a href="publishing_gradle_module_metadata.html#sub:gmm-reproducible">the documentation</a>.</p> </div> </div> <div class="sect2"> <h3 id="jcenter_deprecation"><a class="anchor" href="#jcenter_deprecation"></a><a class="link" href="#jcenter_deprecation">The <code>jcenter()</code> convenience method is now deprecated</a></h3> <div class="paragraph"> <p>JFrog <a href="https://jfrog.com/blog/into-the-sunset-bintray-jcenter-gocenter-and-chartcenter">announced</a> the sunset of the JCenter repository in February 2021. <a href="https://blog.gradle.org/jcenter-shutdown">Many Gradle builds</a> rely on JCenter for project dependencies.</p> </div> <div class="paragraph"> <p>No new packages or versions are published to JCenter, but JFrog says they will keep JCenter running in a read-only state indefinitely. We recommend that you consider <a href="declaring_repositories.html#three-declaring-repositories">using</a> <code>mavenCentral()</code>, <code>google()</code> or a private <code>maven</code> repository instead.</p> </div> <div class="paragraph"> <p>Gradle emits a deprecation warning when <code>jcenter()</code> is used as a repository and this method is scheduled to be removed in Gradle 8.0.</p> </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="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>Kotlin has been updated to <a href="https://kotlinlang.org/docs/reference/whatsnew1430.html">Kotlin 1.4.31</a>.</p> </li> <li> <p>Groovy has been updated to <a href="https://groovy-lang.org/releasenotes/groovy-3.0.html">Groovy 3.0.7</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="changes_to_groovy_and_groovy_dsl"><a class="anchor" href="#changes_to_groovy_and_groovy_dsl"></a><a class="link" href="#changes_to_groovy_and_groovy_dsl">Changes to Groovy and Groovy DSL</a></h4> <div class="paragraph"> <p>Due to the update to the next major version of Groovy, you may experience minor issues when upgrading to Gradle 7.0.</p> </div> <div class="paragraph"> <p>The new version of Groovy has a stricter parser that fails to compile code that may have been accepted in previous Groovy versions. If you encounter syntax errors, check the <a href="https://groovy.apache.org/#reporting-issues">Groovy issue tracker</a> and <a href="https://blogs.apache.org/groovy/entry/groovy-3-highlights">Groovy 3 release highlights</a>.</p> </div> <div class="paragraph"> <p><a href="https://issues.apache.org/jira/browse/GROOVY-9936">Some very specific regressions</a> have already been fixed in the next minor version of Groovy.</p> </div> <div class="sect4"> <h5 id="groovy_modularization"><a class="anchor" href="#groovy_modularization"></a><a class="link" href="#groovy_modularization">Groovy modularization</a></h5> <div class="paragraph"> <p>Gradle no longer embeds a copy of <code>groovy-all</code> that bundles all Groovy modules into a single jar&#8212;&#8203;only the most important modules are distributed in the Gradle distribution.</p> </div> <div class="paragraph"> <p>The <code>localGroovy()</code> dependency will include these Groovy modules:</p> </div> <div class="ulist"> <ul> <li> <p><code>groovy</code></p> </li> <li> <p><code>groovy-ant</code></p> </li> <li> <p><code>groovy-astbuilder</code></p> </li> <li> <p><code>groovy-console</code></p> </li> <li> <p><code>groovy-datetime</code></p> </li> <li> <p><code>groovy-dateutil</code></p> </li> <li> <p><code>groovy-groovydoc</code></p> </li> <li> <p><code>groovy-json</code></p> </li> <li> <p><code>groovy-nio</code></p> </li> <li> <p><code>groovy-sql</code></p> </li> <li> <p><code>groovy-templates</code></p> </li> <li> <p><code>groovy-test</code></p> </li> <li> <p><code>groovy-xml</code></p> </li> </ul> </div> <div class="paragraph"> <p>But the following Groovy modules are <strong>not</strong> included:</p> </div> <div class="ulist"> <ul> <li> <p><code>groovy-cli-picocli</code></p> </li> <li> <p><code>groovy-docgenerator</code></p> </li> <li> <p><code>groovy-groovysh</code></p> </li> <li> <p><code>groovy-jmx</code></p> </li> <li> <p><code>groovy-jsr223</code></p> </li> <li> <p><code>groovy-macro</code></p> </li> <li> <p><code>groovy-servlet</code></p> </li> <li> <p><code>groovy-swing</code></p> </li> <li> <p><code>groovy-test-junit5</code></p> </li> <li> <p><code>groovy-testng</code></p> </li> </ul> </div> <div class="paragraph"> <p>You can pull these dependencies into your build like any other external dependency.</p> </div> </div> <div class="sect4"> <h5 id="building_gradle_plugins_with_groovy_3"><a class="anchor" href="#building_gradle_plugins_with_groovy_3"></a><a class="link" href="#building_gradle_plugins_with_groovy_3">Building Gradle plugins with Groovy 3</a></h5> <div class="paragraph"> <p>Plugins built with Gradle 7.0 will now have Groovy 3 on their classpath when using <code>gradleApi()</code> or <code>localGroovy()</code>.</p> </div> <div class="admonitionblock note"> <table> <tr> <td class="icon"> <i class="fa icon-note" title="Note"></i> </td> <td class="content"> If you use <a href="https://spockframework.org/">Spock</a> to test your plugins, you will need to use Spock 2.x. There are no compatible versions of Spock 1.x and Groovy 3. </td> </tr> </table> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>dependencies { // Ensure you use the Groovy 3.x variant testImplementation('org.spockframework:spock-core:2.0-groovy-3.0') { exclude group: 'org.codehaus.groovy' } } // Spock 2 is based on JUnit Platform which needs to be enabled explicitly. tasks.withType(Test).configureEach { useJUnitPlatform() }</code></pre> </div> </div> </div> <div class="sect4"> <h5 id="performance"><a class="anchor" href="#performance"></a><a class="link" href="#performance">Performance</a></h5> <div class="paragraph"> <p>Depending on the number of subprojects and Groovy DSL build scripts, you may notice a performance regression when compiling build scripts for the first time or when changes are made to the build script&#8217;s classpath. This is due to the slower performance of the Groovy 3 parser, but the Groovy team is aware of the issue and trying to mitigate the regression.</p> </div> <div class="paragraph"> <p>In general, we are also looking at how we can improve the performance of build script compilation for both Groovy DSL and Kotlin DSL.</p> </div> </div> <div class="sect4"> <h5 id="encountering_could_not_find_method_x_for_arguments_y_on_defaultdependencyhandler"><a class="anchor" href="#encountering_could_not_find_method_x_for_arguments_y_on_defaultdependencyhandler"></a><a class="link" href="#encountering_could_not_find_method_x_for_arguments_y_on_defaultdependencyhandler">Encountering 'Could not find method X for arguments Y on DefaultDependencyHandler'</a></h5> <div class="paragraph"> <p>While the following error initially looks like a compile error, it is actually due to the fact that specific `Configuration`s have been removed. Please refer to <a href="#sec:configuration_removal">Removal of <code>compile</code> and <code>runtime</code> configurations</a> for more details.</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>Could not find method testCompile() for arguments [DefaultExternalModuleDependency{group='org.junit', name='junit-bom', version='5.7.0', configuration='default'}] on object of type org.gradle.api.internal.artifacts.dsl.dependencies.DefaultDependencyHandler.</code></pre> </div> </div> </div> </div> <div class="sect3"> <h4 id="updates_to_default_tool_integration_versions"><a class="anchor" href="#updates_to_default_tool_integration_versions"></a><a class="link" href="#updates_to_default_tool_integration_versions">Updates to default tool integration versions</a></h4> <div class="ulist"> <ul> <li> <p>PMD has been updated to <a href="https://github.com/pmd/pmd/releases/tag/pmd_releases%2F6.31.0">PMD 6.31.0</a>.</p> </li> <li> <p>Groovy and GroovyDoc have been updated to <a href="https://groovy-lang.org/releasenotes/groovy-3.0.html">Groovy 3.0.7</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="sec:configuration_removal"><a class="anchor" href="#sec:configuration_removal"></a><a class="link" href="#sec:configuration_removal">Removal of <code>compile</code> and <code>runtime</code> configurations</a></h4> <div class="paragraph"> <p>Since its inception, Gradle provided the <code>compile</code> and <code>runtime</code> configurations to declare dependencies. These however did not support a fine grained scoping of dependencies. Hence, better replacements were introduced in Gradle 3.4:</p> </div> <div class="ulist"> <ul> <li> <p>The <code>implementation</code> configuration should be used to declare dependencies which are <em>implementation details</em> of a library: they are not visible to consumers of the library during compilation time.</p> </li> <li> <p>The <code>api</code> configuration, available only if you apply the <code>java-library</code> plugin, should be used to declare dependencies which are part of the API of a library, that need to be exposed to consumers at compilation time.</p> </li> </ul> </div> <div class="paragraph"> <p>In Gradle 7, both the <code>compile</code> and <code>runtime</code> configurations are removed. Therefore, you have to migrate to the <code>implementation</code> and <code>api</code> configurations above. If you are still using the <code>java</code> plugin for a Java library, you will need to apply the <code>java-library</code> plugin instead.</p> </div> <table class="tableblock frame-all grid-all stretch"> <caption class="title">Table 1. Common configuration upgrades</caption> <colgroup> <col style="width: 50%;"> <col style="width: 50%;"> </colgroup> <thead> <tr> <th class="tableblock halign-left valign-top">Removed Configuration</th> <th class="tableblock halign-left valign-top">New Configuration</th> </tr> </thead> <tbody> <tr> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>compile</code></p></td> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>api</code> or <code>implementation</code></p></td> </tr> <tr> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>runtime</code></p></td> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>runtimeOnly</code></p></td> </tr> <tr> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>testRuntime</code></p></td> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>testRuntimeOnly</code></p></td> </tr> <tr> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>testCompile</code></p></td> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>testImplementation</code></p></td> </tr> <tr> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>&lt;sourceSet&gt;Runtime</code></p></td> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>&lt;sourceSet&gt;RuntimeOnly</code></p></td> </tr> <tr> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>&lt;sourceSet&gt;Compile</code></p></td> <td class="tableblock halign-left valign-top"><p class="tableblock"><code>&lt;sourceSet&gt;Implementation</code></p></td> </tr> </tbody> </table> <div class="paragraph"> <p>You can find more details about the benefits of the new configurations and which one to use in place of <code>compile</code> and <code>runtime</code> by reading the <a href="java_library_plugin.html#java_library_plugin">Java Library plugin</a> documentation.</p> </div> <div class="openblock"> <div class="content"> <div class="paragraph"> <p>When using the Groovy DSL, you need to watch out for a particular upgrade problem when dealing with the removed configurations.</p> </div> <div class="paragraph"> <p>If you were creating custom configurations that extend one of the removed configurations, Gradle may silently create configurations that do not exist.</p> </div> <div class="paragraph"> <p>This looks something like:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>configurations { // This silently creates a configuration called "runtime" myConf extendsFrom runtime }</code></pre> </div> </div> <div class="paragraph"> <p>The result of dependency resolution for your custom configuration may not be the same as Gradle 6.x or before. You may notice missing dependencies or artifacts.</p> </div> </div> </div> </div> <div class="sect3"> <h4 id="location_of_temporary_project_files_for_projectbuilder"><a class="anchor" href="#location_of_temporary_project_files_for_projectbuilder"></a><a class="link" href="#location_of_temporary_project_files_for_projectbuilder">Location of temporary project files for <code>ProjectBuilder</code></a></h4> <div class="paragraph"> <p>The <code>ProjectBuilder</code> API is used for inspecting Gradle builds in unit tests. This API used to create temporary project files under the system temporary directory as defined by <code>java.io.tmpdir</code>.</p> </div> <div class="paragraph"> <p>The API now creates temporary project files under the <code>Test</code> task&#8217;s temporary directory. This path is usually under the project build directory. This may cause test failures when the test expects particular file paths.</p> </div> <div class="paragraph"> <p>If the test uses <code>ProjectBuilder.withProjectDir(&#8230;&#8203;)</code>, it is unaffected.</p> </div> </div> <div class="sect3"> <h4 id="location_of_temporary_files_for_testkit_tests"><a class="anchor" href="#location_of_temporary_files_for_testkit_tests"></a><a class="link" href="#location_of_temporary_files_for_testkit_tests">Location of temporary files for TestKit tests</a></h4> <div class="paragraph"> <p>Tests that use the <a href="test_kit.html#test_kit">TestKit</a> API used to create temporary files under the system temporary directory as defined by <code>java.io.tmpdir</code>. These files were used to store copies of Gradle distributions or another test-only Gradle User Home.</p> </div> <div class="paragraph"> <p>TestKit tests will now create temporary files under the <code>Test</code> task&#8217;s temporary directory. This path is usually under the project build directory. This may cause test failures when the test expects particular file paths.</p> </div> <div class="paragraph"> <p>If the test uses <code>GradleRunner.withTestKitDir(&#8230;&#8203;)</code>, it is unaffected.</p> </div> </div> <div class="sect3"> <h4 id="file_system_watching_with_testkit_on_windows"><a class="anchor" href="#file_system_watching_with_testkit_on_windows"></a><a class="link" href="#file_system_watching_with_testkit_on_windows">File system watching with TestKit on Windows</a></h4> <div class="paragraph"> <p>The file system watching implementation on Windows adds a lock to the root project directory in order to watch for changes. This may cause errors when you try to delete the root project directory after running a build with TestKit. For example, tests that use TestKit together with JUnit&#8217;s <code>@TempDir</code> extension, or the <code>TemporaryFolder</code> rule can run into this problem. To avoid problems with these file locks, <code><a href="test_kit.html#test_kit">TestKit</a></code> disables file system watching for builds executed on Windows via <code>GradleRunner</code>. If you&#8217;d like to override the default behavior, you can enable file system watching by passing <code>--watch-fs</code> to <code>GradleRunner.withArguments()</code>.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_the_legacy_maven_plugin"><a class="anchor" href="#removal_of_the_legacy_maven_plugin"></a><a class="link" href="#removal_of_the_legacy_maven_plugin">Removal of the legacy <code>maven</code> plugin</a></h4> <div class="paragraph"> <p>The <code>maven</code> plugin has been removed. You should use the <code>maven-publish</code> plugin instead.</p> </div> <div class="paragraph"> <p>Please refer to the <a href="publishing_maven.html#publishing_maven">documentation of the Maven Publish plugin</a> for more details.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_the_uploadarchives_task"><a class="anchor" href="#removal_of_the_uploadarchives_task"></a><a class="link" href="#removal_of_the_uploadarchives_task">Removal of the <code>uploadArchives</code> task</a></h4> <div class="paragraph"> <p>The <code>uploadArchives</code> task was used in combination with the legacy Ivy or Maven publishing mechanisms. It has been removed in Gradle 7. You should migrate to the <code>maven-publish</code> or <code>ivy-publish</code> plugin instead.</p> </div> <div class="paragraph"> <p>Please refer to the <a href="publishing_maven.html#publishing_maven">documentation of the Maven Publish plugin</a> for publishing on Maven repositories. Please refer to the <a href="publishing_ivy.html#publishing_ivy">documentation of the Ivy Publish plugin</a> for publishing on Ivy repositories.</p> </div> </div> <div class="sect3"> <h4 id="changes_in_dependency_version_sorting"><a class="anchor" href="#changes_in_dependency_version_sorting"></a><a class="link" href="#changes_in_dependency_version_sorting">Changes in dependency version sorting</a></h4> <div class="paragraph"> <p>In the context of dependency version sorting, a <code>-SNAPSHOT</code> version is now considered to be right before a final release but after any <code>-RC</code> version. More special version suffixes are also taken into account. This brings the Gradle algorithm closer to the Maven one for well-known version suffixes.</p> </div> <div class="paragraph"> <p>Have a look at <a href="dependency_versions.html#sec:single-version-declarations">the documentation</a> for all the rules Gradle applies.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_play_framework_plugins"><a class="anchor" href="#removal_of_play_framework_plugins"></a><a class="link" href="#removal_of_play_framework_plugins">Removal of Play Framework plugins</a></h4> <div class="paragraph"> <p>The deprecated Play plugins have 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> <div class="sect2"> <h3 id="removal_of_deprecated_jvm_plugins"><a class="anchor" href="#removal_of_deprecated_jvm_plugins"></a><a class="link" href="#removal_of_deprecated_jvm_plugins">Removal of deprecated JVM plugins</a></h3> <div class="paragraph"> <p>These unmaintained alternative JVM plugins have been removed: <code>java-lang</code>, <code>scala-lang</code>, <code>junit-test-suite</code>, <code>jvm-component</code>, <code>jvm-resources</code>.</p> </div> <div class="paragraph"> <p>Please use the stable <a href="java_library_plugin.html#java_library_plugin">Java Library</a> and <a href="scala_plugin.html#scala_plugin">Scala</a> plugins instead.</p> </div> <div class="sect3"> <h4 id="removal_of_experimental_javascript_plugins"><a class="anchor" href="#removal_of_experimental_javascript_plugins"></a><a class="link" href="#removal_of_experimental_javascript_plugins">Removal of experimental JavaScript plugins</a></h4> <div class="paragraph"> <p>The following plugins for experimental JavaScript integration are now removed from the distribution: <code>coffeescript-base</code>, <code>envjs</code>, <code>javascript-base</code>, <code>jshint</code>, <code>rhino</code>.</p> </div> <div class="paragraph"> <p>If you used these plugins despite their experimental nature, you may find suitable replacements in the <a href="https://plugins.gradle.org/">Plugin Portal</a>.</p> </div> </div> <div class="sect3"> <h4 id="configuring_the_layout_of_an_ivy_repository"><a class="anchor" href="#configuring_the_layout_of_an_ivy_repository"></a><a class="link" href="#configuring_the_layout_of_an_ivy_repository">Configuring the layout of an Ivy repository</a></h4> <div class="paragraph"> <p>The <code>layout</code> method taking a configuration block has been removed and is replaced by <a href="../dsl/org.gradle.api.artifacts.repositories.IvyArtifactRepository.html#org.gradle.api.artifacts.repositories.IvyArtifactRepository:patternLayout(org.gradle.api.Action)">patternLayout</a>.</p> </div> </div> <div class="sect3"> <h4 id="executing_a_gradle_build_without_a_settings_file_is_now_an_error"><a class="anchor" href="#executing_a_gradle_build_without_a_settings_file_is_now_an_error"></a><a class="link" href="#executing_a_gradle_build_without_a_settings_file_is_now_an_error">Executing a Gradle build without a settings file is now an error</a></h4> <div class="paragraph"> <p>A Gradle build is defined by its <code>settings.gradle(.kts)</code> file found in the current or parent directory. Without a settings file, a Gradle build is undefined and Gradle produces an error when attempting to execute tasks.</p> </div> <div class="paragraph"> <p>To fix this error, <a href="settings_file_basics.html#sec:settings_file_script">create a <code>settings.gradle(.kts)</code> file</a> for the build.</p> </div> <div class="paragraph"> <p>Exceptions to this are invoking Gradle with the <code>init</code> task or using diagnostic command line flags, such as <code>--version</code>.</p> </div> </div> <div class="sect3"> <h4 id="calling_project_afterevaluate_after_project_evaluation_is_now_an_error"><a class="anchor" href="#calling_project_afterevaluate_after_project_evaluation_is_now_an_error"></a><a class="link" href="#calling_project_afterevaluate_after_project_evaluation_is_now_an_error">Calling Project.afterEvaluate() after project evaluation is now an error</a></h4> <div class="paragraph"> <p>Gradle 6.x warns users about the wrong behavior and ignores the target action in this scenario. Starting from 7.0 the same case will produce an error. Plugins and build scripts should be adjusted to call <code>afterEvaluate</code> only at configuration time. If you have such a build failure and the related <code>afterEvaluate</code> statement is declared in your build sources then you can simply delete it. If <code>afterEvaluate</code> is declared in a plugin then report the issue to the plugin maintainers.</p> </div> </div> </div> <div class="sect2"> <h3 id="modifying_file_collections_after_values_finalized_is_now_an_error"><a class="anchor" href="#modifying_file_collections_after_values_finalized_is_now_an_error"></a><a class="link" href="#modifying_file_collections_after_values_finalized_is_now_an_error">Modifying file collections after values finalized is now an error</a></h3> <div class="paragraph"> <p>Calling any mutator methods (i.e. <code>clear()</code>, <code>add()</code>, <code>remove()</code>, etc.) on <code>ConfigurableFileCollection</code> after the stored value calculated throws an exception. Users and plugin authors should adjust their code such that all configuration on <code>ConfigurableFileCollection</code> happens during configuration time, before the values are read.</p> </div> <div class="sect3"> <h4 id="removal_of_projectlayoutconfigurablefiles"><a class="anchor" href="#removal_of_projectlayoutconfigurablefiles"></a><a class="link" href="#removal_of_projectlayoutconfigurablefiles">Removal of <code>ProjectLayout#configurableFiles</code></a></h4> <div class="paragraph"> <p>Please use <code>ObjectFactory#fileCollection()</code> instead.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_basepluginconvention_libsdir_and_basepluginconvention_distsdir"><a class="anchor" href="#removal_of_basepluginconvention_libsdir_and_basepluginconvention_distsdir"></a><a class="link" href="#removal_of_basepluginconvention_libsdir_and_basepluginconvention_distsdir">Removal of <code>BasePluginConvention.libsDir</code> and <code>BasePluginConvention.distsDir</code></a></h4> <div class="paragraph"> <p>Please use the <code>libsDirectory</code> and <code>distsDirectory</code> properties instead.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_unabletodeletefileexception"><a class="anchor" href="#removal_of_unabletodeletefileexception"></a><a class="link" href="#removal_of_unabletodeletefileexception">Removal of <code>UnableToDeleteFileException</code></a></h4> <div class="paragraph"> <p>Existing usages should be replaced with <code>RuntimeException</code>.</p> </div> </div> <div class="sect3"> <h4 id="properties_removed_in_checkstyle_and_pmd_plugins"><a class="anchor" href="#properties_removed_in_checkstyle_and_pmd_plugins"></a><a class="link" href="#properties_removed_in_checkstyle_and_pmd_plugins">Properties removed in Checkstyle and PMD plugins</a></h4> <div class="ulist"> <ul> <li> <p>The <code>configDir</code> getters and setters have been removed from the Checkstle task and extension. Use the <code>configDirectory</code> property instead.</p> </li> <li> <p>The <code>rulePriority</code> getter and setter have been removed from the Pmd task and extension. Use the <code>rulesMinimumPriority</code> property instead.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="removal_of_basename_property_in_distribution_plugin"><a class="anchor" href="#removal_of_basename_property_in_distribution_plugin"></a><a class="link" href="#removal_of_basename_property_in_distribution_plugin">Removal of <code>baseName</code> property in <code>distribution</code> plugin</a></h4> <div class="paragraph"> <p>The <code>getBaseName()</code> and <code>setBaseName()</code> methods were removed from the <code>Distribution</code> class. Clients should replace the usages with the <code>distributionBaseName</code> property.</p> </div> </div> <div class="sect3"> <h4 id="using_abstracttask"><a class="anchor" href="#using_abstracttask"></a><a class="link" href="#using_abstracttask">Using <code>AbstractTask</code></a></h4> <div class="paragraph"> <p>Registering a task with the <code>AbstractTask</code> type or with a type extending <code>AbstractTask</code> was deprecated in Gradle 6.5 and is now an error in Gradle 7.0. You can use <a href="../javadoc/org/gradle/api/DefaultTask.html">DefaultTask</a> instead.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_buildlistener_buildstartedgradle"><a class="anchor" href="#removal_of_buildlistener_buildstartedgradle"></a><a class="link" href="#removal_of_buildlistener_buildstartedgradle">Removal of <code>BuildListener.buildStarted(Gradle)</code></a></h4> <div class="paragraph"> <p><code>BuildListener.buildStarted(Gradle)</code> was deprecated in Gradle 6.0 and is now removed in Gradle 7.0. Please use <a href="../javadoc/org/gradle/BuildListener.html#beforeSettings-org.gradle.api.initialization.Settings-">BuildListener.beforeSettings(Settings)</a> instead.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_unused_startparameter_apis"><a class="anchor" href="#removal_of_unused_startparameter_apis"></a><a class="link" href="#removal_of_unused_startparameter_apis">Removal of unused <code>StartParameter</code> APIs</a></h4> <div class="paragraph"> <p>The following APIs, which were not usable via command line options anymore since Gradle 5.0, are now removed: <code>StartParameter.useEmptySettings()</code>, <code>StartParameter.isUseEmptySettings()</code>, <code>StartParameter.setSearchUpwards(boolean)</code> and <code>StartParameter.isSearchUpwards()</code>.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_searching_for_settings_files_in_master_directories"><a class="anchor" href="#removal_of_searching_for_settings_files_in_master_directories"></a><a class="link" href="#removal_of_searching_for_settings_files_in_master_directories">Removal of searching for settings files in 'master' directories</a></h4> <div class="paragraph"> <p>Gradle no longer supports discovering the settings file in a directory named <code>master</code> in a sibling directory. If your build still uses this deprecated feature, consider refactoring the build to have the root directory match the physical root of the project hierarchy. You can find more information about <a href="multi_project_builds.html#multi_project_builds">how to structure a Gradle build</a> in the user manual. Alternatively, you can still run tasks in builds like this by invoking the build from the <code>master</code> directory only using a <a href="intro_multi_project_builds.html#sec:executing_tasks_by_fully_qualified_name">fully qualified path to the task</a>.</p> </div> </div> <div class="sect3"> <h4 id="modularity_infermodulepath_defaults_to_true"><a class="anchor" href="#modularity_infermodulepath_defaults_to_true"></a><a class="link" href="#modularity_infermodulepath_defaults_to_true"><code>modularity.inferModulePath</code> defaults to 'true'</a></h4> <div class="paragraph"> <p><a href="java_library_plugin.html#sec:java_library_modular">Compiling</a>, <a href="java_testing.html#sec:java_testing_modular">testing</a> and <a href="application_plugin.html#sec:application_modular">executing</a> now works automatically for any source set that defines a module by containing a <code>module-info.java</code> file. Usually, this is the behavior you need. If this is causing issues in cases you manually configure the module path, or use a 3rd party plugin for it, you can still opt out of this by setting <code>modularity.inferModulePath</code> to <code>false</code> on the java extension or individual tasks.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_validatetaskproperties"><a class="anchor" href="#removal_of_validatetaskproperties"></a><a class="link" href="#removal_of_validatetaskproperties">Removal of <code>ValidateTaskProperties</code></a></h4> <div class="paragraph"> <p>The <code>ValidateTaskProperties</code> task has been removed and replaced by the <a href="../javadoc/org/gradle/plugin/devel/tasks/ValidatePlugins.html">ValidatePlugins</a> task.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_immutablefilecollection"><a class="anchor" href="#removal_of_immutablefilecollection"></a><a class="link" href="#removal_of_immutablefilecollection">Removal of <code>ImmutableFileCollection</code></a></h4> <div class="paragraph"> <p>The <code>ImmutableFileCollection</code> type has been removed. Use the <a href="../javadoc/org/gradle/api/file/ProjectLayout.html#files-java.lang.Object&#8230;&#8203;-">factory method</a> instead. A handle to the project layout can be obtained via <a href="../javadoc/org/gradle/api/Project.html#getLayout--">Project.layout</a>.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_componentselectionreason_getdescription"><a class="anchor" href="#removal_of_componentselectionreason_getdescription"></a><a class="link" href="#removal_of_componentselectionreason_getdescription">Removal of <code>ComponentSelectionReason.getDescription</code></a></h4> <div class="paragraph"> <p>The method <code>ComponentSelectionReason.getDescription</code> has been removed. It is replaced by <code>ComponentSelectionReason.getDescriptions</code> which returns a list of <code>ComponentSelectionDescriptor</code>, each having a <code>getDescription</code>.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_domain_object_collection_constructors"><a class="anchor" href="#removal_of_domain_object_collection_constructors"></a><a class="link" href="#removal_of_domain_object_collection_constructors">Removal of domain object collection constructors</a></h4> <div class="paragraph"> <p>The following deprecated constructors were removed:</p> </div> <div class="ulist"> <ul> <li> <p>DefaultNamedDomainObjectList(Class, Instantiator, Namer)</p> </li> <li> <p>DefaultNamedDomainObjectSet(Class, Instantiator)</p> </li> <li> <p>DefaultPolymorphicDomainObjectContainer(Class, Instantiator)</p> </li> <li> <p>FactoryNamedDomainObjectContainer(Class, Instantiator, NamedDomainObjectFactory)</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="removal_of_arbitrary_local_cache_configuration"><a class="anchor" href="#removal_of_arbitrary_local_cache_configuration"></a><a class="link" href="#removal_of_arbitrary_local_cache_configuration">Removal of arbitrary local cache configuration</a></h4> <div class="paragraph"> <p>The local build cache configuration now needs to be done via <a href="../javadoc/org/gradle/caching/configuration/BuildCacheConfiguration.html#local-org.gradle.api.Action-">BuildCacheConfiguration.local()</a>.</p> </div> </div> <div class="sect3"> <h4 id="removal_of_defaultversionselectorscheme_constructor"><a class="anchor" href="#removal_of_defaultversionselectorscheme_constructor"></a><a class="link" href="#removal_of_defaultversionselectorscheme_constructor">Removal of DefaultVersionSelectorScheme constructor</a></h4> <div class="paragraph"> <p>This internal API was used in plugins, amongst other the <a href="https://github.com/nebula-plugins">Nebula plugins</a>, and was deprecated in the Gradle 5.x timeline and is now removed. Latest plugins version should no longer reference it.</p> </div> </div> <div class="sect3"> <h4 id="setting_the_config_loc_config_property_on_the_checkstyle_plugin_is_now_an_error"><a class="anchor" href="#setting_the_config_loc_config_property_on_the_checkstyle_plugin_is_now_an_error"></a><a class="link" href="#setting_the_config_loc_config_property_on_the_checkstyle_plugin_is_now_an_error">Setting the <code>config_loc</code> config property on the <code>checkstyle</code> plugin is now an error</a></h4> <div class="paragraph"> <p>The <code>checkstyle</code> plugin now fails for the following configuration</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>checkstyle { configProperties['config_loc'] = file("path/to/checkstyle-config-dir") }</code></pre> </div> </div> <div class="paragraph"> <p>Builds should declare the checkstyle configuration with the <code>checkstyle</code> block:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>checkstyle { configDirectory = file("path/to/checkstyle-config-dir") }</code></pre> </div> </div> </div> <div class="sect3"> <h4 id="querying_the_mapped_value_of_a_provider_before_the_producer_has_completed_is_now_an_error"><a class="anchor" href="#querying_the_mapped_value_of_a_provider_before_the_producer_has_completed_is_now_an_error"></a><a class="link" href="#querying_the_mapped_value_of_a_provider_before_the_producer_has_completed_is_now_an_error">Querying the mapped value of a provider before the producer has completed is now an error</a></h4> <div class="paragraph"> <p>Gradle 6.x warns users about the wrong behavior and then returns a possibly incorrect provider value. Starting with 7.0 the same case will produce an error. Plugins and build scripts should be adjusted to query the mapped value of a provider, for example a task output property, after the task has completed.</p> </div> </div> <div class="sect3"> <h4 id="task_validation_problems_are_now_errors"><a class="anchor" href="#task_validation_problems_are_now_errors"></a><a class="link" href="#task_validation_problems_are_now_errors">Task validation problems are now errors</a></h4> <div class="paragraph"> <p>Gradle 6.0 started warning about problems with task definitions (such as incorrectly defined inputs or outputs). For Gradle 7.0, those warnings are now errors and will fail the build.</p> </div> </div> <div class="sect3"> <h4 id="change_in_behavior_when_theres_a_strict_version_conflict_with_a_local_project"><a class="anchor" href="#change_in_behavior_when_theres_a_strict_version_conflict_with_a_local_project"></a><a class="link" href="#change_in_behavior_when_theres_a_strict_version_conflict_with_a_local_project">Change in behavior when there&#8217;s a strict version conflict with a local project</a></h4> <div class="paragraph"> <p>Previous Gradle releases had an inconsistent behavior in regard to conflict resolution in a particular configuration: - your project declares a strict dependency on a published module (for example, <code>com.mycompany:some-module:1.2!!</code>, where <code>1.2!!</code> is the short hand notation for a strict dependency on 1.2) - your build actually provides <code>com.mycompany:some-module</code> in a higher version</p> </div> <div class="paragraph"> <p>Previous Gradle releases would succeed, selecting the project dependency despite the strict constraint. Starting from Gradle 7, this will trigger a dependency resolution failure.</p> </div> <div class="paragraph"> <p>See <a href="https://github.com/gradle/gradle/issues/16706">this issue</a> for more context.</p> </div> </div> </div> <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="missing_dependencies"><a class="anchor" href="#missing_dependencies"></a><a class="link" href="#missing_dependencies">Missing dependencies between tasks</a></h4> <div class="paragraph"> <p>Having a task which produces an output in a location and another task consuming that location by referring to it as an input without the consumer task depending on the producer task has been deprecated. A fix for this problem is to <a href="incremental_build.html#sec:link_output_dir_to_input_files">add a dependency from the consumer to the producer</a>.</p> </div> </div> <div class="sect3"> <h4 id="duplicates-strategy"><a class="anchor" href="#duplicates-strategy"></a><a class="link" href="#duplicates-strategy">Duplicates strategy</a></h4> <div class="paragraph"> <p>Gradle 7 now fails when a copy operation (or any operation which uses a <code>org.gradle.api.file.CopySpec</code>) encounters a duplicate entry, and that the duplicates strategy isn&#8217;t set. Please look at <a href="../javadoc/org/gradle/api/file/CopySpec.html#setDuplicatesStrategy-org.gradle.api.file.DuplicatesStrategy-">the CopySpec docs</a> for details.</p> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.9"><a class="anchor" href="#changes_6.9"></a><a class="link" href="#changes_6.9">Upgrading from 6.8 and earlier</a></h2> <div class="sectionbody"> <div class="paragraph"> <p>No upgrade notes from 6.8 to 6.9, as 6.9 only contains bug fixes.</p> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.8"><a class="anchor" href="#changes_6.8"></a><a class="link" href="#changes_6.8">Upgrading from 6.7 and earlier</a></h2> <div class="sectionbody"> <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="toolchain_api_is_now_marked_as_nonnull"><a class="anchor" href="#toolchain_api_is_now_marked_as_nonnull"></a><a class="link" href="#toolchain_api_is_now_marked_as_nonnull">Toolchain API is now marked as @NonNull</a></h4> <div class="paragraph"> <p>The API supporting the Java Toolchain feature in <code>org.gradle.jvm.toolchain</code> is now marked as <code>@NonNull</code>.</p> </div> <div class="paragraph"> <p>This may impact Kotlin consumers where the return types of APIs are no longer nullable.</p> </div> </div> <div class="sect3"> <h4 id="updates_to_default_tool_integration_versions_2"><a class="anchor" href="#updates_to_default_tool_integration_versions_2"></a><a class="link" href="#updates_to_default_tool_integration_versions_2">Updates to default tool integration versions</a></h4> <div class="ulist"> <ul> <li> <p>JaCoCo has been updated to <a href="http://www.jacoco.org/jacoco/trunk/doc/changes.html">0.8.6</a>.</p> </li> <li> <p>Checkstyle has been updated to <a href="https://checkstyle.sourceforge.io/releasenotes.html#Release_8.37">Checkstyle 8.37</a>.</p> </li> <li> <p>CodeNarc has been updated to <a href="https://github.com/CodeNarc/CodeNarc/blob/v2.0.0/CHANGELOG.md">CodeNarc 2.0.0</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="updates_to_bundled_gradle_dependencies_2"><a class="anchor" href="#updates_to_bundled_gradle_dependencies_2"></a><a class="link" href="#updates_to_bundled_gradle_dependencies_2">Updates to bundled Gradle dependencies</a></h4> <div class="ulist"> <ul> <li> <p>Kotlin has been updated to <a href="https://blog.jetbrains.com/kotlin/2020/08/kotlin-1-4-released-with-a-focus-on-quality-and-performance/">Kotlin 1.4.20</a>. Note that Gradle scripts are still using the Kotlin 1.3 language.</p> </li> <li> <p>Apache Ant has been updated to 1.10.9 to fix <a href="https://github.com/gradle/gradle/security/advisories/GHSA-j45w-qrgf-25vm">CVE-2020-11979</a></p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="projects_imported_into_eclipse_now_include_custom_source_set_classpaths"><a class="anchor" href="#projects_imported_into_eclipse_now_include_custom_source_set_classpaths"></a><a class="link" href="#projects_imported_into_eclipse_now_include_custom_source_set_classpaths">Projects imported into Eclipse now include custom source set classpaths</a></h4> <div class="paragraph"> <p>Previously, projects imported by Eclipse only included dependencies for the main and test source sets. The compile and runtime classpaths of custom source sets were ignored.</p> </div> <div class="paragraph"> <p>Since Gradle 6.8, projects imported into Eclipse include the compile and runtime classpath for every source set defined by the build.</p> </div> </div> <div class="sect3"> <h4 id="sourcetask_is_no_longer_sensitive_to_empty_directories"><a class="anchor" href="#sourcetask_is_no_longer_sensitive_to_empty_directories"></a><a class="link" href="#sourcetask_is_no_longer_sensitive_to_empty_directories">SourceTask is no longer sensitive to empty directories</a></h4> <div class="paragraph"> <p>Previously, empty directories would be taken into account during up-to-date checks and build cache key calculations for the sources declared in <code>SourceTask</code>. This meant that a source tree that contained an empty directory and an otherwise identical source tree that did not contain the empty directory would be considered different sources, even if the task would produce the same outputs. In Gradle 6.8, <code>SourceTask</code> now ignores empty directories during doing up-to-date checks and build cache key calculations. In the vast majority of cases, this is the desired behavior, but it is possible that a task may extend <code>SourceTask</code> but also produce different outputs when empty directories are present in the sources. For tasks where this is a concern, you can expose a separate property without the <code>@IgnoreEmptyDirectories</code> annotation in order to capture those changes:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>@InputFiles @SkipWhenEmpty @PathSensitive(PathSensitivity.ABSOLUTE) public FileTree getSourcesWithEmptyDirectories() { return super.getSource() }</code></pre> </div> </div> </div> <div class="sect3"> <h4 id="changes_to_publications"><a class="anchor" href="#changes_to_publications"></a><a class="link" href="#changes_to_publications">Changes to publications</a></h4> <div class="paragraph"> <p>Publishing a component which has a dependency on an enforced platform now triggers a validation error, preventing accidental publishing of bad metadata: enforced platforms use cases should be limited to applications, not things which can be consumed from another library or an application.</p> </div> <div class="paragraph"> <p>If, for some reason, you still want to publish components with dependencies on enforced platforms, you can disable the validation following the <a href="publishing_setup.html#sec:suppressing_validation_errors">documentation</a>.</p> </div> </div> <div class="sect3"> <h4 id="changing_default_excludes_during_the_execution_phase"><a class="anchor" href="#changing_default_excludes_during_the_execution_phase"></a><a class="link" href="#changing_default_excludes_during_the_execution_phase">Changing default excludes during the execution phase</a></h4> <div class="paragraph"> <p>Gradle&#8217;s file trees apply some default exclude patterns for convenience — the same defaults as Ant in fact. See the <a href="working_with_files.html#sec:file_trees">user manual</a> for more information. Sometimes, Ant&#8217;s default excludes prove problematic, for example when you want to include the <code>.gitignore</code> in an archive file.</p> </div> <div class="paragraph"> <p>Changing Gradle&#8217;s default excludes during the execution phase can lead to correctness problems with up-to-date checks. As a consequence, you are only allowed to change Gradle&#8217;s default excludes in the settings script, see the <a href="working_with_files.html#sec:change_default_excludes">user manual</a> for an example.</p> </div> </div> </div> <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="referencing_tasks_from_included_builds"><a class="anchor" href="#referencing_tasks_from_included_builds"></a><a class="link" href="#referencing_tasks_from_included_builds">Referencing tasks from included builds</a></h4> <div class="paragraph"> <p>Direct references to tasks from included builds in <code>mustRunAfter</code>, <code>shouldRunAfter</code> and <code>finalizedBy</code> task methods have been deprecated. Task ordering using <code>mustRunAfter</code> and <code>shouldRunAfter</code> as well as finalizers specified by <code>finalizedBy</code> should be used for task ordering within a build. If you happen to have cross-build task ordering defined using above mentioned methods, consider restructuring such builds and decoupling them from one another.</p> </div> </div> <div class="sect3"> <h4 id="master_subdirectory_root_build"><a class="anchor" href="#master_subdirectory_root_build"></a><a class="link" href="#master_subdirectory_root_build">Searching for settings files in 'master' directories</a></h4> <div class="paragraph"> <p>Gradle will emit a deprecation warning when your build relies on finding the settings file in a directory named <code>master</code> in a sibling directory.</p> </div> <div class="paragraph"> <p>If your build uses this feature, consider refactoring the build to have the root directory match the physical root of the project hierarchy.</p> </div> <div class="paragraph"> <p>Alternatively, you can still run tasks in builds like this by invoking the build from the <code>master</code> directory only using a <a href="intro_multi_project_builds.html#sec:executing_tasks_by_fully_qualified_name">fully qualified path to the task</a>.</p> </div> </div> <div class="sect3"> <h4 id="using_NamedDomainObjectContainer_invoke_kotlin_Function1"><a class="anchor" href="#using_NamedDomainObjectContainer_invoke_kotlin_Function1"></a><a class="link" href="#using_NamedDomainObjectContainer_invoke_kotlin_Function1">Using method <code>NamedDomainObjectContainer&lt;T&gt;.invoke(kotlin.Function1)</code></a></h4> <div class="paragraph"> <p>Gradle Kotlin DSL extensions have been changed to favor Gradle&#8217;s <code>Action&lt;T&gt;</code> type over Kotlin function types.</p> </div> <div class="paragraph"> <p>While the change should be transparent to Kotlin clients, Java clients calling Kotlin DSL extensions need to be updated to use the <code>Action&lt;T&gt;</code> APIs.</p> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.7"><a class="anchor" href="#changes_6.7"></a><a class="link" href="#changes_6.7">Upgrading from 6.6 and earlier</a></h2> <div class="sectionbody"> <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="buildsrc_can_now_see_included_builds_from_the_root"><a class="anchor" href="#buildsrc_can_now_see_included_builds_from_the_root"></a><a class="link" href="#buildsrc_can_now_see_included_builds_from_the_root">buildSrc can now see included builds from the root</a></h4> <div class="paragraph"> <p>Previously, <code>buildSrc</code> was built in such a way that included builds were ignored from the root build.</p> </div> <div class="paragraph"> <p>Since Gradle 6.7, <code>buildSrc</code> can see any included build from the root build. This may cause dependencies to be substituted from an included build in <code>buildSrc</code>. This may also change the order in which some builds are executed if an included build is needed by <code>buildSrc</code>.</p> </div> </div> <div class="sect3"> <h4 id="updates_to_default_tool_integration_versions_3"><a class="anchor" href="#updates_to_default_tool_integration_versions_3"></a><a class="link" href="#updates_to_default_tool_integration_versions_3">Updates to default tool integration versions</a></h4> <div class="ulist"> <ul> <li> <p>PMD has been updated to <a href="https://github.com/pmd/pmd/releases/tag/pmd_releases%2F6.26.0">PMD 6.26.0</a>.</p> </li> <li> <p>Checkstyle has been updated to <a href="https://checkstyle.sourceforge.io/releasenotes.html#Release_8.35">Checkstyle 8.35</a>.</p> </li> <li> <p>CodeNarc has been updated to <a href="https://github.com/CodeNarc/CodeNarc/blob/v1.6.1/CHANGELOG.md">CodeNarc 1.6.1</a>.</p> </li> </ul> </div> </div> </div> <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="changing_default_excludes_during_the_execution_phase_2"><a class="anchor" href="#changing_default_excludes_during_the_execution_phase_2"></a><a class="link" href="#changing_default_excludes_during_the_execution_phase_2">Changing default excludes during the execution phase</a></h4> <div class="paragraph"> <p>Gradle&#8217;s file trees apply some default exclude patterns for convenience — the same defaults as Ant in fact. See the <a href="working_with_files.html#sec:file_trees">user manual</a> for more information. Sometimes, Ant&#8217;s default excludes prove problematic, for example when you want to include the <code>.gitignore</code> in an archive file.</p> </div> <div class="paragraph"> <p>Changing Gradle&#8217;s default excludes during the execution phase can lead to correctness problems with up-to-date checks, and is deprecated. You are only allowed to change Gradle&#8217;s default excludes in the settings script, see the <a href="working_with_files.html#sec:change_default_excludes">user manual</a> for an example.</p> </div> </div> <div class="sect3"> <h4 id="using_a_configuration_directly_as_a_dependency"><a class="anchor" href="#using_a_configuration_directly_as_a_dependency"></a><a class="link" href="#using_a_configuration_directly_as_a_dependency">Using a Configuration directly as a dependency</a></h4> <div class="paragraph"> <p>Gradle allowed instances of <code>Configuration</code> to be used directly as dependencies:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>dependencies { implementation(configurations.myConfiguration) }</code></pre> </div> </div> <div class="paragraph"> <p>This behavior is now deprecated as it is confusing: one could expect the "dependent configuration" to be resolved first and add the result of resolution as dependencies to the including configuration, which is not the case. The deprecated version can be replaced with the actual behavior, which is configuration inheritance:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>configurations.implementation.extendsFrom(configurations.myConfiguration)</code></pre> </div> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.6"><a class="anchor" href="#changes_6.6"></a><a class="link" href="#changes_6.6">Upgrading from 6.5 and earlier</a></h2> <div class="sectionbody"> <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="updates_to_bundled_gradle_dependencies_3"><a class="anchor" href="#updates_to_bundled_gradle_dependencies_3"></a><a class="link" href="#updates_to_bundled_gradle_dependencies_3">Updates to bundled Gradle dependencies</a></h4> <div class="ulist"> <ul> <li> <p>Ant has been updated to <a href="https://downloads.apache.org/ant/RELEASE-NOTES-1.10.8.html">1.10.8</a>.</p> </li> <li> <p>Groovy has been updated to <a href="https://groovy-lang.org/changelogs/changelog-2.5.12.html">Groovy 2.5.12</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="dependency_substitutions_and_variant_aware_dependency_resolution"><a class="anchor" href="#dependency_substitutions_and_variant_aware_dependency_resolution"></a><a class="link" href="#dependency_substitutions_and_variant_aware_dependency_resolution">Dependency substitutions and variant aware dependency resolution</a></h4> <div class="paragraph"> <p>While adding support for expressing <a href="resolution_rules.html#sec:variant-aware-substitutions">variant support</a> in dependency substitutions, a bug fix introduced a behaviour change that some builds may rely upon. Previously a substituted dependency would still use the <a href="variant_attributes.html#variant-attributes">attributes</a> of the original selector instead of the ones from the replacement selector.</p> </div> <div class="paragraph"> <p>With that change, existing substitutions around dependencies with richer selectors, such as for platform dependencies, will no longer work as they did. It becomes mandatory to define the variant aware part in the target selector.</p> </div> <div class="paragraph"> <p>You can be affected by this change if you:</p> </div> <div class="ulist"> <ul> <li> <p>have dependencies on platforms, like <code>implementation platform("org:platform:1.0")</code></p> </li> <li> <p><em>or</em> if you specify attributes on dependencies,</p> </li> <li> <p><em>and</em> you use <a href="resolution_rules.html#using-resolution-rules">resolution rules</a> on these dependencies.</p> </li> </ul> </div> <div class="paragraph"> <p>See the <a href="resolution_rules.html#sec:variant-aware-substitutions">documentation</a> for resolving issues if you are impacted.</p> </div> </div> </div> <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="paragraph"> <p>No deprecations were made in Gradle 6.6.</p> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.5"><a class="anchor" href="#changes_6.5"></a><a class="link" href="#changes_6.5">Upgrading from 6.4 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="updates_to_bundled_gradle_dependencies_4"><a class="anchor" href="#updates_to_bundled_gradle_dependencies_4"></a><a class="link" href="#updates_to_bundled_gradle_dependencies_4">Updates to bundled Gradle dependencies</a></h4> <div class="ulist"> <ul> <li> <p>Kotlin has been updated to <a href="https://github.com/JetBrains/kotlin/releases/tag/v1.3.72">Kotlin 1.3.72</a>.</p> </li> <li> <p>Groovy has been updated to <a href="https://groovy-lang.org/changelogs/changelog-2.5.11.html">Groovy 2.5.11</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="updates_to_default_tool_integration_versions_4"><a class="anchor" href="#updates_to_default_tool_integration_versions_4"></a><a class="link" href="#updates_to_default_tool_integration_versions_4">Updates to default tool integration versions</a></h4> <div class="ulist"> <ul> <li> <p>PMD has been updated to <a href="https://github.com/pmd/pmd/releases/tag/pmd_releases%2F6.23.0">PMD 6.23.0</a>.</p> </li> </ul> </div> </div> </div> <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="sect3"> <h4 id="abstract_task_deprecated"><a class="anchor" href="#abstract_task_deprecated"></a><a class="link" href="#abstract_task_deprecated">Internal class AbstractTask is deprecated</a></h4> <div class="paragraph"> <p><code>AbstractTask</code> is an internal class which is visible on the public API, as a superclass of public type <code>DefaultTask</code>. <code>AbstractTask</code> will be removed in Gradle 7.0, and the following are deprecated in Gradle 6.5:</p> </div> <div class="ulist"> <ul> <li> <p>Registering a task whose type is <code>AbstractTask</code> or <code>TaskInternal</code>. You can remove the task type from the task registration and Gradle will use <code>DefaultTask</code> instead.</p> </li> <li> <p>Registering a task whose type is a subclass of <code>AbstractTask</code> but not a subclass of <code>DefaultTask</code>. You can change the task type to extend <code>DefaultTask</code> instead.</p> </li> <li> <p>Using the class <code>AbstractTask</code> from plugin code or build scripts. You can change the code to use <code>DefaultTask</code> instead.</p> </li> </ul> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.4"><a class="anchor" href="#changes_6.4"></a><a class="link" href="#changes_6.4">Upgrading from 6.3 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="sect3"> <h4 id="upgrade:pmd_expects_6"><a class="anchor" href="#upgrade:pmd_expects_6"></a><a class="link" href="#upgrade:pmd_expects_6">PMD plugin expects PMD 6.0.0 or higher by default</a></h4> <div class="paragraph"> <p>Gradle 6.4 enabled incremental analysis by default. Incremental analysis is only available in PMD 6.0.0 or higher. If you want to use an older PMD version, you need to disable incremental analysis:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>pmd { incrementalAnalysis = false }</code></pre> </div> </div> </div> <div class="sect3"> <h4 id="changes_in_dependency_locking"><a class="anchor" href="#changes_in_dependency_locking"></a><a class="link" href="#changes_in_dependency_locking">Changes in dependency locking</a></h4> <div class="paragraph"> <p>With Gradle 6.4, the incubating API for <a href="dependency_locking.html#sec:fine-tuning-dependency-locking-behaviour-with-lock-mode">dependency locking <code>LockMode</code></a> has changed. The value is now set via a <code>Property&lt;LockMode&gt;</code> instead of a direct setter. This means that the notation to set the value has to be updated for the Kotlin DSL:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>dependencyLocking { lockMode.set(LockMode.STRICT) }</code></pre> </div> </div> <div class="paragraph"> <p>Users of the Groovy DSL should not be impacted as the notation <code>lockMode = LockMode.STRICT</code> remains valid.</p> </div> </div> <div class="sect3"> <h4 id="java_versions_in_published_metadata"><a class="anchor" href="#java_versions_in_published_metadata"></a><a class="link" href="#java_versions_in_published_metadata">Java versions in published metadata</a></h4> <div class="paragraph"> <p>If a Java library is published with Gradle Module Metadata, the information which Java version it supports is encoded in the <code>org.gradle.jvm.version</code> attribute. By default, this attribute was set to what you configured in <code>java.targetCompatibility</code>. If that was not configured, it was set to the current Java version running Gradle. Changing the version of a particular compile task, e.g. <code>javaCompile.targetCompatibility</code> had no effect on that attribute, leading to wrong information if the attribute was not adjusted manually. This is now fixed and the attribute defaults to the setting of the compile task that is associated with the sources from which the published jar is built.</p> </div> </div> <div class="sect3"> <h4 id="ivy_repositories_with_custom_layouts"><a class="anchor" href="#ivy_repositories_with_custom_layouts"></a><a class="link" href="#ivy_repositories_with_custom_layouts">Ivy repositories with custom layouts</a></h4> <div class="paragraph"> <p>Gradle versions from 6.0 to 6.3.x included could generate bad Gradle Module Metadata when publishing on an Ivy repository which had a custom repository layout. Starting from 6.4, Gradle will no longer publish Gradle Module Metadata if it detects that you are using a custom repository layout.</p> </div> </div> <div class="sect3"> <h4 id="new_properties_may_shadow_variables_in_build_scripts"><a class="anchor" href="#new_properties_may_shadow_variables_in_build_scripts"></a><a class="link" href="#new_properties_may_shadow_variables_in_build_scripts">New properties may shadow variables in build scripts</a></h4> <div class="paragraph"> <p>This release introduces some new properties&#8201;&#8212;&#8201;<code>mainClass</code>, <code>mainModule</code>, <code>modularity</code>&#8201;&#8212;&#8201;in different places. Since these are very generic names, there is a chance that you use one of them in your build scripts as variable name. A new property might then shadow one of your variables in an undesired way, leading to a build failure where the property is accessed instead of the local variable with the same name. You can fix it by renaming the corresponding variable in the build script.</p> </div> <div class="paragraph"> <p>Affected is configuration code inside the <code>application {}</code> and <code>java {}</code> configuration blocks, inside a java execution setup with <code>project.javaexec {}</code>, and inside various task configurations (<code>JavaExec</code>, <code>CreateStartScripts</code>, <code>JavaCompile</code>, <code>Test</code>, <code>Javadoc</code>).</p> </div> </div> <div class="sect3"> <h4 id="updates_to_bundled_gradle_dependencies_5"><a class="anchor" href="#updates_to_bundled_gradle_dependencies_5"></a><a class="link" href="#updates_to_bundled_gradle_dependencies_5">Updates to bundled Gradle dependencies</a></h4> <div class="ulist"> <ul> <li> <p>Kotlin has been updated to <a href="https://github.com/JetBrains/kotlin/releases/tag/v1.3.71">Kotlin 1.3.71</a>.</p> </li> </ul> </div> </div> </div> <div class="sect2"> <h3 id="deprecations_6"><a class="anchor" href="#deprecations_6"></a><a class="link" href="#deprecations_6">Deprecations</a></h3> <div class="paragraph"> <p>There were no deprecations between Gradle 6.3 and 6.4.</p> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.3"><a class="anchor" href="#changes_6.3"></a><a class="link" href="#changes_6.3">Upgrading from 6.2 and earlier</a></h2> <div class="sectionbody"> <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="sect3"> <h4 id="fewer_dependencies_available_in_idea"><a class="anchor" href="#fewer_dependencies_available_in_idea"></a><a class="link" href="#fewer_dependencies_available_in_idea">Fewer dependencies available in IDEA</a></h4> <div class="paragraph"> <p>Gradle no longer includes the annotation processor classpath as provided dependencies in IDEA. The dependencies IDEA sees at compile time are the same as what Gradle sees after resolving the compile classpath (configuration named <code>compileClasspath</code>). This prevents the leakage of annotation processor dependencies into the project&#8217;s code.</p> </div> <div class="paragraph"> <p>Before Gradle introduced <a href="java_plugin.html#sec:incremental_annotation_processing">incremental annotation processing support</a>, IDEA required all annotation processors to be on the compilation classpath to be able to run annotation processing when compiling in IDEA. This is no longer necessary because Gradle has a separate <a href="java_plugin.html#tab:configurations">annotation processor classpath</a>. The dependencies for annotation processors are not added to an IDEA module&#8217;s classpath when a Gradle project with annotation processors is imported.</p> </div> </div> <div class="sect3"> <h4 id="updates_to_bundled_gradle_dependencies_6"><a class="anchor" href="#updates_to_bundled_gradle_dependencies_6"></a><a class="link" href="#updates_to_bundled_gradle_dependencies_6">Updates to bundled Gradle dependencies</a></h4> <div class="ulist"> <ul> <li> <p>Kotlin has been updated to <a href="https://blog.jetbrains.com/kotlin/2020/03/kotlin-1-3-70-released/">Kotlin 1.3.70</a>.</p> </li> <li> <p>Groovy has been updated to <a href="http://groovy-lang.org/changelogs/changelog-2.5.10.html">Groovy 2.5.10</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="updates_to_default_tool_integration_versions_5"><a class="anchor" href="#updates_to_default_tool_integration_versions_5"></a><a class="link" href="#updates_to_default_tool_integration_versions_5">Updates to default tool integration versions</a></h4> <div class="ulist"> <ul> <li> <p>PMD has been updated to <a href="https://pmd.github.io/pmd-6.21.0/pmd_release_notes.html#24-january-2020---6210">PMD 6.21.0</a>.</p> </li> <li> <p>CodeNarc has been updated to <a href="https://github.com/CodeNarc/CodeNarc/blob/v1.5/CHANGELOG.md#version-15----nov-2019">CodeNarc 1.5</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="rich_console_support_removed_for_some_32_bit_operating_systems"><a class="anchor" href="#rich_console_support_removed_for_some_32_bit_operating_systems"></a><a class="link" href="#rich_console_support_removed_for_some_32_bit_operating_systems">Rich console support removed for some 32-bit operating systems</a></h4> <div class="paragraph"> <p>Gradle 6.3 does not support the <a href="command_line_interface.html#sec:rich_console">rich console</a> for 32-bit Unix systems and for old FreeBSD versions (older than FreeBSD 10). Microsoft Windows 32-bit is unaffected.</p> </div> <div class="paragraph"> <p>Gradle will continue building projects on 32-bit systems but will no longer show the rich console.</p> </div> </div> </div> <div class="sect2"> <h3 id="deprecations_7"><a class="anchor" href="#deprecations_7"></a><a class="link" href="#deprecations_7">Deprecations</a></h3> <div class="sect3"> <h4 id="using_default_and_archives_configurations"><a class="anchor" href="#using_default_and_archives_configurations"></a><a class="link" href="#using_default_and_archives_configurations">Using default and archives configurations</a></h4> <div class="paragraph"> <p>Almost every Gradle project has the <em>default</em> and <em>archives</em> configurations which are added by the <em>base</em> plugin. These configurations are no longer used in modern Gradle builds that use <a href="variant_model.html#sec:understanding-variant-selection">variant aware dependency management</a> and the <a href="publishing_setup.html#publishing_components">new publishing plugins</a>.</p> </div> <div class="paragraph"> <p>While the configurations will stay in Gradle for backwards compatibility for now, using them to declare dependencies or to resolve dependencies is now deprecated.</p> </div> <div class="paragraph"> <p>Resolving these configurations was never an intended use case and only possible because in earlier Gradle versions <em>every</em> configuration was resolvable. For declaring dependencies, please use the configurations provided by the plugins you use, for example by the <a href="java_library_plugin.html#sec:java_library_configurations_graph">Java Library plugin</a>.</p> </div> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.2"><a class="anchor" href="#changes_6.2"></a><a class="link" href="#changes_6.2">Upgrading from 6.1 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="potential_breaking_changes_8"><a class="anchor" href="#potential_breaking_changes_8"></a><a class="link" href="#potential_breaking_changes_8">Potential breaking changes</a></h3> <div class="sect3"> <h4 id="compile_and_runtime_classpath_now_request_library_variants_by_default"><a class="anchor" href="#compile_and_runtime_classpath_now_request_library_variants_by_default"></a><a class="link" href="#compile_and_runtime_classpath_now_request_library_variants_by_default">Compile and runtime classpath now request library variants by default</a></h4> <div class="paragraph"> <p>A classpath in a JVM project now explicitly requests the <code>org.gradle.category=library</code> attribute. This leads to clearer error messages if a certain library cannot be used. For example, when the library does not support the required Java version. The practical effect is that now all <a href="java_platform_plugin.html#sec:java_platform_consumption">platform dependencies</a> have to be declared as such. Before, platform dependencies also worked, accidentally, when the <code>platform()</code> keyword was omitted for local platforms or platforms published with Gradle Module Metadata.</p> </div> </div> <div class="sect3"> <h4 id="properties_from_project_root_gradle_properties_leaking_into_buildsrc_and_included_builds"><a class="anchor" href="#properties_from_project_root_gradle_properties_leaking_into_buildsrc_and_included_builds"></a><a class="link" href="#properties_from_project_root_gradle_properties_leaking_into_buildsrc_and_included_builds">Properties from project root <code>gradle.properties</code> leaking into <code>buildSrc</code> and included builds</a></h4> <div class="paragraph"> <p>There was a regression in Gradle 6.2 and Gradle 6.2.1 that caused Gradle properties set in the project root <code>gradle.properties</code> file to leak into the <code>buildSrc</code> build and any builds included by the root.</p> </div> <div class="paragraph"> <p>This could cause your build to start failing if the <code>buildSrc</code> build or an included build suddenly found an unexpected or incompatible value for a property coming from the project root <code>gradle.properties</code> file.</p> </div> <div class="paragraph"> <p>The regression has been fixed in Gradle 6.2.2.</p> </div> </div> </div> <div class="sect2"> <h3 id="deprecations_8"><a class="anchor" href="#deprecations_8"></a><a class="link" href="#deprecations_8">Deprecations</a></h3> <div class="paragraph"> <p>There were no deprecations between Gradle 6.1 and 6.2.</p> </div> </div> </div> </div> <div class="sect1"> <h2 id="changes_6.1"><a class="anchor" href="#changes_6.1"></a><a class="link" href="#changes_6.1">Upgrading from 6.0 and earlier</a></h2> <div class="sectionbody"> <div class="sect2"> <h3 id="deprecations_9"><a class="anchor" href="#deprecations_9"></a><a class="link" href="#deprecations_9">Deprecations</a></h3> <div class="sect3"> <h4 id="querying_a_mapped_output_property_of_a_task_before_the_task_has_completed"><a class="anchor" href="#querying_a_mapped_output_property_of_a_task_before_the_task_has_completed"></a><a class="link" href="#querying_a_mapped_output_property_of_a_task_before_the_task_has_completed">Querying a mapped output property of a task before the task has completed</a></h4> <div class="paragraph"> <p>Querying the value of a mapped output property before the task has completed can cause strange build failures because it indicates stale or non-existent outputs may be used by mistake. This behavior is deprecated and will emit a deprecation warning. This will become an error in Gradle 7.0.</p> </div> <div class="paragraph"> <p>The following example demonstrates this problem where the Producer&#8217;s output file is parsed before the Producer executes:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>class Consumer extends DefaultTask { @Input final Property&lt;Integer&gt; threadPoolSize = ... } class Producer extends DefaultTask { @OutputFile final RegularFileProperty outputFile = ... } // threadPoolSize is read from the producer's outputFile consumer.threadPoolSize = producer.outputFile.map { it.text.toInteger() } // Emits deprecation warning println("thread pool size = " + consumer.threadPoolSize.get())</code></pre> </div> </div> <div class="paragraph"> <p>Querying the value of <code>consumer.threadPoolSize</code> will produce a deprecation warning if done prior to <code>producer</code> completing, as the output file has not yet been generated.</p> </div> </div> <div class="sect3"> <h4 id="discontinued_methods"><a class="anchor" href="#discontinued_methods"></a><a class="link" href="#discontinued_methods">Discontinued methods</a></h4> <div class="paragraph"> <p>The following methods have been discontinued and should no longer be used. They will be removed in Gradle 7.0.</p> </div> <div class="ulist"> <ul> <li> <p><code>BasePluginConvention.setProject(ProjectInternal)</code></p> </li> <li> <p><code>BasePluginConvention.getProject()</code></p> </li> <li> <p><code>StartParameter.useEmptySettings()</code></p> </li> <li> <p><code>StartParameter.isUseEmptySettings()</code></p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="upgrading_jvm_plugins"><a class="anchor" href="#upgrading_jvm_plugins"></a><a class="link" href="#upgrading_jvm_plugins">Alternative JVM plugins (a.k.a "Software Model")</a></h4> <div class="paragraph"> <p>A set of alternative plugins for Java and Scala development were introduced in Gradle 2.x as an experiment based on the "software model". These plugins are now deprecated and will eventually be removed. If you are still using one of these old plugins (<code>java-lang</code>, <code>scala-lang</code>, <code>jvm-component</code>, <code>jvm-resources</code>, <code>junit-test-suite</code>) please consult the documentation on <a href="building_java_projects.html#building_java_projects">Building Java &amp; JVM projects</a> to determine which of the stable JVM plugins are appropriate for your project.</p> </div> </div> </div> <div class="sect2"> <h3 id="potential_breaking_changes_9"><a class="anchor" href="#potential_breaking_changes_9"></a><a class="link" href="#potential_breaking_changes_9">Potential breaking changes</a></h3> <div class="sect3"> <h4 id="projectlayout_is_no_longer_available_to_worker_actions_as_a_service"><a class="anchor" href="#projectlayout_is_no_longer_available_to_worker_actions_as_a_service"></a><a class="link" href="#projectlayout_is_no_longer_available_to_worker_actions_as_a_service"><code>ProjectLayout</code> is no longer available to worker actions as a service</a></h4> <div class="paragraph"> <p>In Gradle 6.0, the <code>ProjectLayout</code> service was made available to worker actions via service injection. This service allowed for mutable state to leak into a worker action and introduced a way for dependencies to go undeclared in the worker action.</p> </div> <div class="paragraph"> <p><code>ProjectLayout</code> has been removed from the available services. Worker actions that were using <code>ProjectLayout</code> should switch to injecting the <code>projectDirectory</code> or <code>buildDirectory</code> as a parameter instead.</p> </div> </div> <div class="sect3"> <h4 id="updates_to_bundled_gradle_dependencies_7"><a class="anchor" href="#updates_to_bundled_gradle_dependencies_7"></a><a class="link" href="#updates_to_bundled_gradle_dependencies_7">Updates to bundled Gradle dependencies</a></h4> <div class="ulist"> <ul> <li> <p>Kotlin has been updated to <a href="https://blog.jetbrains.com/kotlin/2019/11/kotlin-1-3-60-released/">Kotlin 1.3.61</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="updates_to_default_tool_integration_versions_6"><a class="anchor" href="#updates_to_default_tool_integration_versions_6"></a><a class="link" href="#updates_to_default_tool_integration_versions_6">Updates to default tool integration versions</a></h4> <div class="ulist"> <ul> <li> <p>Checkstyle has been updated to <a href="https://checkstyle.org/releasenotes.html#Release_8.27">Checkstyle 8.27</a>.</p> </li> <li> <p>PMD has been updated to <a href="https://pmd.github.io/pmd-6.20.0/pmd_release_notes.html#29-november-2019---6200">PMD 6.20.0</a>.</p> </li> </ul> </div> </div> <div class="sect3"> <h4 id="publishing_spring_boot_applications"><a class="anchor" href="#publishing_spring_boot_applications"></a><a class="link" href="#publishing_spring_boot_applications">Publishing Spring Boot applications</a></h4> <div class="paragraph"> <p>Starting from Gradle 6.2, Gradle performs a sanity check before uploading, to make sure you don&#8217;t upload stale files (files produced by another build). This introduces a problem with Spring Boot applications which are uploaded using the <code>components.java</code> component:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>Artifact my-application-0.0.1-SNAPSHOT.jar wasn't produced by this build.</code></pre> </div> </div> <div class="paragraph"> <p>This is caused by the fact that the main <code>jar</code> task is disabled by the Spring Boot application, and the component expects it to be present. Because the <code>bootJar</code> task uses the <em>same file</em> as the main <code>jar</code> task by default, previous releases of Gradle would either:</p> </div> <div class="ulist"> <ul> <li> <p>publish a stale <code>bootJar</code> artifact</p> </li> <li> <p>or fail if the <code>bootJar</code> task hasn&#8217;t been called previously</p> </li> </ul> </div> <div class="paragraph"> <p>A workaround is to tell Gradle what to upload. If you want to upload the <code>bootJar</code>, then you need to configure the outgoing configurations to do this:</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>configurations { [apiElements, runtimeElements].each { it.outgoing.artifacts.removeIf { it.buildDependencies.getDependencies(null).contains(jar) } it.outgoing.artifact(bootJar) } }</code></pre> </div> </div> <div class="paragraph"> <p>Alternatively, you might want to re-enable the <code>jar</code> task, and add the <code>bootJar</code> with a different classifier.</p> </div> <div class="listingblock"> <div class="content"> <pre class="prettyprint highlight"><code>jar { enabled = true } bootJar { classifier = 'application' }</code></pre> </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>

Pages: 1 2 3 4 5 6 7 8 9 10