From b524244c084c987d36b47eb5ef2e55e9d0c683d5 Mon Sep 17 00:00:00 2001 From: FlyJingFish Date: Sun, 20 Oct 2024 18:13:26 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E4=BF=AE=E5=A4=8DdebugMode=E9=85=8D?= =?UTF-8?q?=E7=BD=AE=E6=96=87=E4=BB=B6=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 14 ++-- README_EN.md | 14 ++-- .../android_aop_plugin/plugin/BasePlugin.kt | 57 ++------------ .../plugin/CompilePlugin.kt | 15 +++- .../android_aop_plugin/plugin/PluginConfig.kt | 75 +++++++++++++++++++ .../tasks/DebugModeFileTask.kt | 46 ++++++++++++ docs/android_aop_extra.md | 2 +- docs/getting_started.md | 14 ++-- docs/zh/android_aop_extra.md | 2 +- docs/zh/getting_started.md | 14 ++-- gradle.properties | 2 +- version.properties | 4 +- 12 files changed, 173 insertions(+), 86 deletions(-) create mode 100644 android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/PluginConfig.kt diff --git a/README.md b/README.md index 9df83877..307addb2 100644 --- a/README.md +++ b/README.md @@ -121,7 +121,7 @@ plugins { //必须项 👇 apply 设置为 true 自动为所有module“预”配置debugMode,false则按下边步骤五的方式二 - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4" apply true + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5" apply true } ```
@@ -131,7 +131,7 @@ buildscript { dependencies { //必须项 👇 - classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.4' + classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.5' } } // 👇加上这句自动为所有module“预”配置debugMode,不加则按下边步骤五的方式二 @@ -186,7 +186,7 @@ //必须项 👇 plugins { ... - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4"//最好放在最后一行 + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5"//最好放在最后一行 } ``` @@ -212,18 +212,18 @@ plugins { dependencies { //必须项 👇 - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.5' //非必须项 👇这个包提供了一些常见的注解切面 - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.5' //必须项 👇如果您项目内已经有了这项不用加也可以 implementation 'androidx.appcompat:appcompat:1.3.0' // 至少在1.3.0及以上 //非必须项 👇,如果你想自定义切面需要用到,⚠️支持Java和Kotlin代码写的切面 - ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.4' + ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.5' //非必须项 👇,如果你想自定义切面需要用到,⚠️只适用于Java代码写的切面 - annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.4' + annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.5' //⚠️上边的 android-aop-ksp 和 android-aop-processor 二选一 } ``` diff --git a/README_EN.md b/README_EN.md index 8a7d32d1..e2de9a6d 100644 --- a/README_EN.md +++ b/README_EN.md @@ -118,7 +118,7 @@ Depend on the plug-in in build.gradle in the project root d plugins { //Required item 👇 apply is set to true to automatically apply debugMode to all modules, if false, follow step 5 below. - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4" apply true + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5" apply true } ```
@@ -128,7 +128,7 @@ Depend on the plug-in in build.gradle in the project root d buildscript { dependencies { //Required items 👇 - classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.4' + classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.5' } } //👇Add this sentence to automatically apply debugMode to all modules. If not, follow step 5 below. @@ -176,7 +176,7 @@ Depend on the plug-in in build.gradle in the project root d //Required items 👇 plugins { ... - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4" + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5" } ``` @@ -206,17 +206,17 @@ plugins { dependencies { //Required items 👇 - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.5' //Optional 👇This package provides some common annotation aspects - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.5' //Required item 👇If you already have this item in your project, you don’t need to add it. implementation 'androidx.appcompat:appcompat:1.3.0' // At least in 1.3.0 and above //Optional 👇, if you want to customize aspects, you need to use them, ⚠️supports aspects written in Java and Kotlin code - ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.4' + ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.5' //Optional 👇, if you want to customize aspects, you need to use them, ⚠️only applies to aspects written in Java code - annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.4' + annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.5' //⚠️Choose one of the above android-aop-ksp and android-aop-processor } ``` diff --git a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/BasePlugin.kt b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/BasePlugin.kt index 5d6053c6..ccf4e366 100644 --- a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/BasePlugin.kt +++ b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/BasePlugin.kt @@ -1,33 +1,16 @@ package com.flyjingfish.android_aop_plugin.plugin -import com.flyjingfish.android_aop_plugin.config.RootBooleanConfig import org.gradle.api.Plugin import org.gradle.api.Project abstract class BasePlugin :Plugin { - private var reflectInvokeMethod = false - private var reflectInvokeMethodOnlyDebug = false - private var debugMode = false - private var onlyDebug = false - private var isIncremental = true - private var buildConfig = true + private lateinit var pluginConfig: PluginConfig private fun init(project: Project){ - val reflectInvokeMethodStr = project.properties[RootBooleanConfig.REFLECT_INVOKE_METHOD.propertyName]?:"${RootBooleanConfig.REFLECT_INVOKE_METHOD.defaultValue}" - val debugModeStr = project.properties[RootBooleanConfig.DEBUG_MODE.propertyName]?:"${RootBooleanConfig.DEBUG_MODE.defaultValue}" - val onlyModeStr = project.properties[RootBooleanConfig.ONLY_DEBUG.propertyName]?:"${RootBooleanConfig.ONLY_DEBUG.defaultValue}" - val isIncrementalStr = project.properties[RootBooleanConfig.INCREMENTAL.propertyName]?:"${RootBooleanConfig.INCREMENTAL.defaultValue}" - val reflectInvokeMethodDebugStr = project.properties[RootBooleanConfig.REFLECT_INVOKE_METHOD_ONLY_DEBUG.propertyName]?:"${RootBooleanConfig.REFLECT_INVOKE_METHOD_ONLY_DEBUG.defaultValue}" - val buildConfigStr = project.properties[RootBooleanConfig.BUILD_CONFIG.propertyName]?:"${RootBooleanConfig.BUILD_CONFIG.defaultValue}" - debugMode = debugModeStr.toString() == "true" - reflectInvokeMethod = reflectInvokeMethodStr.toString() == "true" - onlyDebug = onlyModeStr.toString() == "true" - isIncremental = isIncrementalStr.toString() == "true" - reflectInvokeMethodOnlyDebug = reflectInvokeMethodDebugStr.toString() == "true" - buildConfig = buildConfigStr.toString() == "true" + pluginConfig = PluginConfig(project) } fun isIncremental():Boolean{ - return isIncremental + return pluginConfig.isIncremental() } override fun apply(project: Project) { @@ -35,44 +18,20 @@ abstract class BasePlugin :Plugin { } fun isDebugMode(buildTypeName :String?,variantName :String):Boolean{ - return if (debugMode){ - if (onlyDebug){ - if (buildTypeName != null){ - buildTypeName.lowercase() == "debug" - }else{ - variantName.lowercase().contains("debug") - } - }else{ - true - } - }else{ - false - } + return pluginConfig.isDebugMode(buildTypeName, variantName) } fun isReflectInvokeMethod(buildTypeName :String?,variantName :String):Boolean{ - return if (reflectInvokeMethod){ - if (reflectInvokeMethodOnlyDebug){ - if (buildTypeName != null){ - buildTypeName.lowercase() == "debug" - }else{ - variantName.lowercase().contains("debug") - } - }else{ - true - } - }else{ - false - } + return pluginConfig.isReflectInvokeMethod(buildTypeName, variantName) } fun isDebugMode():Boolean{ - return debugMode + return pluginConfig.isDebugMode() } fun isReflectInvokeMethod():Boolean{ - return reflectInvokeMethod + return pluginConfig.isReflectInvokeMethod() } fun hasBuildConfig():Boolean{ - return buildConfig + return pluginConfig.hasBuildConfig() } } \ No newline at end of file diff --git a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/CompilePlugin.kt b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/CompilePlugin.kt index 09f210d6..48b0a8f0 100644 --- a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/CompilePlugin.kt +++ b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/CompilePlugin.kt @@ -45,6 +45,8 @@ class CompilePlugin(private val root:Boolean): BasePlugin() { if (project.rootProject == project || root){ return } + val buildTypeName = "release" + val variantName = "release" if (hasBuildConfig()){ try { val javaPluginExtension = project.extensions.getByType(JavaPluginExtension::class.java) @@ -75,6 +77,9 @@ class CompilePlugin(private val root:Boolean): BasePlugin() { project.tasks.register(DEBUG_MODE_FILE_TASK_NAME, DebugModeFileTask::class.java){ it.debugModeDir = debugModeDir.absolutePath it.packageName = packageName + it.variantName = variantName + it.buildTypeName = buildTypeName + it.isAndroidModule = false } project.afterEvaluate { project.tasks.findByName("compileJava")?.dependsOn(DEBUG_MODE_FILE_TASK_NAME) @@ -102,8 +107,7 @@ class CompilePlugin(private val root:Boolean): BasePlugin() { } val compileKotlin = compileKotlinTask.get() - val buildTypeName = "release" - val variantName = "release" + val cacheDir = try { compileKotlin.destinationDirectory.get().asFile @@ -183,7 +187,6 @@ class CompilePlugin(private val root:Boolean): BasePlugin() { null } val kotlinPath = cacheDir ?: File(project.buildDir.path + "/tmp/kotlin-classes/".adapterOSPath() + variantName) - doAopTask(project, isApp, variantName, buildTypeName, javaCompile, kotlinPath) } } @@ -246,11 +249,15 @@ class CompilePlugin(private val root:Boolean): BasePlugin() { } } } + val buildTypeName: String? = variant.buildType project .tasks .register("$DEBUG_MODE_FILE_TASK_NAME$variantNameCapitalized", DebugModeFileTask::class.java){ it.debugModeDir = debugModeDir.absolutePath it.packageName = packageName + it.variantName = variantName + it.buildTypeName = buildTypeName + it.isAndroidModule = true } } project.afterEvaluate { @@ -269,7 +276,7 @@ class CompilePlugin(private val root:Boolean): BasePlugin() { if (srcDir.exists()){ //说明这个才是真正的源码所在路径 val packageFile = getPackageNameFile(srcDir,0) - val relativePath = packageFile.getRelativePath(srcDir).replace(File.separator,".") + val relativePath = packageFile.getRelativePath(srcDir).replace("/",".") return if (relativePath.endsWith(".")){ relativePath.substring(0,relativePath.length-1) }else{ diff --git a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/PluginConfig.kt b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/PluginConfig.kt new file mode 100644 index 00000000..50bd768a --- /dev/null +++ b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/plugin/PluginConfig.kt @@ -0,0 +1,75 @@ +package com.flyjingfish.android_aop_plugin.plugin + +import com.flyjingfish.android_aop_plugin.config.RootBooleanConfig +import org.gradle.api.Plugin +import org.gradle.api.Project + +class PluginConfig(private val project: Project) { + private var reflectInvokeMethod = false + private var reflectInvokeMethodOnlyDebug = false + private var debugMode = false + private var onlyDebug = false + private var isIncremental = true + private var buildConfig = true + + init{ + val reflectInvokeMethodStr = project.properties[RootBooleanConfig.REFLECT_INVOKE_METHOD.propertyName]?:"${RootBooleanConfig.REFLECT_INVOKE_METHOD.defaultValue}" + val debugModeStr = project.properties[RootBooleanConfig.DEBUG_MODE.propertyName]?:"${RootBooleanConfig.DEBUG_MODE.defaultValue}" + val onlyModeStr = project.properties[RootBooleanConfig.ONLY_DEBUG.propertyName]?:"${RootBooleanConfig.ONLY_DEBUG.defaultValue}" + val isIncrementalStr = project.properties[RootBooleanConfig.INCREMENTAL.propertyName]?:"${RootBooleanConfig.INCREMENTAL.defaultValue}" + val reflectInvokeMethodDebugStr = project.properties[RootBooleanConfig.REFLECT_INVOKE_METHOD_ONLY_DEBUG.propertyName]?:"${RootBooleanConfig.REFLECT_INVOKE_METHOD_ONLY_DEBUG.defaultValue}" + val buildConfigStr = project.properties[RootBooleanConfig.BUILD_CONFIG.propertyName]?:"${RootBooleanConfig.BUILD_CONFIG.defaultValue}" + debugMode = debugModeStr.toString() == "true" + reflectInvokeMethod = reflectInvokeMethodStr.toString() == "true" + onlyDebug = onlyModeStr.toString() == "true" + isIncremental = isIncrementalStr.toString() == "true" + reflectInvokeMethodOnlyDebug = reflectInvokeMethodDebugStr.toString() == "true" + buildConfig = buildConfigStr.toString() == "true" + } + + fun isIncremental():Boolean{ + return isIncremental + } + + fun isDebugMode(buildTypeName :String?,variantName :String):Boolean{ + return if (debugMode){ + if (onlyDebug){ + if (buildTypeName != null){ + buildTypeName.lowercase() == "debug" + }else{ + variantName.lowercase().contains("debug") + } + }else{ + true + } + }else{ + false + } + } + + fun isReflectInvokeMethod(buildTypeName :String?,variantName :String):Boolean{ + return if (reflectInvokeMethod){ + if (reflectInvokeMethodOnlyDebug){ + if (buildTypeName != null){ + buildTypeName.lowercase() == "debug" + }else{ + variantName.lowercase().contains("debug") + } + }else{ + true + } + }else{ + false + } + } + + fun isDebugMode():Boolean{ + return debugMode + } + fun isReflectInvokeMethod():Boolean{ + return reflectInvokeMethod + } + fun hasBuildConfig():Boolean{ + return buildConfig + } +} \ No newline at end of file diff --git a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/tasks/DebugModeFileTask.kt b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/tasks/DebugModeFileTask.kt index 02923848..f5185f27 100644 --- a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/tasks/DebugModeFileTask.kt +++ b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/tasks/DebugModeFileTask.kt @@ -1,5 +1,10 @@ package com.flyjingfish.android_aop_plugin.tasks +import com.android.build.gradle.AppPlugin +import com.flyjingfish.android_aop_plugin.config.AndroidAopConfig +import com.flyjingfish.android_aop_plugin.plugin.BasePlugin +import com.flyjingfish.android_aop_plugin.plugin.PluginConfig +import com.flyjingfish.android_aop_plugin.utils.InitConfig import com.flyjingfish.android_aop_plugin.utils.Utils import com.flyjingfish.android_aop_plugin.utils.adapterOSPath import com.flyjingfish.android_aop_plugin.utils.checkExist @@ -15,10 +20,51 @@ import java.io.IOException abstract class DebugModeFileTask : DefaultTask() { @get:Input abstract var debugModeDir : String + + @get:Input + abstract var variantName : String + + @get:Input + abstract var isAndroidModule : Boolean + + @get:Input + abstract var buildTypeName : String? + @get:Input abstract var packageName : String? + @TaskAction fun taskAction() { + val pluginConfig = PluginConfig(project) + val exportFile :Boolean = if (isAndroidModule){ + val isApp = project.plugins.hasPlugin(AppPlugin::class.java) + val androidAopConfig : AndroidAopConfig = if (isApp){ + project.extensions.getByType(AndroidAopConfig::class.java) + }else{ + var config = InitConfig.optFromJsonString( + InitConfig.readAsString(Utils.configJsonFile(project)), + AndroidAopConfig::class.java) + if (config == null){ + config = AndroidAopConfig() + } + config + } + + androidAopConfig.enabled && pluginConfig.isDebugMode(buildTypeName,variantName) + }else{ + var config = InitConfig.optFromJsonString( + InitConfig.readAsString(Utils.configJsonFile(project)), + AndroidAopConfig::class.java) + if (config == null){ + config = AndroidAopConfig() + } + config.enabled && pluginConfig.isDebugMode() + } + + if (!exportFile){ + return + } + val packageName = this.packageName if (packageName.isNullOrEmpty() || packageName == "null"){ return diff --git a/docs/android_aop_extra.md b/docs/android_aop_extra.md index cb31e2e2..6ee2f92f 100644 --- a/docs/android_aop_extra.md +++ b/docs/android_aop_extra.md @@ -4,7 +4,7 @@ ```groovy dependencies { //Optional 👇This package provides some common annotation aspects - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.5' } ``` diff --git a/docs/getting_started.md b/docs/getting_started.md index 2be89cc7..dcc7ecb9 100644 --- a/docs/getting_started.md +++ b/docs/getting_started.md @@ -24,7 +24,7 @@ Depend on the plug-in in build.gradle in the project root d plugins { //Required item 👇 apply is set to true to automatically apply debugMode to all modules, if false, follow step 5 below. - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4" apply true + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5" apply true } ```
@@ -34,7 +34,7 @@ Depend on the plug-in in build.gradle in the project root d buildscript { dependencies { //Required items 👇 - classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.4' + classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.5' } } //👇Add this sentence to automatically apply debugMode to all modules. If not, follow step 5 below. @@ -79,7 +79,7 @@ Depend on the plug-in in build.gradle in the project root d //Required items 👇 plugins { ... - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4" + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5" } ``` @@ -108,17 +108,17 @@ plugins { dependencies { //Required items 👇 - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.5' //Optional 👇This package provides some common annotation aspects - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.5' //Required item 👇If you already have this item in your project, you don’t need to add it. implementation 'androidx.appcompat:appcompat:1.3.0' // At least in 1.3.0 and above //Optional 👇, if you want to customize aspects, you need to use them, ⚠️supports aspects written in Java and Kotlin code - ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.4' + ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.5' //Optional 👇, if you want to customize aspects, you need to use them, ⚠️only applies to aspects written in Java code - annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.4' + annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.5' //⚠️Choose one of the above android-aop-ksp and android-aop-processor } ``` diff --git a/docs/zh/android_aop_extra.md b/docs/zh/android_aop_extra.md index 0872ee76..c7a8b61e 100644 --- a/docs/zh/android_aop_extra.md +++ b/docs/zh/android_aop_extra.md @@ -4,7 +4,7 @@ ```groovy dependencies { //非必须项 👇这个包提供了一些常见的注解切面 - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.5' } ``` diff --git a/docs/zh/getting_started.md b/docs/zh/getting_started.md index b6eb6ea5..64bdc47f 100644 --- a/docs/zh/getting_started.md +++ b/docs/zh/getting_started.md @@ -28,7 +28,7 @@ plugins { //必须项 👇 apply 设置为 true 自动为所有module“预”配置debugMode,false则按下边步骤五的方式二 - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4" apply true + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5" apply true } ``` @@ -37,7 +37,7 @@ buildscript { dependencies { //必须项 👇 - classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.4' + classpath 'io.github.FlyJingFish.AndroidAop:android-aop-plugin:2.2.5' } } // 👇加上这句自动为所有module“预”配置debugMode,不加则按下边步骤五的方式二 @@ -85,7 +85,7 @@ //必须项 👇 plugins { ... - id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.4"//最好放在最后一行 + id "io.github.FlyJingFish.AndroidAop.android-aop" version "2.2.5"//最好放在最后一行 } ``` @@ -111,18 +111,18 @@ plugins { dependencies { //必须项 👇 - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-core:2.2.5' //非必须项 👇这个包提供了一些常见的注解切面 - implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.4' + implementation 'io.github.FlyJingFish.AndroidAop:android-aop-extra:2.2.5' //必须项 👇如果您项目内已经有了这项不用加也可以 implementation 'androidx.appcompat:appcompat:1.3.0' // 至少在1.3.0及以上 //非必须项 👇,如果你想自定义切面需要用到,⚠️支持Java和Kotlin代码写的切面 - ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.4' + ksp 'io.github.FlyJingFish.AndroidAop:android-aop-ksp:2.2.5' //非必须项 👇,如果你想自定义切面需要用到,⚠️只适用于Java代码写的切面 - annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.4' + annotationProcessor 'io.github.FlyJingFish.AndroidAop:android-aop-processor:2.2.5' //⚠️上边的 android-aop-ksp 和 android-aop-processor 二选一 } ``` diff --git a/gradle.properties b/gradle.properties index e80730eb..4fcdd2b6 100644 --- a/gradle.properties +++ b/gradle.properties @@ -41,7 +41,7 @@ DEVELOPER_ID=FlyJingFish DEVELOPER_NAME=FlyJingFish DEVELOPER_EMAIL=749617782@qq.com -TestVersion = 2.2.4 +TestVersion = 2.2.5 SonatypeTestCode = 1573 # 0 mavenLocal 1 SonatypeCache 2 mavenCentral TestType = 0 diff --git a/version.properties b/version.properties index 042b7148..821aad3e 100644 --- a/version.properties +++ b/version.properties @@ -1,2 +1,2 @@ -#Fri Oct 18 17:02:58 CST 2024 -PROJ_VERSION=2.2.4 +#Sun Oct 20 17:24:00 CST 2024 +PROJ_VERSION=2.2.5 From 6450cb6d7d03f2ab77d6505967de725edd55b017 Mon Sep 17 00:00:00 2001 From: FlyJingFish Date: Sun, 20 Oct 2024 18:22:08 +0800 Subject: [PATCH 2/2] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E6=96=87=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- docs/zh/getting_started.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/zh/getting_started.md b/docs/zh/getting_started.md index 64bdc47f..09dbb92f 100644 --- a/docs/zh/getting_started.md +++ b/docs/zh/getting_started.md @@ -189,7 +189,7 @@ android { - ~~**方式二:(不推荐)**~~ - 请按照上述[步骤一的方式一配置项目](#apply)后,手动为**需要的子 module 模块**设置,例如: + 请按照上述[步骤一的方式一配置项目](#apply)后,手动为 **需要的子 module 模块** 设置,例如: ```groovy plugins {