buildSrc/src/main/kotlin/SourceLicenseChecker.kt
author Da Risk <da_risk@geekorum.com>
Mon, 18 May 2026 20:00:02 -0400
changeset 105 4dd59e91dc99
parent 75 534a19e25217
permissions -rw-r--r--
build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     1
/*
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     2
 * Geekdroid is a utility library for development on the Android
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     3
 * Platform.
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     4
 *
75
534a19e25217 build: update license headers
Da Risk <da_risk@geekorum.com>
parents: 72
diff changeset
     5
 * Copyright (C) 2017-2025 by Frederic-Charles Barthelery.
10
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     6
 *
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     7
 * This file is part of Geekdroid.
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     8
 *
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
     9
 * Geekdroid is free software: you can redistribute it and/or modify
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    10
 * it under the terms of the GNU General Public License as published by
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    11
 * the Free Software Foundation, either version 3 of the License, or
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    12
 * (at your option) any later version.
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    13
 *
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    14
 * Geekdroid is distributed in the hope that it will be useful,
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    17
 * GNU General Public License for more details.
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    18
 *
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    19
 * You should have received a copy of the GNU General Public License
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    20
 * along with Geekdroid.  If not, see <http://www.gnu.org/licenses/>.
9aad34f43f71 More license headers
Da Risk <da_risk@geekorum.com>
parents: 1
diff changeset
    21
 */
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    22
package com.geekorum.build
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    23
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    24
import com.android.build.api.dsl.AndroidSourceSet
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    25
import com.android.build.gradle.BaseExtension
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    26
import com.android.build.gradle.DynamicFeaturePlugin
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    27
import com.hierynomus.gradle.license.LicenseBasePlugin
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    28
import com.hierynomus.gradle.license.tasks.LicenseCheck
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    29
import com.hierynomus.gradle.license.tasks.LicenseFormat
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    30
import nl.javadude.gradle.plugins.license.License
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    31
import nl.javadude.gradle.plugins.license.LicenseExtension
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    32
import nl.javadude.gradle.plugins.license.LicensePlugin
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    33
import org.gradle.api.NamedDomainObjectContainer
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    34
import org.gradle.api.Project
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    35
import org.gradle.api.file.FileTree
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    36
import org.gradle.api.tasks.TaskProvider
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    37
import org.gradle.kotlin.dsl.*
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    38
import org.jetbrains.kotlin.gradle.dsl.KotlinProjectExtension
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    39
import org.jetbrains.kotlin.gradle.plugin.KotlinAndroidPluginWrapper
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    40
import org.jetbrains.kotlin.gradle.plugin.KotlinJsPluginWrapper
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    41
import org.jetbrains.kotlin.gradle.plugin.KotlinMultiplatformPluginWrapper
105
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    42
import java.io.File
72
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
    43
