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