Remove old gradle files
Bug: 270105162
Change-Id: Id7b5c1b2df15cf11e19280bdd2ddc2f3ae4a66b9
diff --git a/gradle.properties b/gradle.properties
deleted file mode 100644
index 4bd94ac..0000000
--- a/gradle.properties
+++ /dev/null
@@ -1,17 +0,0 @@
-# Copyright (c) 2020, the R8 project authors. Please see the AUTHORS file
-# for details. All rights reserved. Use of this source code is governed by a
-# BSD-style license that can be found in the LICENSE file.
-
-org.gradle.jvmargs=-Xmx2048M -Dfile.encoding=UTF-8
-kotlin.daemon.jvmargs=-Xmx3g -Dkotlin.js.compiler.legacy.force_enabled=true
-systemProp.file.encoding=UTF-8
-
-# Enable new incremental compilation
-kotlin.incremental.useClasspathSnapshot=true
-
-org.gradle.parallel=true
-org.gradle.caching=false
-
-# Do not download any jdks or detect them. We provide them
-org.gradle.java.installations.auto-detect=false
-org.gradle.java.installations.auto-download=false
diff --git a/old.gradle.deprecated b/old.gradle.deprecated
deleted file mode 100644
index f7b3a44..0000000
--- a/old.gradle.deprecated
+++ /dev/null
@@ -1,1844 +0,0 @@
-// Copyright (c) 2016, the R8 project authors. Please see the AUTHORS file
-// for details. All rights reserved. Use of this source code is governed by a
-// BSD-style license that can be found in the LICENSE file.
-
-
-
-import net.ltgt.gradle.errorprone.CheckSeverity
-import org.gradle.internal.os.OperatingSystem
-import tasks.DownloadDependency
-
-plugins {
- id "net.ltgt.errorprone" version "2.0.2"
-}
-
-apply plugin: 'java'
-apply plugin: 'idea'
-
-ext {
- // When updating dependencies also update and run
- // tools/create_local_maven_with_dependencies.py
- androidSupportVersion = '25.4.0'
- asmVersion = '9.5' // When updating update tools/asmifier.py, build.src and Toolhelper as well.
- javassistVersion = '3.29.2-GA'
- espressoVersion = '3.0.0'
- fastutilVersion = '7.2.1'
- guavaVersion = '31.1-jre'
- gsonVersion = '2.10.1'
- junitVersion = '4.13-beta-2'
- mockitoVersion = '2.10.0'
- // The kotlin version is only here to specify the kotlin language level,
- // all kotlin compilations are done in tests.
- kotlinVersion = '1.8.0'
- kotlinExtMetadataJVMVersion = '0.7.0'
- smaliVersion = '3.0.3'
- errorproneVersion = '2.18.0'
- testngVersion = '6.10'
-}
-
-repositories {
- maven {
- url uri('file:third_party/dependencies')
- }
-}
-
-if (project.hasProperty('with_code_coverage')) {
- apply plugin: 'jacoco'
-}
-
-// Custom source set for example tests and generated tests.
-sourceSets {
- main {
- java {
- srcDirs = ['src/main/java', 'src/keepanno/java']
- // Exclude in old setup, resource shrinker is only compiled into R8 with 8.0
- exclude 'com/android/tools/r8/utils/resourceshrinker/*.java'
- }
- resources {
- srcDirs "third_party/api_database/api_database"
- }
- }
- main17 {
- java {
- srcDirs = ['src/main/java', 'src/keepanno/java']
- // Exclude in old setup, resource shrinker is only compiled into R8 with 8.0
- exclude 'com/android/tools/r8/utils/resourceshrinker/*.java'
- }
- resources {
- srcDirs "third_party/api_database/api_database"
- }
- }
- test {
- java {
- srcDirs = [
- 'src/test/java',
- 'src/test/bootstrap',
- 'build/generated/test/java',
- ]
- }
- }
- apiUsageSample {
- java {
- srcDirs = ['src/test/apiUsageSample', 'src/main/java']
- include 'com/android/tools/apiusagesample/*.java'
- include 'com/android/tools/r8/BaseCompilerCommandParser.java'
- include 'com/android/tools/r8/D8CommandParser.java'
- include 'com/android/tools/r8/R8CommandParser.java'
- include 'com/android/tools/r8/utils/FlagFile.java'
- }
- }
- cfSegments {
- java {
- srcDirs = ['third_party/classlib/java', 'src/cf_segments/java']
- }
- output.resourcesDir = 'build/classes/cfSegments'
- }
- debugTestResources {
- java {
- srcDirs = ['src/test/debugTestResources']
- }
- output.resourcesDir = 'build/classes/debugTestResources'
- }
- debugTestResourcesJava8 {
- java {
- srcDirs = ['src/test/debugTestResourcesJava8']
- }
- output.resourcesDir = 'build/classes/debugTestResourcesJava8'
- }
- examplesJava9 {
- java {
- srcDirs = ['src/test/examplesJava9']
- }
- }
- examplesJava10 {
- java {
- srcDirs = ['src/test/examplesJava10']
- }
- }
- examplesJava11 {
- java {
- srcDirs = ['src/test/examplesJava11']
- }
- }
- examplesJava17 {
- java {
- srcDirs = ['src/test/examplesJava17']
- }
- }
- examplesJava20 {
- java {
- srcDirs = ['src/test/examplesJava20']
- }
- }
- keepanno {
- java {
- srcDirs = ['src/keepanno/java']
- include 'com/android/tools/r8/keepanno/annotations/*.java'
- }
- }
-}
-
-// Ensure importing into IntelliJ IDEA use the same output directories as Gradle. In tests we
-// use the output path for tests (ultimately through ToolHelper.getClassPathForTests()) and
-// therefore these paths need to be the same. See https://youtrack.jetbrains.com/issue/IDEA-175172
-// for context.
-idea {
- sourceSets.all { SourceSet sources ->
- module {
- if (sources.name == "main") {
- sourceDirs += sources.java.srcDirs
- outputDir sources.output.classesDirs[0]
- } else {
- testSourceDirs += sources.java.srcDirs
- testOutputDir sources.output.classesDirs[0]
- }
- }
- }
-}
-
-dependencies {
- implementation "com.google.code.gson:gson:$gsonVersion"
- // Include all of guava when compiling the code, but exclude annotations that we don't
- // need from the packaging.
- compileOnly("com.google.guava:guava:$guavaVersion")
- implementation("com.google.guava:guava:$guavaVersion", {
- exclude group: 'com.google.errorprone'
- exclude group: 'com.google.code.findbugs'
- exclude group: 'com.google.j2objc'
- exclude group: 'org.codehaus.mojo'
- exclude group: 'com.google.guava', module: 'listenablefuture'
- exclude group: 'com.google.guava', module: 'failureaccess'
- })
- implementation group: 'it.unimi.dsi', name: 'fastutil', version: fastutilVersion
- implementation "org.jetbrains.kotlinx:kotlinx-metadata-jvm:$kotlinExtMetadataJVMVersion"
- implementation group: 'org.ow2.asm', name: 'asm', version: asmVersion
- implementation group: 'org.ow2.asm', name: 'asm-commons', version: asmVersion
- implementation group: 'org.ow2.asm', name: 'asm-tree', version: asmVersion
- implementation group: 'org.ow2.asm', name: 'asm-analysis', version: asmVersion
- implementation group: 'org.ow2.asm', name: 'asm-util', version: asmVersion
-
- main17Implementation "com.google.code.gson:gson:$gsonVersion"
- // Include all of guava when compiling the code, but exclude annotations that we don't
- // need from the packaging.
- main17CompileOnly("com.google.guava:guava:$guavaVersion")
- main17Implementation("com.google.guava:guava:$guavaVersion", {
- exclude group: 'com.google.errorprone'
- exclude group: 'com.google.code.findbugs'
- exclude group: 'com.google.j2objc'
- exclude group: 'org.codehaus.mojo'
- })
- main17Implementation group: 'it.unimi.dsi', name: 'fastutil', version: fastutilVersion
- main17Implementation "org.jetbrains.kotlinx:kotlinx-metadata-jvm:$kotlinExtMetadataJVMVersion"
- main17Implementation group: 'org.ow2.asm', name: 'asm', version: asmVersion
- main17Implementation group: 'org.ow2.asm', name: 'asm-commons', version: asmVersion
- main17Implementation group: 'org.ow2.asm', name: 'asm-tree', version: asmVersion
- main17Implementation group: 'org.ow2.asm', name: 'asm-analysis', version: asmVersion
- main17Implementation group: 'org.ow2.asm', name: 'asm-util', version: asmVersion
-
- testCompile "junit:junit:$junitVersion"
- testCompile "com.google.guava:guava:$guavaVersion"
- testCompile "org.jetbrains.kotlin:kotlin-stdlib:$kotlinVersion"
- testCompile "org.jetbrains.kotlin:kotlin-reflect:$kotlinVersion"
- testCompile group: 'com.android.tools.smali', name: 'smali', version: smaliVersion
- testCompile files('third_party/jasmin/jasmin-2.4.jar')
- testCompile files('third_party/jdwp-tests/apache-harmony-jdwp-tests-host.jar')
- testCompile files('third_party/ddmlib/ddmlib.jar')
- testCompile group: 'org.ow2.asm', name: 'asm', version: asmVersion
- testCompile group: 'org.ow2.asm', name: 'asm-commons', version: asmVersion
- testCompile group: 'org.ow2.asm', name: 'asm-tree', version: asmVersion
- testCompile group: 'org.ow2.asm', name: 'asm-analysis', version: asmVersion
- testCompile group: 'org.ow2.asm', name: 'asm-util', version: asmVersion
- testCompile group: 'it.unimi.dsi', name: 'fastutil', version: fastutilVersion
- testCompile group: 'org.javassist', name: 'javassist', version: javassistVersion
-
- apiUsageSampleCompile sourceSets.main.output
- apiUsageSampleCompile "com.google.guava:guava:$guavaVersion"
- errorprone("com.google.errorprone:error_prone_core:$errorproneVersion")
-
- keepannoCompile group: 'org.ow2.asm', name: 'asm', version: asmVersion
- keepannoCompile "com.google.guava:guava:$guavaVersion"
-}
-
-def r8LibPath = "$buildDir/libs/r8lib.jar"
-def r8LibExludeDepsPath = "$buildDir/libs/r8lib-exclude-deps.jar"
-def r8DesugaredPath = "$buildDir/libs/r8desugared.jar"
-def r8LibGeneratedKeepRulesPath = "$buildDir/generated/keep.txt"
-def r8LibTestPath = "$buildDir/classes/r8libtest"
-def java11ClassFiles = "$buildDir/classes/java/mainJava11"
-def r8RetracePath = "$buildDir/libs/r8retrace.jar"
-def r8RetraceExludeDepsPath = "$buildDir/libs/r8retrace-exclude-deps.jar"
-
-def osString = OperatingSystem.current().isLinux() ? "linux" :
- OperatingSystem.current().isMacOsX() ? "mac" : "windows"
-
-def cloudDependencies = [
- "tests" : [
- "2017-10-04/art",
- "2016-12-19/art"
- ],
- "third_party": [
- "aapt2",
- "android_cts_baseline",
- "android_jar/libcore_latest",
- "android_jar/lib-v14",
- "android_jar/lib-v15",
- "android_jar/lib-v19",
- "android_jar/lib-v21",
- "android_jar/lib-v22",
- "android_jar/lib-v23",
- "android_jar/lib-v24",
- "android_jar/lib-v25",
- "android_jar/lib-v26",
- "android_jar/lib-v27",
- "android_jar/lib-v28",
- "android_jar/lib-v29",
- "android_jar/lib-v30",
- "android_jar/lib-v31",
- "android_jar/lib-v32",
- "android_jar/lib-v33",
- "android_jar/lib-v34",
- "android_jar/lib-master",
- "api_database/api_database",
- "api-outlining/simple-app-dump",
- "binary_compatibility_tests/compiler_api_tests",
- "bundletool/bundletool-1.11.0",
- "core-lambda-stubs",
- "dagger/2.41",
- "dart-sdk",
- "ddmlib",
- "examples",
- "examplesAndroidN",
- "examplesAndroidO",
- "examplesAndroidOLegacy",
- "examplesAndroidOGenerated",
- "examplesAndroidP",
- "examplesAndroidPGenerated",
- "gradle/gradle",
- "google/google-java-format/1.14.0",
- "google-java-format",
- "gson/gson-2.10.1",
- "guava/guava-32.1.2-android",
- "guava/guava-32.1.2-jre",
- "jacoco/0.8.2",
- "jacoco/0.8.6",
- "jasmin",
- "junit",
- "jdwp-tests",
- "jsr223-api-1.0",
- "rhino-1.7.10",
- "rhino-android-1.1.1",
- "kotlin/kotlin-compiler-1.3.72",
- "kotlin/kotlin-compiler-1.4.20",
- "kotlin/kotlin-compiler-1.5.0",
- "kotlin/kotlin-compiler-1.6.0",
- "kotlin/kotlin-compiler-1.7.0",
- "kotlin/kotlin-compiler-1.8.0",
- "kotlinx-coroutines-1.3.6",
- "kotlinR8TestResources",
- "multidex",
- "openjdk/custom_conversion",
- "openjdk/openjdk-rt-1.8",
- "openjdk/desugar_jdk_libs",
- "openjdk/desugar_jdk_libs_11",
- "openjdk/desugar_jdk_libs_releases/1.0.9",
- "openjdk/desugar_jdk_libs_releases/1.0.10",
- "openjdk/desugar_jdk_libs_releases/1.1.0",
- "openjdk/desugar_jdk_libs_releases/1.1.1",
- "openjdk/desugar_jdk_libs_releases/1.1.5",
- "openjdk/desugar_jdk_libs_releases/2.0.3",
- "openjdk/jdk-11-test",
- "opensource-apps/tivi",
- "proguard/proguard5.2.1",
- "proguard/proguard6.0.1",
- "proguard/proguard-7.0.0",
- "proguard/proguard-7.3.2",
- "retrace_benchmark",
- "retrace/binary_compatibility",
- "r8",
- "r8-releases/2.0.74",
- "r8-releases/3.2.54",
- "r8mappings",
- "smali"
- ],
- // All dex-vms have a fixed OS of Linux, as they are only supported on Linux, and will be run in a Docker
- // container on other platforms where supported.
- "tools" : [
- "linux/art",
- "linux/art-5.1.1",
- "linux/art-6.0.1",
- "linux/art-7.0.0",
- "linux/art-8.1.0",
- "linux/art-9.0.0",
- "linux/art-10.0.0",
- "linux/host/art-12.0.0-beta4",
- "linux/host/art-13.0.0",
- "linux/host/art-14.0.0-beta3",
- "linux/host/art-master",
- "linux/dalvik",
- "linux/dalvik-4.0.4",
- ]
-]
-
-def cloudSystemDependencies = [
- linux: [
- "third_party": ["openjdk/openjdk-9.0.4/linux",
- "openjdk/jdk8/linux-x86",
- "openjdk/jdk-11/linux",
- "openjdk/jdk-17/linux",
- "openjdk/jdk-20/linux"],
- ],
- osx: [
- "third_party": ["openjdk/openjdk-9.0.4/osx",
- "openjdk/jdk8/darwin-x86",
- "openjdk/jdk-11/osx",
- "openjdk/jdk-17/osx",
- "openjdk/jdk-20/osx"],
- ],
- windows: [
- "third_party": ["openjdk/openjdk-9.0.4/windows",
- "openjdk/jdk-11/windows",
- "openjdk/jdk-17/windows",
- "openjdk/jdk-20/windows"],
- ],
-]
-
-if (OperatingSystem.current().isWindows()) {
- cloudSystemDependencies.windows.each { entry ->
- cloudDependencies.get(entry.key).addAll(entry.value)
- }
-} else if (OperatingSystem.current().isLinux()) {
- cloudSystemDependencies.linux.each { entry ->
- cloudDependencies.get(entry.key).addAll(entry.value)
- }
-} else if (OperatingSystem.current().isMacOsX()) {
- cloudSystemDependencies.osx.each { entry ->
- cloudDependencies.get(entry.key).addAll(entry.value)
- }
-} else {
- println "WARNING: Unsupported system: " + OperatingSystem.current()
-}
-
-def getDownloadDepsTaskName(entryKey, entryFile) {
- return "download_deps_${entryKey}_${entryFile.replace('/', '_').replace('\\', '_')}"
-}
-
-cloudDependencies.each { entry ->
- entry.value.each { entryFile ->
- task (getDownloadDepsTaskName(entry.key, entryFile), type: DownloadDependency) {
- type DownloadDependency.Type.GOOGLE_STORAGE
- dependency "${entry.key}/${entryFile}"
- }
- }
-}
-
-def x20Dependencies = [
- "third_party": [
- "benchmarks/kotlin-benches",
- "chrome/chrome_200430",
- "chrome/monochrome_public_minimal_apks/chrome_200520",
- "chrome/clank_google3_prebuilt",
- "classlib",
- "cf_segments",
- "desugar/desugar_20180308",
- "internal/issue-127524985",
- "framework",
- "gmail/gmail_android_180826.15",
- "gmscore/gmscore_v10",
- "gmscore/latest",
- "nest/nest_20180926_7c6cfb",
- "proguard/proguard_internal_159423826",
- "proguardsettings",
- "proto",
- "protobuf-lite",
- "retrace_internal",
- "youtube/youtube.android_17.19"
- ],
-]
-
-x20Dependencies.each { entry ->
- entry.value.each { entryFile ->
- task "${getDownloadDepsTaskName(entry.key, entryFile)}"(type: DownloadDependency) {
- type DownloadDependency.Type.X20
- dependency "${entry.key}/${entryFile}"
- }
- }
-}
-
-task downloadOpenJDKrt {
- cloudDependencies.each { entry ->
- entry.value.each { entryFile ->
- if (entryFile.contains("openjdk-rt")) {
- dependsOn "${getDownloadDepsTaskName(entry.key, entryFile)}"
- }
- }
- }
-}
-
-task downloadAndroidCts {
- cloudDependencies.each { entry ->
- entry.value.each { entryFile ->
- if (entryFile.contains("android_cts_baseline")) {
- dependsOn "${getDownloadDepsTaskName(entry.key, entryFile)}"
- }
- }
- }
-}
-
-task downloadCloudDeps() {
- cloudDependencies.each { entry ->
- entry.value.each { entryFile ->
- dependsOn "${getDownloadDepsTaskName(entry.key, entryFile)}"
- }
- }
-}
-
-task downloadX20Deps() {
- x20Dependencies.each { entry ->
- entry.value.each { entryFile ->
- dependsOn "${getDownloadDepsTaskName(entry.key, entryFile)}"
- }
- }
-}
-
-task downloadDeps {
- dependsOn downloadCloudDeps
- if (!project.hasProperty('no_internal')) {
- dependsOn downloadX20Deps
- }
-}
-
-allprojects {
- sourceCompatibility = JavaVersion.VERSION_1_8
- targetCompatibility = JavaVersion.VERSION_1_8
-}
-
-// TODO(ricow): Remove debug prints
-println("NOTE: Current operating system: " + OperatingSystem.current())
-println("NOTE: Current operating system isWindows: " + OperatingSystem.current().isWindows())
-
-// Check if running with the JDK location from tools/jdk.py.
-if (OperatingSystem.current().isWindows()) {
- println "NOTE: Running with JDK: " + org.gradle.internal.jvm.Jvm.current().javaHome
- compileJava.options.encoding = "UTF-8"
- compileTestJava.options.encoding = "UTF-8"
-} else {
- def javaHomeOut = new StringBuilder()
- def javaHomeErr = new StringBuilder()
- def javaHomeProc = './tools/jdk.py'.execute([], projectDir)
- javaHomeProc.waitForProcessOutput(javaHomeOut, javaHomeErr)
- def jdkHome = new File(javaHomeOut.toString().trim())
- if (!jdkHome.exists()) {
- println "WARNING: Failed to find the ./tools/jdk.py specified JDK: " + jdkHome
- } else if (jdkHome != org.gradle.internal.jvm.Jvm.current().javaHome) {
- println("WARNING: Gradle is running in a non-pinned Java"
- + ". Gradle Java Home: " + org.gradle.internal.jvm.Jvm.current().javaHome
- + ". Expected: " + jdkHome)
- } else {
- println("NOTE: Running with jdk from tools/jdk.py: " + jdkHome)
- }
-}
-
-compileJava.dependsOn downloadCloudDeps
-
-sourceSets.configureEach { sourceSet ->
- tasks.named(sourceSet.compileJavaTaskName).configure {
- // Default disable errorprone (enabled and setup below).
- options.errorprone.enabled = false
- options.compilerArgs << '-Xlint:unchecked'
- // Run all compilation tasks in a forked subprocess.
- options.fork = true
- // Javac often runs out of stack space when compiling the tests.
- // Increase the stack size for the javac process.
- options.forkOptions.jvmArgs << "-Xss256m"
- // Test compilation is sometimes hitting the default limit at 1g, increase it.
- options.forkOptions.jvmArgs << "-Xmx3g"
- }
-}
-
-def setJdkCompilationWithCompatibility(String sourceSet, String javaHome, JavaVersion compatibility, boolean enablePreview) {
- tasks.named(sourceSet).get().configure {
- def jdkDir = "third_party/openjdk/${javaHome}/"
- options.fork = true
- options.forkOptions.jvmArgs = []
- if (enablePreview) {
- options.compilerArgs.add('--enable-preview')
- }
- if (OperatingSystem.current().isLinux()) {
- dependsOn getDownloadDepsTaskName("third_party", "openjdk/" + javaHome + "/linux")
- options.forkOptions.javaHome = file(jdkDir + 'linux')
- } else if (OperatingSystem.current().isMacOsX()) {
- dependsOn getDownloadDepsTaskName("third_party", "openjdk/" + javaHome + "/osx")
- options.forkOptions.javaHome = compatibility > JavaVersion.VERSION_1_9
- ? file(jdkDir + 'osx/Contents/Home')
- : file(jdkDir + 'osx')
- } else {
- dependsOn getDownloadDepsTaskName("third_party", "openjdk/" + javaHome + "/windows")
- options.forkOptions.javaHome = file(jdkDir + 'windows')
- }
- sourceCompatibility = compatibility
- targetCompatibility = compatibility
- }
-}
-
-setJdkCompilationWithCompatibility(
- sourceSets.main.compileJavaTaskName,
- 'jdk-11',
- JavaVersion.VERSION_11,
- false);
-
-setJdkCompilationWithCompatibility(
- sourceSets.examplesJava9.compileJavaTaskName,
- 'openjdk-9.0.4',
- JavaVersion.VERSION_1_9,
- false)
-setJdkCompilationWithCompatibility(
- sourceSets.examplesJava10.compileJavaTaskName,
- 'jdk-11',
- JavaVersion.VERSION_1_10,
- false)
-setJdkCompilationWithCompatibility(
- sourceSets.main17.compileJavaTaskName,
- 'jdk-17',
- JavaVersion.VERSION_17,
- false)
-setJdkCompilationWithCompatibility(
- sourceSets.examplesJava11.compileJavaTaskName,
- 'jdk-11',
- JavaVersion.VERSION_11,
- false)
-setJdkCompilationWithCompatibility(
- sourceSets.examplesJava17.compileJavaTaskName,
- 'jdk-17',
- JavaVersion.VERSION_17,
- false)
-setJdkCompilationWithCompatibility(
- sourceSets.examplesJava20.compileJavaTaskName,
- 'jdk-20',
- // TODO(b/218293990): Update Gradle to get JavaVersion.VERSION_18.
- JavaVersion.VERSION_17,
- false)
-
-if (!project.hasProperty('without_error_prone') &&
- // Don't enable error prone on Java 8 as the plugin setup does not support it.
- !org.gradle.internal.jvm.Jvm.current().javaVersion.java8) {
- compileJava {
-
- // Enable error prone for D8/R8 main sources.
- options.errorprone.enabled = true
-
- // Make all warnings errors. Warnings that we have chosen not to fix (or suppress) are
- // disabled outright below.
- options.compilerArgs << "-Werror"
-
- // Increase number of reported errors to 1000 (default is 100).
- options.compilerArgs << "-Xmaxerrs"
- options.compilerArgs << "1000"
-
- // Non-default / Experimental checks - explicitly enforced.
- options.errorprone.check('RemoveUnusedImports', CheckSeverity.ERROR)
- options.errorprone.check('InconsistentOverloads', CheckSeverity.ERROR)
- options.errorprone.check('MissingDefault', CheckSeverity.ERROR)
- options.errorprone.check('MultipleTopLevelClasses', CheckSeverity.ERROR)
- options.errorprone.check('NarrowingCompoundAssignment', CheckSeverity.ERROR)
-
- // Warnings that cause unwanted edits (e.g., inability to write informative asserts).
- options.errorprone.check('AlreadyChecked', CheckSeverity.OFF)
-
- // JavaDoc related warnings. Would be nice to resolve but of no real consequence.
- options.errorprone.check('InvalidLink', CheckSeverity.OFF)
- options.errorprone.check('InvalidBlockTag', CheckSeverity.OFF)
- options.errorprone.check('InvalidInlineTag', CheckSeverity.OFF)
- options.errorprone.check('EmptyBlockTag', CheckSeverity.OFF)
- options.errorprone.check('MissingSummary', CheckSeverity.OFF)
- options.errorprone.check('UnrecognisedJavadocTag', CheckSeverity.OFF)
- options.errorprone.check('AlmostJavadoc', CheckSeverity.OFF)
-
- // Moving away from identity and canonical items is not planned.
- options.errorprone.check('IdentityHashMapUsage', CheckSeverity.OFF)
- }
-}
-
-task consolidatedLicense {
- def license = new File(new File(buildDir, 'generatedLicense'), 'LICENSE')
-
- inputs.files files('LICENSE', 'LIBRARY-LICENSE') + fileTree(dir: 'library-licensing')
- def runtimeClasspath = configurations.findByName("runtimeClasspath")
- inputs.files { runtimeClasspath.getResolvedConfiguration().files }
-
- outputs.files license
-
- doLast {
- def dependencies = []
- runtimeClasspath.resolvedConfiguration.resolvedArtifacts.each {
- def identifier = (ModuleComponentIdentifier) it.id.componentIdentifier
- dependencies.add("${identifier.group}:${identifier.module}")
- }
- def libraryLicenses = file('LIBRARY-LICENSE').text
- dependencies.each {
- if (!libraryLicenses.contains("- artifact: $it")) {
- throw new GradleException("No license for $it in LIBRARY_LICENSE")
- }
- }
-
- license.getParentFile().mkdirs()
- license.createNewFile()
- license.text = "This file lists all licenses for code distributed.\n"
- license.text += "All non-library code has the following 3-Clause BSD license.\n"
- license.text += "\n"
- license.text += "\n"
- license.text += file('LICENSE').text
- license.text += "\n"
- license.text += "\n"
- license.text += "Summary of distributed libraries:\n"
- license.text += "\n"
- license.text += libraryLicenses
- license.text += "\n"
- license.text += "\n"
- license.text += "Licenses details:\n"
- fileTree(dir: 'library-licensing').getFiles().stream().sorted().forEach { file ->
- license.text += "\n"
- license.text += "\n"
- license.text += file.text
- }
- }
-}
-
-def repackageDepFile(file) {
- if (file.getName().endsWith('.jar')) {
- return zipTree(file).matching {
- exclude '**/module-info.class'
- exclude 'META-INF/maven/**'
- exclude 'META-INF/LICENSE.txt'
- exclude 'META-INF/MANIFEST.MF'
- }
- } else {
- return fileTree(file)
- }
-}
-
-task repackageDeps(type: Jar) {
- dependsOn downloadCloudDeps
- dependsOn project.configurations.runtimeClasspath
- project.configurations.runtimeClasspath.forEach {
- from repackageDepFile(it)
- }
- archiveFileName = 'deps_all.jar'
-}
-
-task repackageTestDeps(type: Jar) {
- dependsOn downloadCloudDeps
- dependsOn project.configurations.testCompile
- project.configurations.testCompile.forEach {
- from repackageDepFile(it)
- }
- archiveFileName = 'test_deps_all.jar'
-}
-
-task repackageSources(type: Jar) {
- // If this fails then remove all generated folders from
- // build/classes/java/test that is not {com,dalvik}
- from sourceSets.main.output
- archiveFileName = 'sources_main.jar'
-}
-
-task repackageSources17(type: Jar) {
- from sourceSets.main17.output
- archiveFileName = 'sources_main_17.jar'
-}
-
-def r8CreateTask(name, baseName, sources, includeLibraryLicenses, includeSwissArmyKnife) {
- return tasks.create("r8Create${name}", Jar) {
- entryCompression ZipEntryCompression.STORED
- dependsOn sources
- dependsOn files('LICENSE')
- if (includeLibraryLicenses) {
- from consolidatedLicense.outputs.files
- } else {
- from files('LICENSE')
- }
- from sources.collect { zipTree(it) }
- exclude "$buildDir/classes/**"
- archiveFileName = baseName
- if (includeSwissArmyKnife) {
- manifest {
- attributes 'Main-Class': 'com.android.tools.r8.SwissArmyKnife'
- }
- }
- exclude "META-INF/*.kotlin_module"
- exclude "**/*.kotlin_metadata"
- }
-}
-
-def r8RelocateTask(r8Task, output) {
- return tasks.create("r8Relocate_${r8Task.name}", Exec) {
- dependsOn r8WithDeps
- dependsOn r8Task
- outputs.file output
- workingDir = projectDir
- inputs.files r8Task.outputs.files + r8WithDeps.outputs.files
- commandLine baseCompilerCommandLine([
- "relocator",
- "--input",
- r8Task.outputs.files[0],
- "--output",
- output,
- "--map",
- "com.google.common.**->com.android.tools.r8.com.google.common",
- "--map",
- "com.google.gson.**->com.android.tools.r8.com.google.gson",
- "--map",
- "com.google.thirdparty.**->com.android.tools.r8.com.google.thirdparty",
- "--map",
- "org.objectweb.asm.**->com.android.tools.r8.org.objectweb.asm",
- "--map",
- "it.unimi.dsi.fastutil.**->com.android.tools.r8.it.unimi.dsi.fastutil",
- "--map",
- "kotlin.**->com.android.tools.r8.jetbrains.kotlin",
- "--map",
- "kotlinx.**->com.android.tools.r8.jetbrains.kotlinx",
- "--map",
- "org.jetbrains.**->com.android.tools.r8.org.jetbrains",
- "--map",
- "org.intellij.**->com.android.tools.r8.org.intellij",
- "--map",
- "org.checkerframework.**->com.android.tools.r8.org.checkerframework"
- ])
- }
-}
-
-task r8WithDeps {
- dependsOn repackageSources
- dependsOn repackageDeps
- inputs.files ([repackageSources.outputs, repackageDeps.outputs])
- def r8Task = r8CreateTask(
- 'WithDeps',
- 'r8_with_deps.jar',
- repackageSources.outputs.files + repackageDeps.outputs.files,
- true,
- true)
- dependsOn r8Task
- outputs.files r8Task.outputs.files
-}
-
-task r8WithDeps17 {
- dependsOn repackageSources17
- dependsOn repackageDeps
- inputs.files ([repackageSources17.outputs, repackageDeps.outputs])
- def r8Task = r8CreateTask(
- 'WithDeps17',
- 'r8_with_deps_17.jar',
- repackageSources17.outputs.files + repackageDeps.outputs.files,
- true,
- true)
- dependsOn r8Task
- outputs.files r8Task.outputs.files
-}
-
-task r8WithRelocatedDeps {
- def output = "${buildDir}/libs/r8_with_relocated_deps.jar"
- dependsOn r8RelocateTask(r8WithDeps, output)
- inputs.files r8WithDeps.outputs.files
- outputs.file output
-}
-
-task r8WithRelocatedDeps17 {
- def output = "${buildDir}/libs/r8_with_relocated_deps_17.jar"
- dependsOn r8RelocateTask(r8WithDeps17, output)
- inputs.files r8WithDeps17.outputs.files
- outputs.file output
-}
-
-task r8WithoutDeps {
- dependsOn repackageSources
- inputs.files repackageSources.outputs
- def r8Task = r8CreateTask(
- 'WithoutDeps',
- 'r8_without_deps.jar',
- repackageSources.outputs.files,
- false,
- true)
- dependsOn r8Task
- outputs.files r8Task.outputs.files
-}
-
-task r8(type: Copy) {
- def r8Task = project.hasProperty("exclude_deps")
- ? r8WithoutDeps : r8WithRelocatedDeps
- dependsOn r8Task
- from r8Task.outputs.files[0]
- into file("${buildDir}/libs")
- rename { String fileName -> "r8.jar" }
- outputs.file "${buildDir}/libs/r8.jar"
-}
-
-task r8NoManifestWithoutDeps {
- dependsOn repackageSources
- inputs.files repackageSources.outputs
- def r8Task = r8CreateTask(
- 'NoManifestWithoutDeps',
- 'r8_no_manifest_without_deps.jar',
- repackageSources.outputs.files,
- false,
- false)
- dependsOn r8Task
- outputs.files r8Task.outputs.files
-}
-
-task r8NoManifestWithDeps {
- dependsOn repackageSources
- inputs.files ([repackageSources.outputs, repackageDeps.outputs])
- def r8Task = r8CreateTask(
- 'NoManifestWithDeps',
- 'r8_no_manifest_with_deps.jar',
- repackageSources.outputs.files + repackageDeps.outputs.files,
- true,
- false)
- dependsOn r8Task
- outputs.files r8Task.outputs.files
-}
-
-task r8NoManifestWithRelocatedDeps {
- def output = "${buildDir}/libs/r8_no_manifest_with_relocated_deps.jar"
- dependsOn r8RelocateTask(r8NoManifestWithDeps, output)
- inputs.files r8NoManifestWithDeps.outputs.files
- outputs.file output
-}
-
-task r8NoManifest(type: Copy) {
- def r8Task = project.hasProperty("exclude_deps")
- ? r8NoManifestWithoutDeps : r8NoManifestWithRelocatedDeps
- dependsOn r8Task
- from r8Task.outputs.files[0]
- into file("${buildDir}/libs")
- rename { String fileName -> "r8_no_manifest.jar" }
- outputs.file "${buildDir}/libs/r8_no_manifest.jar"
-}
-
-def baseCompilerCommandLine(compiler, args = []) {
- // Execute r8 commands against a stable r8 with dependencies.
- // TODO(b/139725780): See if we can remove or lower the heap size (-Xmx8g).
- return [org.gradle.internal.jvm.Jvm.current().getJavaExecutable(),
- "-Xmx8g", "-ea", "-jar", r8WithDeps.outputs.files[0]] + compiler + args
-}
-
-def baseR8CommandLine(args = []) {
- // Execute r8 commands against a stable r8 with dependencies.
- return baseCompilerCommandLine("r8", args)
-}
-
-def baseD8CommandLine(args = []) {
- // Execute r8 commands against a stable r8 with dependencies.
- return baseCompilerCommandLine("d8", args)
-}
-
-def r8CfCommandLine(input, output, pgConfs = [], args = ["--release"], libs = []) {
- def allArgs = [
- "--classfile",
- input,
- "--output", output,
- "--pg-map-output", output + ".map",
- "--partition-map-output", output + "_map.zip",
- "--lib", org.gradle.internal.jvm.Jvm.current().javaHome,
- ] + args + libs.collectMany { ["--lib", it] } + pgConfs.collectMany { ["--pg-conf", it] }
- return baseR8CommandLine(allArgs)
-}
-
-def d8CfCommandLine(input, output, args = ["--release"], libs = []) {
- def allArgs = [
- "--classfile",
- input,
- "--output", output,
- "--lib", "third_party/openjdk/openjdk-rt-1.8/rt.jar"
- ] + args + libs.collectMany { ["--lib", it] }
- return baseD8CommandLine(allArgs)
-}
-
-def r8LibCreateTask(
- name, pgConfs = [], r8Task, output, libs = [], classpath = [], excldeps=false, debug=false) {
- return tasks.create("r8Lib${name}", Exec) {
- inputs.files ([pgConfs, r8WithRelocatedDeps.outputs, r8Task.outputs])
- outputs.file output
- dependsOn downloadOpenJDKrt
- dependsOn r8WithRelocatedDeps
- dependsOn r8Task
- commandLine ([
- "python3", "tools/create_r8lib.py",
- "--r8jar", r8Task.outputs.files[0],
- "--output", output]
- + (excldeps ? ['--excldeps-variant'] : [])
- + (debug ? ['--debug-variant'] : [])
- + (pgConfs.collectMany { ["--pg-conf", it] })
- + (libs.collectMany { ["--lib", it] })
- + (classpath.collectMany { ["--classpath", it] }))
- workingDir = projectDir
- }
-}
-
-task testJarSources(type: Jar, dependsOn: [testClasses]) {
- archiveFileName = "r8testsbase.jar"
- from sourceSets.test.output
- // We only want to include tests that use R8 when generating keep rules for applymapping.
- include "com/android/tools/r8/**"
- include "android/**"
- include "dalvik/**"
-}
-
-task testJar(type: Exec) {
- dependsOn r8WithDeps
- dependsOn testJarSources
- def output = "$buildDir/libs/r8tests.jar"
- outputs.file output
- workingDir = projectDir
- inputs.files (testJarSources.outputs.files + r8WithDeps.outputs.files)
- commandLine baseCompilerCommandLine([
- "relocator",
- "--input",
- testJarSources.outputs.files[0],
- "--output",
- output,
- "--map",
- "kotlinx.metadata.**->com.android.tools.r8.jetbrains.kotlinx.metadata"
- ])
-}
-
-task generateR8LibKeepRules(type: Exec) {
- // Depend on r8WithRelocatedDeps to ensure that we do not have external
- // dependencies crossing the boundary.
- dependsOn r8WithDeps
- dependsOn r8NoManifestWithRelocatedDeps
- dependsOn testJar
- dependsOn repackageTestDeps
- dependsOn downloadOpenJDKrt
- inputs.files ([
- r8WithDeps.outputs,
- r8NoManifestWithRelocatedDeps.outputs,
- repackageDeps.outputs,
- repackageTestDeps.outputs,
- testJar.outputs])
- outputs.file r8LibGeneratedKeepRulesPath
- commandLine baseCompilerCommandLine([
- "tracereferences",
- "--keep-rules",
- "--allowobfuscation",
- "--lib",
- "third_party/openjdk/openjdk-rt-1.8/rt.jar",
- "--lib",
- repackageDeps.outputs.files[0],
- "--lib",
- repackageTestDeps.outputs.files[0],
- "--target",
- r8NoManifestWithRelocatedDeps.outputs.files[0],
- "--source",
- testJar.outputs.files[0],
- "--output",
- r8LibGeneratedKeepRulesPath])
- workingDir = projectDir
-}
-
-task R8Lib {
- dependsOn r8LibCreateTask(
- "Main",
- ["src/main/keep.txt", generateR8LibKeepRules.outputs.files[0]],
- r8NoManifestWithRelocatedDeps,
- r8LibPath
- ).dependsOn(generateR8LibKeepRules)
- inputs.files r8NoManifestWithRelocatedDeps.outputs.files
- outputs.file r8LibPath
-}
-
-task R8LibNoDeps {
- dependsOn r8LibCreateTask(
- "MainNoDeps",
- ["src/main/keep.txt"],
- r8NoManifestWithoutDeps,
- r8LibExludeDepsPath,
- [],
- repackageDeps.outputs.files,
- true,
- ).dependsOn(repackageDeps)
- inputs.files ([r8NoManifestWithoutDeps.outputs, repackageDeps.outputs])
- outputs.file r8LibExludeDepsPath
-}
-
-task R8Desugared(type: Exec) {
- dependsOn downloadOpenJDKrt
- dependsOn r8NoManifestWithRelocatedDeps
- inputs.files r8NoManifestWithRelocatedDeps.outputs.files
- commandLine d8CfCommandLine(
- r8NoManifestWithRelocatedDeps.outputs.files[0],
- r8DesugaredPath,
- ["--release"])
- workingDir = projectDir
- outputs.file r8DesugaredPath
-}
-
-task R8Retrace {
- dependsOn R8Lib
- dependsOn r8LibCreateTask(
- "Retrace",
- ["src/main/keep_retrace.txt"],
- R8Lib,
- r8RetracePath,
- [],
- [],
- false,
- true
- ).dependsOn(R8Lib)
- outputs.file r8RetracePath
-}
-
-task R8RetraceNoDeps {
- dependsOn R8LibNoDeps
- dependsOn r8LibCreateTask(
- "RetraceNoDeps",
- ["src/main/keep_retrace.txt"],
- R8LibNoDeps,
- r8RetraceExludeDepsPath,
- [],
- repackageDeps.outputs.files,
- true,
- true,
- ).dependsOn(R8LibNoDeps)
- outputs.file r8RetraceExludeDepsPath
-}
-
-task sourceJar(type: Jar, dependsOn: classes) {
- classifier = 'src'
- from sourceSets.main.allSource
-}
-
-task keepAnnoJar(type: Jar) {
- archiveFileName = "keepanno-annotations.jar"
- from sourceSets.keepanno.output
-}
-
-artifacts {
- archives sourceJar
-}
-
-task createArtTests(type: Exec) {
- def outputDir = "build/generated/test/java/com/android/tools/r8/art"
- def createArtTestsScript = "tools/create_art_tests.py"
- inputs.files files("tests/2017-10-04/art.tar.gz", createArtTestsScript)
- outputs.dir outputDir
- dependsOn downloadDeps
- commandLine "python3", createArtTestsScript
- workingDir = projectDir
-}
-
-compileTestJava {
- dependsOn createArtTests
-}
-
-task buildCfSegments(type: Jar, dependsOn: downloadDeps) {
- from sourceSets.cfSegments.output
- archiveFileName = 'cf_segments.jar'
- destinationDir file('build/libs')
-}
-
-task buildR8ApiUsageSample(type: Jar) {
- from sourceSets.apiUsageSample.output
- archiveFileName = 'r8_api_usage_sample.jar'
- destinationDir file('tests')
-}
-
-task buildApiSampleJars {
- dependsOn buildR8ApiUsageSample
-}
-
-def buildExampleJarsCreateTask(javaVersion, sourceSet) {
- return tasks.create("buildExample${javaVersion}Jars") {
- def examplesDir = file("src/test/examples${javaVersion}")
- examplesDir.eachDir { dir ->
- def name = dir.getName();
- def exampleOutputDir = file("build/test/examples${javaVersion}");
- def jarName = "${name}.jar"
- dependsOn "jar_examples${javaVersion}_${name}"
- task "jar_examples${javaVersion}_${name}"(type: Jar) {
- archiveName = jarName
- destinationDir = exampleOutputDir
- from sourceSet.output
- include "**/" + name + "/**/*.class"
- }
- }
- }
-}
-
-buildExampleJarsCreateTask("Java9", sourceSets.examplesJava9)
-buildExampleJarsCreateTask("Java10", sourceSets.examplesJava10)
-buildExampleJarsCreateTask("Java11", sourceSets.examplesJava11)
-buildExampleJarsCreateTask("Java17", sourceSets.examplesJava17)
-buildExampleJarsCreateTask("Java20", sourceSets.examplesJava20)
-
-task buildExamples {
- if (OperatingSystem.current().isMacOsX() || OperatingSystem.current().isWindows()) {
- logger.lifecycle("WARNING: Testing (including building examples) is only partially supported on your " +
- "platform (" + OperatingSystem.current().getName() + ").")
- } else if (!OperatingSystem.current().isLinux()) {
- logger.lifecycle("WARNING: Testing (including building examples) is not supported on your platform. " +
- "It is fully supported on Linux and partially supported on Mac OS and Windows")
- return;
- }
- dependsOn buildExampleJava9Jars
- dependsOn buildExampleJava10Jars
- dependsOn buildExampleJava11Jars
- dependsOn buildExampleJava17Jars
- dependsOn buildExampleJava20Jars
-}
-
-tasks.withType(Test) {
- println("NOTE: Number of processors " + Runtime.runtime.availableProcessors())
- def userDefinedCoresPerFork = System.getenv('R8_GRADLE_CORES_PER_FORK')
- def processors = Runtime.runtime.availableProcessors()
- // See https://docs.gradle.org/current/dsl/org.gradle.api.tasks.testing.Test.html.
- if (userDefinedCoresPerFork) {
- maxParallelForks = processors.intdiv(userDefinedCoresPerFork.toInteger()) ?: 1
- } else {
- // On normal work machines this seems to give the best test execution time (without freezing)
- maxParallelForks = processors.intdiv(3) ?: 1
- // On low cpu count machines (bots) we under subscribe, so increase the count.
- if (processors == 32) {
- maxParallelForks = 15
- }
- }
- println("NOTE: Max parallel forks " + maxParallelForks)
-
- forkEvery = 0
- if (project.hasProperty('disable_assertions')) {
- enableAssertions = false
- }
- // TODO(b/124091860): Increase the max heap size to avoid OOM when running tests.
- if (project.hasProperty('test_xmx')) {
- maxHeapSize = project.property('test_xmx')
- } else {
- maxHeapSize = "4G"
- }
-}
-
-task generateR8TestKeepRules {
- def path = "build/generated/r8tests-keep.txt"
- outputs.file path
- dependsOn R8Lib
- doLast {
- file(path).write """-keep class ** { *; }
--dontshrink
--dontoptimize
--keepattributes *
--applymapping ${R8Lib.outputs.files[0]}.map
-"""
- }
-}
-
-task buildR8LibCfTestDeps(type: Exec) {
- def outputPath = "build/libs/r8libtestdeps-cf.jar"
- dependsOn downloadDeps
- dependsOn r8NoManifest
- dependsOn R8Lib
- dependsOn generateR8TestKeepRules
- dependsOn testJar
- // Take all .jar files as libraries and append the generated test classes in classes/java/test.
- def addedLibraries = sourceSets.test.runtimeClasspath.findAll { pkg ->
- return pkg.toString().endsWith(".jar")
- } + ["${buildDir}/classes/java/test"]
- inputs.files testJar.outputs.files +
- generateR8TestKeepRules.outputs.files +
- R8Lib.outputs
- commandLine = r8CfCommandLine(
- testJar.outputs.files[0],
- outputPath,
- [generateR8TestKeepRules.outputs.files[0]],
- ["--debug", "--classpath", r8NoManifest.outputs.files[0]],
- r8NoManifest.outputs.files + addedLibraries)
- workingDir = projectDir
- outputs.file outputPath
-}
-
-task configureTestForR8Lib(type: Copy) {
- dependsOn testJar
- inputs.files buildR8LibCfTestDeps.outputs
- dependsOn R8Lib
- delete r8LibTestPath
- from zipTree(buildR8LibCfTestDeps.outputs.files[0])
- def examplesDir = file("build/test")
- if (examplesDir.exists()) {
- examplesDir.eachDir { dir ->
- from ("${buildDir}/test/${dir.getName()}/classes")
- }
- }
- from ("${buildDir}/runtime/examples")
- into r8LibTestPath
- outputs.dir r8LibTestPath
-}
-
-def shouldRetrace() {
- return project.hasProperty('r8lib') || project.hasProperty('r8lib_no_deps')
-}
-
-def retrace(Throwable exception) {
- def out = new StringBuffer()
- def err = new StringBuffer()
- def command = "python3 tools/retrace.py --quiet"
- def header = "RETRACED STACKTRACE";
- out.append("\n--------------------------------------\n")
- out.append("${header}\n")
- out.append("--------------------------------------\n")
- Process process = command.execute()
- def processIn = new PrintStream(process.getOut())
- process.consumeProcessOutput(out, err)
- exception.printStackTrace(processIn)
- processIn.flush()
- processIn.close()
- def errorDuringRetracing = process.waitFor() != 0
- if (errorDuringRetracing) {
- out.append("ERROR DURING RETRACING\n")
- out.append(err.toString())
- }
- if (project.hasProperty('print_obfuscated_stacktraces') || errorDuringRetracing) {
- out.append("\n\n--------------------------------------\n")
- out.append("OBFUSCATED STACKTRACE\n")
- out.append("--------------------------------------\n")
- }
- return out.toString()
-}
-
-def printStackTrace(TestResult result) {
- filterStackTraces(result)
- if (shouldRetrace()) {
- def exception = new Exception(retrace(result.exception))
- exception.setStackTrace([] as StackTraceElement[])
- result.exceptions.add(0, exception)
- }
-}
-
-def filterStackTraces(TestResult result) {
- for (Throwable throwable : result.getExceptions()) {
- filterStackTrace(throwable)
- }
-}
-
-// It would be nice to do this in a non-destructive way...
-def filterStackTrace(Throwable exception) {
- if (!project.hasProperty('print_full_stacktraces')) {
- def elements = []
- def skipped = []
- for (StackTraceElement element : exception.getStackTrace()) {
- if (element.toString().contains("com.android.tools.r8")) {
- elements.addAll(skipped)
- elements.add(element)
- skipped.clear()
- } else {
- skipped.add(element)
- }
- }
- exception.setStackTrace(elements as StackTraceElement[])
- }
-}
-
-def printAllStackTracesToFile(List<Throwable> exceptions, File out) {
- new PrintStream(new FileOutputStream(out)).withCloseable {printer ->
- exceptions.forEach { it.printStackTrace(printer) }
- }
-}
-
-static def escapeHtml(String string) {
- return string.replace("&", "&").replace("<", "<").replace(">", ">")
-}
-
-static def urlEncode(String string) {
- // Not sure why, but the + also needs to be converted to have working links.
- return URLEncoder.encode(string, "UTF-8").replace("+","%20")
-}
-
-def ensureDir(File dir) {
- dir.mkdirs()
- return dir
-}
-
-// Some of our test parameters have new lines :-( We really don't want test names to span lines.
-static def sanitizedTestName(testDesc) {
- if (testDesc.getName().contains("\n")) {
- throw new RuntimeException("Unsupported use of newline in test name: '${testDesc.getName()}'")
- }
- return testDesc.getName()
-}
-
-static def desanitizedTestName(testName) {
- return testName
-}
-
-def getTestReportEntryDir(reportDir, testDesc) {
- return ensureDir(reportDir.toPath()
- .resolve(testDesc.getClassName())
- .resolve(sanitizedTestName(testDesc))
- .toFile())
-}
-
-def getTestReportEntryURL(reportDir, testDesc) {
- def classDir = urlEncode(testDesc.getClassName())
- def testDir = urlEncode(sanitizedTestName(testDesc))
- return "file://${reportDir}/${classDir}/${testDir}"
-}
-
-def getTestResultEntryOutputFile(reportDir, testDesc, fileName) {
- def dir = getTestReportEntryDir(reportDir, testDesc).toPath()
- return dir.resolve(fileName).toFile()
-}
-
-def withTestResultEntryWriter(reportDir, testDesc, fileName, append, fn) {
- def file = getTestResultEntryOutputFile(reportDir, testDesc, fileName)
- new FileWriter(file, append).withCloseable fn
-}
-
-static def getGitBranchName() {
- def out = new StringBuilder()
- def err = new StringBuilder()
- def proc = "git rev-parse --abbrev-ref HEAD".execute()
- proc.waitForProcessOutput(out, err)
- return out.toString().trim()
-}
-
-static def getFreshTestReportIndex(File reportDir) {
- def number = 0
- while (true) {
- def freshIndex = reportDir.toPath().resolve("index.${number++}.html").toFile()
- if (!freshIndex.exists()) {
- return freshIndex
- }
- }
-}
-
-def forEachTestReportAlreadyX(File reportDir, fileName, onTest) {
- def out = new StringBuilder()
- def err = new StringBuilder()
- def proc = "find . -name ${fileName}".execute([], reportDir)
- proc.waitForProcessOutput(out, err)
- def outString = out.toString()
- outString.eachLine {
- // Lines are of the form: ./<class>/<name>/FAILURE
- def clazz = null
- def name = null
- try {
- def trimmed = it.trim()
- def line = trimmed.substring(2)
- def sep = line.indexOf("/")
- clazz = line.substring(0, sep)
- name = line.substring(sep + 1, line.length() - fileName.length() - 1)
- } catch (Exception e) {
- logger.lifecycle("WARNING: failed attempt to read test description from: '${it}'")
- return
- }
- onTest(clazz, desanitizedTestName(name))
- }
- return !outString.trim().isEmpty()
-}
-
-def forEachTestReportAlreadyFailing(File reportDir, onFailureTest) {
- return forEachTestReportAlreadyX(reportDir, TestResult.ResultType.FAILURE.name(), onFailureTest)
-}
-
-def forEachTestReportAlreadyPassing(File reportDir, onSucceededTest) {
- return forEachTestReportAlreadyX(reportDir, TestResult.ResultType.SUCCESS.name(), onSucceededTest)
-}
-
-def forEachTestReportAlreadySkipped(File reportDir, onSucceededTest) {
- return forEachTestReportAlreadyX(reportDir, TestResult.ResultType.SKIPPED.name(), onSucceededTest)
-}
-
-def setUpTestingState(Test task) {
- // Hide all test events from the console, they are written to the report.
- task.testLogging { events = [] }
-
- def branch = project.hasProperty('testing-state-name')
- ? project.getProperty('testing-state-name')
- : getGitBranchName()
- def reportDir = file("${buildDir}/test-state/${branch}")
- def index = reportDir.toPath().resolve("index.html").toFile()
- def resetState = project.hasProperty('reset-testing-state')
- def reportDirExists = reportDir.exists()
- def resuming = !resetState && reportDirExists
-
- def hasFailingTests = false;
- if (resuming) {
- // Test filtering happens before the test execution is initiated so compute it here.
- // If there are still failing tests in the report, include only those.
- hasFailingTests = forEachTestReportAlreadyFailing(reportDir, {
- clazz, name -> task.filter.includeTestsMatching("$clazz.$name")
- })
- // Otherwise exclude all of the test already marked as succeeding.
- if (!hasFailingTests) {
- // Also allow the test to overall succeed if there are no remaining tests that match,
- // which is natural if the state already succeeded in full.
- task.filter.failOnNoMatchingTests = false
- forEachTestReportAlreadyPassing(reportDir, {
- clazz, name -> task.filter.excludeTestsMatching("$clazz.$name")
- })
- forEachTestReportAlreadySkipped(reportDir, {
- clazz, name -> task.filter.excludeTestsMatching("$clazz.$name")
- })
- }
- }
-
- task.beforeSuite { desc ->
- if (!desc.parent) {
- def parentReport = null
- if (resetState && reportDirExists) {
- delete reportDir
- }
- if (resuming) {
- if (index.exists()) {
- parentReport = getFreshTestReportIndex(reportDir)
- index.renameTo(parentReport)
- }
- } else {
- reportDir.mkdirs()
- }
- def runPrefix = resuming ? "Resuming" : "Starting"
- def title = "${runPrefix} @ ${branch}"
- // Print a console link to the test report for easy access.
- println "${runPrefix} test, report written to:"
- println " file://${index}"
- // Print the new index content.
- index << "<html><head><title>${title}</title>"
- index << "<style> * { font-family: monospace; }</style>"
- index << "<meta http-equiv='refresh' content='10' />"
- index << "</head><body><h1>${title}</h1>"
- index << "<p>Run on: ${new Date()}</p>"
- index << "<p>Git branch: ${branch}</p>"
- if (parentReport != null) {
- index << "<p><a href=\"file://${parentReport}\">Previous result index</a></p>"
- }
- index << "<p><a href=\"file://${index}\">Most recent result index</a></p>"
- index << "<p><a href=\"file://${reportDir}\">Test directories</a></p>"
- index << "<h2>Failing tests (refreshing automatically every 10 seconds)</h2><ul>"
- }
- }
-
- task.afterSuite { desc, result ->
- if (!desc.parent) {
- // Update the final test results in the index.
- index << "</ul>"
- if (result.resultType == TestResult.ResultType.SUCCESS) {
- if (hasFailingTests) {
- index << "<h2>Rerun of failed tests now pass!</h2>"
- index << "<h2>Rerun again to continue with outstanding tests!</h2>"
- } else {
- index << "<h2 style=\"background-color:#62D856\">GREEN BAR == YOU ROCK!</h2>"
- }
- } else if (result.resultType == TestResult.ResultType.FAILURE) {
- index << "<h2 style=\"background-color:#6D130A\">Some tests failed: ${result.resultType.name()}</h2><ul>"
- } else {
- index << "<h2>Tests finished: ${result.resultType.name()}</h2><ul>"
- }
- index << "<li>Number of tests: ${result.testCount}"
- index << "<li>Failing tests: ${result.failedTestCount}"
- index << "<li>Successful tests: ${result.successfulTestCount}"
- index << "<li>Skipped tests: ${result.skippedTestCount}"
- index << "</ul></body></html>"
- }
- }
-
- // Events to stdout/err are appended to the files in the test directories.
- task.onOutput { desc, event ->
- withTestResultEntryWriter(reportDir, desc, event.getDestination().name(), true, {
- it.append(event.getMessage())
- })
- }
-
- task.beforeTest { desc ->
- // Remove any stale output files before running the test.
- for (def destType : TestOutputEvent.Destination.values()) {
- def destFile = getTestResultEntryOutputFile(reportDir, desc, destType.name())
- if (destFile.exists()) {
- delete destFile
- }
- }
- }
-
- task.afterTest { desc, result ->
- if (result.getTestCount() != 1) {
- throw new IllegalStateException("Unexpected test with more than one result: ${desc}")
- }
- // Clear any previous result files.
- for (def resultType : TestResult.ResultType.values()) {
- delete getTestResultEntryOutputFile(reportDir, desc, resultType.name())
- }
- // Emit the result type status in a file of the same name: SUCCESS, FAILURE or SKIPPED.
- withTestResultEntryWriter(reportDir, desc, result.getResultType().name(), false, {
- it.append(result.getResultType().name())
- })
- // Emit the test time.
- withTestResultEntryWriter(reportDir, desc, "time", false, {
- it.append("${result.getEndTime() - result.getStartTime()}")
- })
- // For failed tests, update the index and emit stack trace information.
- if (result.resultType == TestResult.ResultType.FAILURE) {
- def title = escapeHtml("${desc.className}.${desc.name}")
- def link = getTestReportEntryURL(reportDir, desc)
- index << "<li><a href=\"${link}\">${title}</a></li>"
- if (!result.exceptions.isEmpty()) {
- printAllStackTracesToFile(
- result.exceptions,
- getTestResultEntryOutputFile(
- reportDir,
- desc,
- "exceptions-raw.txt"))
- filterStackTraces(result)
- printAllStackTracesToFile(
- result.exceptions,
- getTestResultEntryOutputFile(
- reportDir,
- desc,
- "exceptions-filtered.txt"))
- if (shouldRetrace()) {
- withTestResultEntryWriter(reportDir, desc, "exceptions-retraced.txt", false, { writer ->
- result.exceptions.forEach { writer.append(retrace(it)) }
- })
- }
- }
- }
- }
-}
-
-def testTimes = [:]
-def numberOfTestTimesToPrint = 100
-
-test { task ->
-
- dependsOn sourceSets.keepanno.output
- // R8.jar is required for running bootstrap tests.
- dependsOn r8
-
- def useTestingState = project.hasProperty('testing-state')
- if (useTestingState) {
- setUpTestingState(task)
- }
-
- if (project.hasProperty('generate_golden_files_to')) {
- systemProperty 'generate_golden_files_to', project.property('generate_golden_files_to')
- assert project.hasProperty('HEAD_sha1')
- systemProperty 'test_git_HEAD_sha1', project.property('HEAD_sha1')
- }
-
- if (project.hasProperty('use_golden_files_in')) {
- systemProperty 'use_golden_files_in', project.property('use_golden_files_in')
- assert project.hasProperty('HEAD_sha1')
- systemProperty 'test_git_HEAD_sha1', project.property('HEAD_sha1')
- }
-
- if (project.hasProperty('kotlin_compiler_dev')) {
- systemProperty 'com.android.tools.r8.kotlincompilerdev', '1';
- }
-
- if (project.hasProperty('kotlin_compiler_old')) {
- systemProperty 'com.android.tools.r8.kotlincompilerold', '1';
- }
-
- if (!useTestingState) {
- testLogging.exceptionFormat = 'full'
- if (project.hasProperty('print_test_stdout')) {
- testLogging.showStandardStreams = true
- }
- }
- if (project.hasProperty('dex_vm') && project.property('dex_vm') != 'default') {
- println "NOTE: Running with non default vm: " + project.property('dex_vm')
- systemProperty 'dex_vm', project.property('dex_vm')
- }
-
- // Forward runtime configurations for test parameters.
- if (project.hasProperty('runtimes')) {
- println "NOTE: Running with runtimes: " + project.property('runtimes')
- systemProperty 'runtimes', project.property('runtimes')
- }
-
- if (project.hasProperty('art_profile_rewriting_completeness_check')) {
- String key = 'com.android.tools.r8.artprofilerewritingcompletenesscheck'
- String value = project.property('art_profile_rewriting_completeness_check')
- systemProperty key, value
- }
-
- if (project.hasProperty('slow_tests')) {
- systemProperty 'slow_tests', project.property('slow_tests')
- }
-
-
- if (project.hasProperty('desugar_jdk_json_dir')) {
- systemProperty 'desugar_jdk_json_dir', project.property('desugar_jdk_json_dir')
- }
- if (project.hasProperty('desugar_jdk_libs')) {
- systemProperty 'desugar_jdk_libs', project.property('desugar_jdk_libs')
- }
-
- if (!useTestingState) {
- if (project.hasProperty('print_times') || project.hasProperty('one_line_per_test')) {
- afterTest { desc, result ->
- def executionTime = (result.endTime - result.startTime) / 1000
- testTimes["${desc.name} [${desc.className}]"] = executionTime
- }
- afterSuite { desc, result ->
- // parent is null if all tests are done.
- if (desc.parent == null) {
- def sortedTimes = testTimes.sort({ e1, e2 -> e2.value <=> e1.value })
- sortedTimes.eachWithIndex { key, value, i ->
- println "$key: $value"
- }
- }
- }
- }
-
- if (project.hasProperty('one_line_per_test')) {
- beforeTest { desc ->
- println "Start executing test ${desc.name} [${desc.className}]"
- }
-
- afterTest { desc, result ->
- if (result.resultType == TestResult.ResultType.FAILURE) {
- printStackTrace(result)
- }
- if (project.hasProperty('update_test_timestamp')) {
- file(project.getProperty('update_test_timestamp')).text = new Date().getTime()
- }
- println "Done executing test ${desc.name} [${desc.className}] with result: ${result.resultType}"
- }
- } else {
- afterTest { desc, result ->
- if (result.resultType == TestResult.ResultType.FAILURE) {
- printStackTrace(result)
- }
- }
- }
- }
- if (project.hasProperty('no_internal')) {
- exclude "com/android/tools/r8/internal/**"
- }
- if (project.hasProperty('only_internal')) {
- include "com/android/tools/r8/internal/**"
- }
-
- if (project.hasProperty('test_namespace')) {
- include "com/android/tools/r8/" + project.getProperty('test_namespace') + "/**"
- }
-
- if (project.hasProperty('tool') && project.property('tool') == 'd8') {
- // Don't run anything, deprecated
- println "Running with deprecated tool d8, not running any tests"
- include ""
- }
- if (project.hasProperty('no_arttests')) {
- exclude "com/android/tools/r8/art/**"
- }
- if (project.hasProperty('shard_count') ) {
- assert project.hasProperty('shard_number')
- int shard_count = project.getProperty('shard_count') as Integer
- int shard_number = project.getProperty('shard_number') as Integer
- assert shard_count < 65536
- assert shard_number < shard_count
- exclude {
- entry ->
- // Don't leave out directories. Leaving out a directory means all entries below.
- if (entry.file.isDirectory()) {
- return false
- }
- def first4 = entry.getRelativePath().toString().md5().substring(0, 4)
- int hash = Integer.parseInt(first4, 16)
- return hash % shard_count != shard_number
- }
- }
- if (project.hasProperty('test_dir')) {
- systemProperty 'test_dir', project.property('test_dir')
- }
- if (project.hasProperty('command_cache_dir')) {
- systemProperty 'command_cache_dir', project.property('command_cache_dir')
- }
- if (project.hasProperty('command_cache_stats_dir')) {
- systemProperty 'command_cache_stats_dir', project.property('command_cache_stats_dir')
- }
- if (project.hasProperty('r8lib')) {
- dependsOn configureTestForR8Lib
- // R8lib should be used instead of the main output and all the tests in
- // r8 should be mapped and exists in r8LibTestPath.
- classpath = sourceSets.test.runtimeClasspath.filter {
- !it.getAbsolutePath().contains("/build/")
- }
- classpath += files([r8LibPath, r8LibTestPath])
- testClassesDirs = files(r8LibTestPath)
- }
- if (OperatingSystem.current().isLinux()
- || OperatingSystem.current().isMacOsX()
- || OperatingSystem.current().isWindows()) {
- if (OperatingSystem.current().isMacOsX()) {
- logger.lifecycle("WARNING: Testing in only partially supported on Mac OS. " +
- "Art only runs on Linux and tests requiring Art runs in a Docker container, which must be present. " +
- "See tools/docker/README.md for details.")
- }
- if (OperatingSystem.current().isWindows()) {
- logger.lifecycle("WARNING: Testing in only partially supported on Windows. " +
- "Art only runs on Linux and tests requiring Art will be skipped")
- }
- dependsOn downloadDeps
- dependsOn buildExamples
- } else {
- logger.lifecycle("WARNING: Testing in not supported on your platform. Testing is only fully supported on " +
- "Linux and partially supported on Mac OS and Windows. Art does not run on other platforms.")
- }
-}
-
-
-task javadocD8(type: Javadoc) {
- title "D8 API"
- classpath = sourceSets.main.compileClasspath
- source = sourceSets.main.allJava
- include '**/com/android/tools/r8/ArchiveClassFileProvider.java'
- include '**/com/android/tools/r8/ArchiveProgramResourceProvider.java'
- include '**/com/android/tools/r8/BaseCommand.java'
- include '**/com/android/tools/r8/BaseCompilerCommand.java'
- include '**/com/android/tools/r8/ClassFileResourceProvider.java'
- include '**/com/android/tools/r8/CompilationFailedException.java'
- include '**/com/android/tools/r8/CompilationMode.java'
- include '**/com/android/tools/r8/D8.java'
- include '**/com/android/tools/r8/D8Command.java'
- include '**/com/android/tools/r8/DexIndexedConsumer.java'
- include '**/com/android/tools/r8/DexFilePerClassFileConsumer.java'
- include '**/com/android/tools/r8/Diagnostic.java'
- include '**/com/android/tools/r8/DiagnosticsHandler.java'
- include '**/com/android/tools/r8/DirectoryClassFileProvider.java'
- include '**/com/android/tools/r8/OutputMode.java'
- include '**/com/android/tools/r8/ProgramConsumer.java'
- include '**/com/android/tools/r8/ProgramResource.java'
- include '**/com/android/tools/r8/ProgramResourceProvider.java'
- include '**/com/android/tools/r8/Resource.java'
- include '**/com/android/tools/r8/ResourceException.java'
- include '**/com/android/tools/r8/StringConsumer.java'
- include '**/com/android/tools/r8/StringResource.java'
- include '**/com/android/tools/r8/Version.java'
- include '**/com/android/tools/r8/origin/*.java'
-}
-
-task javadocR8(type: Javadoc) {
- title "R8 API"
- classpath = sourceSets.main.compileClasspath
- source = sourceSets.main.allJava
- include '**/com/android/tools/r8/ArchiveClassFileProvider.java'
- include '**/com/android/tools/r8/ArchiveProgramResourceProvider.java'
- include '**/com/android/tools/r8/BaseCommand.java'
- include '**/com/android/tools/r8/BaseCompilerCommand.java'
- include '**/com/android/tools/r8/ClassFileConsumer.java'
- include '**/com/android/tools/r8/ClassFileResourceProvider.java'
- include '**/com/android/tools/r8/CompilationFailedException.java'
- include '**/com/android/tools/r8/CompilationMode.java'
- include '**/com/android/tools/r8/R8.java'
- include '**/com/android/tools/r8/R8Command.java'
- include '**/com/android/tools/r8/DexIndexedConsumer.java'
- include '**/com/android/tools/r8/Diagnostic.java'
- include '**/com/android/tools/r8/DiagnosticsHandler.java'
- include '**/com/android/tools/r8/DirectoryClassFileProvider.java'
- include '**/com/android/tools/r8/OutputMode.java'
- include '**/com/android/tools/r8/ProgramConsumer.java'
- include '**/com/android/tools/r8/ProgramResource.java'
- include '**/com/android/tools/r8/ProgramResourceProvider.java'
- include '**/com/android/tools/r8/Resource.java'
- include '**/com/android/tools/r8/ResourceException.java'
- include '**/com/android/tools/r8/StringConsumer.java'
- include '**/com/android/tools/r8/StringResource.java'
- include '**/com/android/tools/r8/Version.java'
- include '**/com/android/tools/r8/origin/*.java'
-}
-
-task copyMavenDeps(type: Copy) {
- from configurations.compile into "$buildDir/deps"
- from configurations.compileClasspath into "$buildDir/deps"
- from configurations.testCompile into "$buildDir/deps"
-}
-
-task printMavenDeps {
- // Only actually print to stdout when we are updating.
- if (project.hasProperty('updatemavendeps')) {
- for (Configuration config : configurations) {
- if (!config.isCanBeResolved()) {
- continue
- }
- def componentIds = config.incoming.resolutionResult.allDependencies.collect {
- it.selected.id
- }
- def result = dependencies.createArtifactResolutionQuery()
- .forComponents(componentIds)
- .withArtifacts(MavenModule, MavenPomArtifact)
- .execute()
- for (component in result.resolvedComponents) {
- component.getArtifacts(MavenPomArtifact).each {
- println "POM: ${it.file} ${component.id}"
- }
- }
- config.each {
- println "JAR: ${it}"
- }
- }
- }
-}
-
-allprojects {
- tasks.withType(Exec) {
- doFirst {
- println commandLine.join(' ')
- }
- }
-}
diff --git a/settings.gradle b/settings.gradle
deleted file mode 100644
index 969cb9c..0000000
--- a/settings.gradle
+++ /dev/null
@@ -1,25 +0,0 @@
-// Copyright (c) 2019, the R8 project authors. Please see the AUTHORS file
-// for details. All rights reserved. Use of this source code is governed by a
-// BSD-style license that can be found in the LICENSE file.
-
-import org.gradle.internal.os.OperatingSystem
-
-rootProject.name = 'r8'
-
-// Bootstrap building by downloading dependencies.
-def dependencies_bucket = "r8-deps"
-def dependencies_sha1_file = "third_party/dependencies.tar.gz.sha1"
-def extension = OperatingSystem.current().isWindows() ? ".bat" : ".py"
-
-def cmd =
- ("download_from_google_storage${extension} --extract"
- + " --bucket ${dependencies_bucket}"
- + " --sha1_file ${dependencies_sha1_file}")
-def process = cmd.execute()
-process.waitFor()
-if (process.exitValue() != 0) {
- throw new GradleException(
- "Bootstrapping dependencies download failed:\n"
- + "STDOUT:\n${process.in.text}\n"
- + "STDERR:\n${process.err.text}")
-}
\ No newline at end of file