mirror of
				https://github.com/HighCapable/YukiHookAPI.git
				synced 2025-10-26 05:19:25 +08:00 
			
		
		
		
	Add more function
This commit is contained in:
		| @@ -112,10 +112,11 @@ class ConstructorFinder(private val hookInstance: YukiHookCreater.MemberHookCrea | ||||
|      * @param isAlwaysPrint 忽略条件每次都打印错误 | ||||
|      */ | ||||
|     private fun onFailureMsg(msg: String = "", throwable: Throwable? = null, isAlwaysPrint: Boolean = false) { | ||||
|         Thread { | ||||
|         fun print() = loggerE(msg = "NoSuchConstructor happend in [$hookClass] $msg [${hookInstance.tag}]", e = throwable) | ||||
|         if (isAlwaysPrint) print() | ||||
|         else Thread { | ||||
|             SystemClock.sleep(10) | ||||
|             if ((hookInstance.isNotIgnoredHookingFailure && !isUsingRemedyPlan) || isAlwaysPrint) | ||||
|                 loggerE(msg = "NoSuchConstructor happend in [$hookClass] $msg [${hookInstance.tag}]", e = throwable) | ||||
|             if (hookInstance.isNotIgnoredHookingFailure && !isUsingRemedyPlan) print() | ||||
|         }.start() | ||||
|     } | ||||
|  | ||||
| @@ -127,7 +128,7 @@ class ConstructorFinder(private val hookInstance: YukiHookCreater.MemberHookCrea | ||||
|     inner class RemedyPlan { | ||||
|  | ||||
|         /** 失败尝试次数数组 */ | ||||
|         private val remedyPlans = HashSet<ConstructorFinder>() | ||||
|         private val remedyPlans = HashSet<Pair<ConstructorFinder, Result>>() | ||||
|  | ||||
|         /** | ||||
|          * 创建需要重新查找的 [Constructor] | ||||
| @@ -138,7 +139,7 @@ class ConstructorFinder(private val hookInstance: YukiHookCreater.MemberHookCrea | ||||
|          * @param initiate 方法体 | ||||
|          */ | ||||
|         fun constructor(initiate: ConstructorFinder.() -> Unit) = | ||||
|             remedyPlans.add(ConstructorFinder(hookInstance, hookClass).apply(initiate)) | ||||
|             Result().apply { remedyPlans.add(Pair(ConstructorFinder(hookInstance, hookClass).apply(initiate), this)) } | ||||
|  | ||||
|         /** | ||||
|          * 开始重查找 | ||||
| @@ -153,11 +154,12 @@ class ConstructorFinder(private val hookInstance: YukiHookCreater.MemberHookCrea | ||||
|                 remedyPlans.forEachIndexed { p, it -> | ||||
|                     runCatching { | ||||
|                         runBlocking { | ||||
|                             hookInstance.member = it.result | ||||
|                             hookInstance.member = it.first.result | ||||
|                         }.result { | ||||
|                             hookInstance.onHookLogMsg(msg = "Find Constructor [${hookInstance.member}] takes ${it}ms [${hookInstance.tag}]") | ||||
|                         } | ||||
|                         isFindSuccess = true | ||||
|                         it.second.onFindCallback?.invoke(hookInstance.member as Constructor<*>) | ||||
|                         hookInstance.onHookLogMsg(msg = "Constructor [${hookInstance.member}] trying ${p + 1} times success by RemedyPlan [${hookInstance.tag}]") | ||||
|                         return@run | ||||
|                     }.onFailure { | ||||
| @@ -175,6 +177,25 @@ class ConstructorFinder(private val hookInstance: YukiHookCreater.MemberHookCrea | ||||
|                 } | ||||
|             } else loggerW(msg = "RemedyPlan is empty,forgot it? [${hookInstance.tag}]") | ||||
|         } | ||||
|  | ||||
|         /** | ||||
|          * [RemedyPlan] 结果实现类 | ||||
|          * | ||||
|          * 可在这里处理是否成功的回调 | ||||
|          */ | ||||
|         inner class Result { | ||||
|  | ||||
|             /** 找到结果时的回调 */ | ||||
|             internal var onFindCallback: (Constructor<*>.() -> Unit)? = null | ||||
|  | ||||
|             /** | ||||
|              * 当找到结果时 | ||||
|              * @param initiate 回调 | ||||
|              */ | ||||
|             fun onFind(initiate: Constructor<*>.() -> Unit) { | ||||
|                 onFindCallback = initiate | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
| @@ -130,10 +130,11 @@ class MethodFinder(private val hookInstance: YukiHookCreater.MemberHookCreater, | ||||
|      * @param isAlwaysPrint 忽略条件每次都打印错误 | ||||
|      */ | ||||
|     private fun onFailureMsg(msg: String = "", throwable: Throwable? = null, isAlwaysPrint: Boolean = false) { | ||||
|         Thread { | ||||
|         fun print() = loggerE(msg = "NoSuchMethod happend in [$hookClass] $msg [${hookInstance.tag}]", e = throwable) | ||||
|         if (isAlwaysPrint) print() | ||||
|         else Thread { | ||||
|             SystemClock.sleep(10) | ||||
|             if ((hookInstance.isNotIgnoredHookingFailure && !isUsingRemedyPlan) || isAlwaysPrint) | ||||
|                 loggerE(msg = "NoSuchMethod happend in [$hookClass] $msg [${hookInstance.tag}]", e = throwable) | ||||
|             if (hookInstance.isNotIgnoredHookingFailure && !isUsingRemedyPlan) print() | ||||
|         }.start() | ||||
|     } | ||||
|  | ||||
| @@ -145,7 +146,7 @@ class MethodFinder(private val hookInstance: YukiHookCreater.MemberHookCreater, | ||||
|     inner class RemedyPlan { | ||||
|  | ||||
|         /** 失败尝试次数数组 */ | ||||
|         private val remedyPlans = HashSet<MethodFinder>() | ||||
|         private val remedyPlans = HashSet<Pair<MethodFinder, Result>>() | ||||
|  | ||||
|         /** | ||||
|          * 创建需要重新查找的 [Method] | ||||
| @@ -154,9 +155,10 @@ class MethodFinder(private val hookInstance: YukiHookCreater.MemberHookCreater, | ||||
|          * | ||||
|          * 若最后依然失败 - 将停止查找并输出错误日志 | ||||
|          * @param initiate 方法体 | ||||
|          * @return [Result] 结果 | ||||
|          */ | ||||
|         fun method(initiate: MethodFinder.() -> Unit) = | ||||
|             remedyPlans.add(MethodFinder(hookInstance, hookClass).apply(initiate)) | ||||
|             Result().apply { remedyPlans.add(Pair(MethodFinder(hookInstance, hookClass).apply(initiate), this)) } | ||||
|  | ||||
|         /** | ||||
|          * 开始重查找 | ||||
| @@ -171,11 +173,12 @@ class MethodFinder(private val hookInstance: YukiHookCreater.MemberHookCreater, | ||||
|                 remedyPlans.forEachIndexed { p, it -> | ||||
|                     runCatching { | ||||
|                         runBlocking { | ||||
|                             hookInstance.member = it.result | ||||
|                             hookInstance.member = it.first.result | ||||
|                         }.result { | ||||
|                             hookInstance.onHookLogMsg(msg = "Find Method [${hookInstance.member}] takes ${it}ms [${hookInstance.tag}]") | ||||
|                         } | ||||
|                         isFindSuccess = true | ||||
|                         it.second.onFindCallback?.invoke(hookInstance.member as Method) | ||||
|                         hookInstance.onHookLogMsg(msg = "Method [${hookInstance.member}] trying ${p + 1} times success by RemedyPlan [${hookInstance.tag}]") | ||||
|                         return@run | ||||
|                     }.onFailure { | ||||
| @@ -193,6 +196,25 @@ class MethodFinder(private val hookInstance: YukiHookCreater.MemberHookCreater, | ||||
|                 } | ||||
|             } else loggerW(msg = "RemedyPlan is empty,forgot it? [${hookInstance.tag}]") | ||||
|         } | ||||
|  | ||||
|         /** | ||||
|          * [RemedyPlan] 结果实现类 | ||||
|          * | ||||
|          * 可在这里处理是否成功的回调 | ||||
|          */ | ||||
|         inner class Result { | ||||
|  | ||||
|             /** 找到结果时的回调 */ | ||||
|             internal var onFindCallback: (Method.() -> Unit)? = null | ||||
|  | ||||
|             /** | ||||
|              * 当找到结果时 | ||||
|              * @param initiate 回调 | ||||
|              */ | ||||
|             fun onFind(initiate: Method.() -> Unit) { | ||||
|                 onFindCallback = initiate | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|   | ||||
		Reference in New Issue
	
	Block a user