From 45f05b246af5358a832f5b4190da15cad45b8b43 Mon Sep 17 00:00:00 2001
From: huangx <549631030@qq.com>
Date: Thu, 10 Aug 2023 09:21:50 +0800
Subject: [PATCH] =?UTF-8?q?=E8=A7=A3=E5=86=B3AGP7.0.0=E5=88=B07.3.0?=
=?UTF-8?q?=E8=87=AA=E5=8A=A8=E7=94=9F=E6=88=90=E6=B7=B7=E6=B7=86=E5=A4=B1?=
=?UTF-8?q?=E6=95=88=E9=97=AE=E9=A2=98?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
app/build.gradle | 2 +-
build.gradle | 2 +-
gradle.properties | 1 +
library/build.gradle | 2 +-
library/gradle.properties | 2 +-
.../plugin/AndroidJunkCodePlugin.groovy | 8 +--
.../plugin/NewVariantApiPlugin.groovy | 55 +++++++++++++------
.../plugin/OldVariantApiPlugin.groovy | 2 +-
.../junkcode/task/AndroidJunkCodeTask.groovy | 2 +-
.../junkcode/task/GenerateJunkCodeTask.groovy | 5 +-
.../hx/plugin/junkcode/utils/JunkUtil.groovy | 26 +++++++++
11 files changed, 77 insertions(+), 30 deletions(-)
diff --git a/app/build.gradle b/app/build.gradle
index 5666d31d..e6ff7fc4 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -172,7 +172,7 @@ if (PLUGIN_ENABLE.toBoolean()) {
//例
fileNameBuilder.append("android_junk_code_keep")
- contentBuilder.append( "\n")
}
diff --git a/build.gradle b/build.gradle
index 255481e8..617aba19 100644
--- a/build.gradle
+++ b/build.gradle
@@ -11,7 +11,7 @@ buildscript {
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
classpath "com.getkeepsafe.dexcount:dexcount-gradle-plugin:3.0.1"
if (PLUGIN_ENABLE.toBoolean()) {
- classpath "com.github.qq549631030:android-junk-code:1.3.0"
+ classpath "com.github.qq549631030:android-junk-code:1.3.1"
}
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
diff --git a/gradle.properties b/gradle.properties
index 50440ed9..fd349bf3 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -24,4 +24,5 @@ org.gradle.warning.mode=all
RELEASE_SIGNING_ENABLED=true
+#PLUGIN_ENABLE = false
PLUGIN_ENABLE = true
\ No newline at end of file
diff --git a/library/build.gradle b/library/build.gradle
index 99d48dc1..f73dc2b2 100644
--- a/library/build.gradle
+++ b/library/build.gradle
@@ -81,5 +81,5 @@ java {
dependencies {
implementation gradleApi()
implementation 'com.squareup:javapoet:1.13.0'
- compileOnly 'com.android.tools.build:gradle-api:7.1.0'
+ compileOnly 'com.android.tools.build:gradle-api:7.0.0'
}
\ No newline at end of file
diff --git a/library/gradle.properties b/library/gradle.properties
index 06af2411..d771665c 100644
--- a/library/gradle.properties
+++ b/library/gradle.properties
@@ -1,7 +1,7 @@
#project
GROUP=com.github.qq549631030
POM_ARTIFACT_ID=android-junk-code
-VERSION_NAME=1.3.0
+VERSION_NAME=1.3.1
POM_PACKAGING=jar
POM_NAME=AndroidJunkCode
diff --git a/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/AndroidJunkCodePlugin.groovy b/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/AndroidJunkCodePlugin.groovy
index 08c01171..f344eb28 100644
--- a/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/AndroidJunkCodePlugin.groovy
+++ b/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/AndroidJunkCodePlugin.groovy
@@ -1,6 +1,6 @@
package cn.hx.plugin.junkcode.plugin
-
+import cn.hx.plugin.junkcode.utils.JunkUtil
import org.gradle.api.Plugin
import org.gradle.api.Project
@@ -12,10 +12,8 @@ class AndroidJunkCodePlugin implements Plugin {
if (!android || !android.hasProperty("applicationVariants")) {
throw IllegalArgumentException("must apply this plugin after 'com.android.application'")
}
- def androidComponents = project.extensions.findByName("androidComponents")
- //AGP 7.4.0+
- if (androidComponents && androidComponents.hasProperty("pluginVersion")
- && (androidComponents.pluginVersion.major > 7 || androidComponents.pluginVersion.minor >= 4)) {
+ //AGP 7.0.0+
+ if (JunkUtil.isAGP7_0_0(project)) {
new NewVariantApiPlugin().apply(project)
} else {
new OldVariantApiPlugin().apply(project)
diff --git a/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/NewVariantApiPlugin.groovy b/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/NewVariantApiPlugin.groovy
index 9d60ac75..897214e7 100644
--- a/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/NewVariantApiPlugin.groovy
+++ b/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/NewVariantApiPlugin.groovy
@@ -2,18 +2,21 @@ package cn.hx.plugin.junkcode.plugin
import cn.hx.plugin.junkcode.ext.AndroidJunkCodeExt
import cn.hx.plugin.junkcode.ext.JunkCodeConfig
-import cn.hx.plugin.junkcode.task.ManifestMergeTask
import cn.hx.plugin.junkcode.task.GenerateJunkCodeTask
+import cn.hx.plugin.junkcode.task.ManifestMergeTask
+import cn.hx.plugin.junkcode.utils.JunkUtil
import com.android.build.api.artifact.SingleArtifact
import org.gradle.api.Plugin
import org.gradle.api.Project
import org.gradle.api.tasks.TaskProvider
+/**
+ * AGP 7.0.0+
+ */
class NewVariantApiPlugin implements Plugin {
@Override
void apply(Project project) {
- def android = project.extensions.findByName("android")
def androidComponents = project.extensions.findByName("androidComponents")
def generateJunkCodeExt = project.extensions.create("androidJunkCode", AndroidJunkCodeExt, project.container(JunkCodeConfig))
androidComponents.onVariants(androidComponents.selector().all(), { variant ->
@@ -23,24 +26,26 @@ class NewVariantApiPlugin implements Plugin {
println("AndroidJunkCode: generate code for variant $variantName? ${junkCodeConfig != null}")
}
if (junkCodeConfig) {
- def junkCodeOutDir = new File(project.buildDir, "generated/source/junk/${variantName}")
+ def junkCodeOutDir = project.layout.buildDirectory.dir("generated/source/junk/${variantName}")
def generateJunkCodeTaskProvider = project.tasks.register("generate${variantName.capitalize()}JunkCode", GenerateJunkCodeTask) {
config = junkCodeConfig
- namespace = android.namespace
- javaOutputFolder.set(new File(junkCodeOutDir, "java"))
- resOutputFolder.set(new File(junkCodeOutDir, "res"))
- manifestOutputFile.set(new File(junkCodeOutDir, "AndroidManifest.xml"))
- proguardOutputFile.set(new File(junkCodeOutDir, "proguard-rules.pro"))
- }
- if (variant.sources.java) {
- variant.sources.java.addGeneratedSourceDirectory(generateJunkCodeTaskProvider, {
- it.javaOutputFolder
- })
+ namespace = variant.namespace
+ javaOutputFolder.set(junkCodeOutDir.map { it.dir("java") })
+ resOutputFolder.set(junkCodeOutDir.map { it.dir("res") })
+ manifestOutputFile.set(junkCodeOutDir.map { it.file("AndroidManifest.xml") })
+ proguardOutputFile.set(junkCodeOutDir.map { it.file("proguard-rules.pro") })
}
- if (variant.sources.res) {
- variant.sources.res.addGeneratedSourceDirectory(generateJunkCodeTaskProvider, {
- it.resOutputFolder
- })
+ if (JunkUtil.isAGP7_4_0(project)) {
+ if (variant.sources.java) {
+ variant.sources.java.addGeneratedSourceDirectory(generateJunkCodeTaskProvider, {
+ it.javaOutputFolder
+ })
+ }
+ if (variant.sources.res) {
+ variant.sources.res.addGeneratedSourceDirectory(generateJunkCodeTaskProvider, {
+ it.resOutputFolder
+ })
+ }
}
TaskProvider manifestUpdater = project.tasks.register('merge' + variantName.capitalize() + 'JunkCodeManifest', ManifestMergeTask) {
it.genManifestFile.set(generateJunkCodeTaskProvider.flatMap {
@@ -56,5 +61,21 @@ class NewVariantApiPlugin implements Plugin {
})
}
})
+ if (!JunkUtil.isAGP7_4_0(project)) {
+ def android = project.extensions.findByName("android")
+ android.applicationVariants.all { variant ->
+ def variantName = variant.name
+ def junkCodeConfig = generateJunkCodeExt.variantConfig.findByName(variantName)
+ if (junkCodeConfig) {
+ def generateJunkCodeTaskProvider = project.tasks.named("generate${variantName.capitalize()}JunkCode", GenerateJunkCodeTask)
+ variant.registerJavaGeneratingTask(generateJunkCodeTaskProvider, generateJunkCodeTaskProvider.get().javaOutputFolder.get().asFile)
+
+ variant.registerGeneratedResFolders(project.files(generateJunkCodeTaskProvider.map {
+ it.resOutputFolder.asFile
+ }).builtBy(generateJunkCodeTaskProvider))
+ variant.mergeResourcesProvider.configure { dependsOn(generateJunkCodeTaskProvider.get()) }
+ }
+ }
+ }
}
}
\ No newline at end of file
diff --git a/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/OldVariantApiPlugin.groovy b/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/OldVariantApiPlugin.groovy
index 8250d9a7..3379bdb9 100644
--- a/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/OldVariantApiPlugin.groovy
+++ b/library/src/main/groovy/cn/hx/plugin/junkcode/plugin/OldVariantApiPlugin.groovy
@@ -7,7 +7,7 @@ import org.gradle.api.Plugin
import org.gradle.api.Project
/**
- * before AGP 7.4.0
+ * before AGP 7.0.0
*/
class OldVariantApiPlugin implements Plugin {
diff --git a/library/src/main/groovy/cn/hx/plugin/junkcode/task/AndroidJunkCodeTask.groovy b/library/src/main/groovy/cn/hx/plugin/junkcode/task/AndroidJunkCodeTask.groovy
index eb930c45..9055ace6 100644
--- a/library/src/main/groovy/cn/hx/plugin/junkcode/task/AndroidJunkCodeTask.groovy
+++ b/library/src/main/groovy/cn/hx/plugin/junkcode/task/AndroidJunkCodeTask.groovy
@@ -6,7 +6,7 @@ import org.gradle.api.DefaultTask
import org.gradle.api.tasks.*
/**
- * before AGP 7.4.0
+ * before AGP 7.0.0
*/
abstract class AndroidJunkCodeTask extends DefaultTask {
diff --git a/library/src/main/groovy/cn/hx/plugin/junkcode/task/GenerateJunkCodeTask.groovy b/library/src/main/groovy/cn/hx/plugin/junkcode/task/GenerateJunkCodeTask.groovy
index 98d11517..7315d1f7 100644
--- a/library/src/main/groovy/cn/hx/plugin/junkcode/task/GenerateJunkCodeTask.groovy
+++ b/library/src/main/groovy/cn/hx/plugin/junkcode/task/GenerateJunkCodeTask.groovy
@@ -5,6 +5,7 @@ import cn.hx.plugin.junkcode.utils.JunkUtil
import org.gradle.api.DefaultTask
import org.gradle.api.file.DirectoryProperty
import org.gradle.api.file.RegularFileProperty
+import org.gradle.api.provider.Property
import org.gradle.api.tasks.*
abstract class GenerateJunkCodeTask extends DefaultTask {
@@ -13,7 +14,7 @@ abstract class GenerateJunkCodeTask extends DefaultTask {
abstract JunkCodeConfig config
@Input
- abstract String namespace
+ abstract Property getNamespace()
@OutputDirectory
abstract DirectoryProperty getJavaOutputFolder()
@@ -53,7 +54,7 @@ abstract class GenerateJunkCodeTask extends DefaultTask {
packageName = config.packageBase + "." + JunkUtil.generateName(i)
}
}
- def list = JunkUtil.generateActivity(javaDir, resDir, namespace, packageName, config)
+ def list = JunkUtil.generateActivity(javaDir, resDir, getNamespace().get(), packageName, config)
activityList.addAll(list)
JunkUtil.generateJava(javaDir, packageName, config)
packageList.add(packageName)
diff --git a/library/src/main/groovy/cn/hx/plugin/junkcode/utils/JunkUtil.groovy b/library/src/main/groovy/cn/hx/plugin/junkcode/utils/JunkUtil.groovy
index f6e428f2..d8298687 100644
--- a/library/src/main/groovy/cn/hx/plugin/junkcode/utils/JunkUtil.groovy
+++ b/library/src/main/groovy/cn/hx/plugin/junkcode/utils/JunkUtil.groovy
@@ -6,6 +6,7 @@ import com.squareup.javapoet.ClassName
import com.squareup.javapoet.JavaFile
import com.squareup.javapoet.MethodSpec
import com.squareup.javapoet.TypeSpec
+import org.gradle.api.Project
import javax.lang.model.element.Modifier
import java.nio.file.Files
@@ -397,4 +398,29 @@ class JunkUtil {
}
}
}
+
+ /**
+ * 是否是AGP7.0.0及以上
+ * @param project
+ * @return
+ */
+ static boolean isAGP7_0_0(Project project) {
+ def androidComponents = project.extensions.findByName("androidComponents")
+ if (androidComponents && androidComponents.hasProperty("pluginVersion")) {
+ return true
+ }
+ return false
+ }
+ /**
+ * 是否是AGP7.4.0及以上
+ * @param project
+ * @return
+ */
+ static boolean isAGP7_4_0(Project project) {
+ def androidComponents = project.extensions.findByName("androidComponents")
+ if (androidComponents && androidComponents.hasProperty("pluginVersion") && (androidComponents.pluginVersion.major > 7 || androidComponents.pluginVersion.minor >= 4)) {
+ return true
+ }
+ return false
+ }
}
\ No newline at end of file