diff --git a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/AssembleAndroidAopTask.kt b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/AssembleAndroidAopTask.kt index 1b89c938..bc8a71f1 100644 --- a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/AssembleAndroidAopTask.kt +++ b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/AssembleAndroidAopTask.kt @@ -170,27 +170,29 @@ abstract class AssembleAndroidAopTask : DefaultTask() { } private fun searchJoinPointLocation(){ - val androidConfig = AndroidConfig(project) - val list: List = androidConfig.getBootClasspath() - for (file in list) { - try { - val jarFile = JarFile(file) - val enumeration = jarFile.entries() - while (enumeration.hasMoreElements()) { - val jarEntry = enumeration.nextElement() - try { - val entryName = jarEntry.name - if (entryName.endsWith(Utils._CLASS)) { - val className = entryName.replace(".class","") - WovenInfoUtils.addExtendsReplace(Utils.slashToDot(className)) - } - } catch (_: Exception) { + if (WovenInfoUtils.isHasExtendsReplace()){ + val androidConfig = AndroidConfig(project) + val list: List = androidConfig.getBootClasspath() + for (file in list) { + try { + val jarFile = JarFile(file) + val enumeration = jarFile.entries() + while (enumeration.hasMoreElements()) { + val jarEntry = enumeration.nextElement() + try { + val entryName = jarEntry.name + if (entryName.endsWith(Utils._CLASS)) { + val className = entryName.replace(".class","") + WovenInfoUtils.addExtendsReplace(Utils.slashToDot(className)) + } + } catch (_: Exception) { + } } + jarFile.close() + } catch (e: Exception) { + e.printStackTrace() } - jarFile.close() - } catch (e: Exception) { - e.printStackTrace() } } diff --git a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/utils/WovenInfoUtils.kt b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/utils/WovenInfoUtils.kt index 754ea4c0..356394ea 100644 --- a/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/utils/WovenInfoUtils.kt +++ b/android-aop-plugin/src/main/kotlin/com/flyjingfish/android_aop_plugin/utils/WovenInfoUtils.kt @@ -319,14 +319,18 @@ object WovenInfoUtils { return lastAopMatchCuts != aopMatchCuts } - private var invokeMethodCutCache : MutableList?= null - fun addExtendsReplace(className:String){ + fun isHasExtendsReplace():Boolean{ if (invokeMethodCutCache == null){ invokeMethodCutCache = invokeMethodCuts.filter { it.matchType != AopMatchCut.MatchType.SELF.name }.toMutableList() } - if (invokeMethodCutCache?.isEmpty() == true){ + return !invokeMethodCutCache.isNullOrEmpty() + } + + private var invokeMethodCutCache : MutableList?= null + fun addExtendsReplace(className:String){ + if (!isHasExtendsReplace()){ return } val ctClass = try {