import java.util.Locale
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    44
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    45
internal fun Project.configureSourceLicenseChecker() {
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    46
    apply<LicensePlugin>()
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    47
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    48
    configure<LicenseExtension> {
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    49
        header = file("$rootDir/config/license/header.txt")
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    50
        mapping("java", "SLASHSTAR_STYLE")
105
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    51
        mapping("json", "SLASHSTAR_STYLE")
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    52
        mapping("kt", "SLASHSTAR_STYLE")
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    53
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    54
        excludes(listOf("**/*.webp", "**/*.png"))
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    55
    }
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    56
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    57
    // the LicensePlugin doesn't configure itself properly on DynamicFeaturePlugin
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    58
    // Copied the code to configure it
105
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    59
    plugins.withType<DynamicFeaturePlugin> {
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    60
        configureAndroid()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    61
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    62
    // make the license tasks looks for kotlin files in an Android project
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    63
    plugins.withType(KotlinAndroidPluginWrapper::class.java) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    64
        configureKotlinAndroid()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    65
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    66
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    67
    // make the license tasks for kotlin js project
105
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    68
    plugins.withType<KotlinJsPluginWrapper> {
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    69
        configureKotlin()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    70
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    71
105
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    72
    plugins.withType<KotlinMultiplatformPluginWrapper> {
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    73
        configureKotlin()
105
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    74
        configureComposeResources()
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    75
    }
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    76
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    77
    tasks.withType<License>().configureEach {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
    78
        notCompatibleWithConfigurationCache("License tasks calls getProject() at execution time")
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    79
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    80
}
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    81
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    82
@OptIn(ExperimentalStdlibApi::class)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    83
private fun Project.configureKotlin() {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    84
    val kotlin = the<KotlinProjectExtension>()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    85
    val taskInfix = ""
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    86
    kotlin.sourceSets.configureEach {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    87
        val kotlinSource = this
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    88
        val sourceSetTaskName =
72
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
    89
            "${LicenseBasePlugin.getLICENSE_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    90
        logger.info("Adding $sourceSetTaskName task for sourceSet ${kotlinSource.name}")
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    91
        if (sourceSetTaskName in tasks.names) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    92
            // tasks may have already been added by configuration for the Android plugin
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    93
            logger.info("Tasks $sourceSetTaskName already exists. Skip")
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    94
            return@configureEach
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    95
        }
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    96
        tasks.register(sourceSetTaskName, LicenseCheck::class.java) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    97
            source(kotlinSource.kotlin)
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
    98
        }
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
    99
        val sourceSetFormatTaskName =
72
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
   100
            "${LicenseBasePlugin.getFORMAT_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   101
        tasks.register(sourceSetFormatTaskName, LicenseFormat::class.java) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   102
            source(kotlinSource.kotlin)
1
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
   103
        }
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
   104
    }
831cffa9c991 source import
Da Risk <da_risk@geekorum.com>
parents:
diff changeset
   105
}
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   106
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   107
@OptIn(ExperimentalStdlibApi::class)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   108
private fun Project.configureKotlinAndroid() {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   109
    val kotlin = the<KotlinProjectExtension>()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   110
    val android = the<BaseExtension>()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   111
    val taskInfix = "Android"
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   112
    android.sourceSets.configureEach {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   113
        val kotlinSource = kotlin.sourceSets[name]
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   114
        logger.info("Adding kotlin sources from sourceSet $name to License plugin tasks")
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   115
        val sourceSetTaskName =
72
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
   116
            "${LicenseBasePlugin.getLICENSE_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   117
        tasks.named(sourceSetTaskName, LicenseCheck::class.java) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   118
            source(kotlinSource.kotlin, manifest.srcFile)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   119
        }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   120
        val sourceSetFormatTaskName =
72
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
   121
            "${LicenseBasePlugin.getFORMAT_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   122
        tasks.named(sourceSetFormatTaskName, LicenseFormat::class.java) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   123
            source(kotlinSource.kotlin, manifest.srcFile)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   124
        }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   125
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   126
}
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   127
105
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   128
private fun Project.configureComposeResources() {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   129
    val kotlin = the<KotlinProjectExtension>()
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   130
    val taskInfix = "ComposeResources"
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   131
    kotlin.sourceSets.configureEach {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   132
        val kotlinSource = this
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   133
        val sourceSetTaskName =
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   134
            "${LicenseBasePlugin.getLICENSE_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   135
        if (name.startsWith("generated")) {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   136
            logger.info("Skip sourceSet $name because it's generated code")
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   137
            return@configureEach
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   138
        }
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   139
        val resourceDir = kotlinSource.resources.sourceDirectories.files.first()
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   140
        val composeResourceDir = File(resourceDir, "../composeResources")
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   141
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   142
        val configureLicenseCheckTaskLambda: LicenseCheck.() -> Unit = {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   143
            source(composeResourceDir)
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   144
        }
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   145
        if (sourceSetTaskName in tasks.names) {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   146
            // tasks may have already been added by configuration for the Android plugin
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   147
            logger.info("Tasks $sourceSetTaskName already exists. configure it")
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   148
            tasks.named(sourceSetTaskName, LicenseCheck::class.java, configureLicenseCheckTaskLambda)
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   149
        } else {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   150
            logger.info("Adding ${project.name}:$sourceSetTaskName task for sourceSet ${kotlinSource.name}")
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   151
            tasks.register(sourceSetTaskName, LicenseCheck::class.java, configureLicenseCheckTaskLambda)
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   152
        }
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   153
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   154
        val configureLicenseFormatTaskLambda: LicenseFormat.() -> Unit = {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   155
            source(composeResourceDir)
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   156
        }
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   157
        val sourceSetFormatTaskName =
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   158
            "${LicenseBasePlugin.getFORMAT_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   159
        if (sourceSetFormatTaskName in tasks.names) {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   160
            // tasks may have already been added by configuration for the Android plugin
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   161
            logger.info("Tasks $sourceSetFormatTaskName already exists. configure it")
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   162
            tasks.named(sourceSetFormatTaskName, LicenseFormat::class.java, configureLicenseFormatTaskLambda)
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   163
        } else {
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   164
            logger.info("Adding ${project.name}:$sourceSetFormatTaskName task for sourceSet ${kotlinSource.name}")
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   165
            tasks.register(sourceSetFormatTaskName, LicenseFormat::class.java, configureLicenseFormatTaskLambda)
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   166
        }
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   167
    }
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   168
}
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   169
4dd59e91dc99 build: SourceLicenseChecker mark license task not compatible with gradle configuration cache
Da Risk <da_risk@geekorum.com>
parents: 75
diff changeset
   170
19
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   171
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   172
private fun Project.configureAndroid() {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   173
    val android = the<BaseExtension>()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   174
    configureSourceSetRule(android.sourceSets, "Android") { ss ->
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   175
        @Suppress("DEPRECATION")
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   176
        when (ss) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   177
            // the dsl.AndroidSourceSet don't expose any getter, so we still need to cast it
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   178
            is com.android.build.gradle.api.AndroidSourceSet -> {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   179
        ss.java.getSourceFiles() + ss.res.getSourceFiles() + fileTree(ss.manifest.srcFile)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   180
            }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   181
            else -> fileTree()
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   182
        }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   183
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   184
}
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   185
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   186
/**
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   187
 * Dynamically create a task for each sourceSet, and register with check
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   188
 */
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   189
@Suppress("DefaultLocale")
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   190
private fun Project.configureSourceSetRule(androidSourceSetContainer: NamedDomainObjectContainer<out AndroidSourceSet>,
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   191
                                           taskInfix: String, sourceSetSources: (AndroidSourceSet) -> FileTree) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   192
    // This follows the other check task pattern
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   193
    androidSourceSetContainer.configureEach {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   194
        val sourceSetTaskName = "${LicenseBasePlugin.getLICENSE_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   195
        logger.info("Adding $sourceSetTaskName task for sourceSet $name")
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   196
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   197
        val checkTask = tasks.register(sourceSetTaskName, LicenseCheck::class.java)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   198
        configureForSourceSet(this, checkTask, sourceSetSources)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   199
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   200
        // Add independent license task, which will perform format
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   201
        val sourceSetFormatTaskName = "${LicenseBasePlugin.getFORMAT_TASK_BASE_NAME()}${taskInfix}${name.capitalize()}"
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   202
        val formatTask = tasks.register(sourceSetFormatTaskName, LicenseFormat::class.java)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   203
        configureForSourceSet(this, formatTask, sourceSetSources)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   204
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   205
}
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   206
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   207
private fun configureForSourceSet(sourceSet: AndroidSourceSet, task: TaskProvider<out License>, sourceSetSources: (AndroidSourceSet) -> FileTree) {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   208
    task.configure {
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   209
        // Explicitly set description
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   210
        description = "Scanning license on ${sourceSet.name} files"
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   211
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   212
        // Default to all source files from SourceSet
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   213
        source = sourceSetSources(sourceSet)
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   214
    }
91a3ad3b1b9c build: update buildsrc
Da Risk <da_risk@geekorum.com>
parents: 10
diff changeset
   215
}
72
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
   216
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
   217
private fun String.capitalize() =
0b98a9a23a94 build: update to agp 8.3.1
Da Risk <da_risk@geekorum.com>
parents: 61
diff changeset
   218
    replaceFirstChar { if (it.isLowerCase()) it.titlecase(Locale.getDefault()) else it.toString() }