KPropertyFinder - class
open class KPropertyFinder internal constructor(final override val classSet: KClass<*>?) : KCallableBaseFinder
变更记录
v1.0.0 添加
功能描述
KProperty查找类。
可通过指定类型查找指定 KProperty 或一组 KProperty。
name - field
var name: String
变更记录
v1.0.0 添加
功能描述
设置
KProperty名称。
特别注意
若不填写名称则必须存在一个其它条件。
type - field
var type: Any?
变更记录
v1.0.0 添加
功能描述
设置
KProperty类型。
可不填写类型。
modifiers - method
fun modifiers(conditions: KModifierConditions): IndexTypeCondition
变更记录
v1.0.0 添加
功能描述
设置
KProperty标识符筛选条件。
可不设置筛选条件。
特别注意
存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。
order - method
fun order(): IndexTypeCondition
变更记录
v1.0.0 添加
功能描述
顺序筛选字节码的下标。
name - method
fun name(value: String): IndexTypeCondition
变更记录
v1.0.0 添加
功能描述
设置
KProperty名称。
特别注意
若不填写名称则必须存在一个其它条件。
存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。
name - method
fun name(conditions: KNameConditions): IndexTypeCondition
变更记录
v1.0.0 添加
功能描述
设置
KProperty名称条件。
特别注意
若不填写名称则必须存在一个其它条件。
存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。
type - method
fun type(value: Any): IndexTypeCondition
变更记录
v1.0.0 添加
功能描述
设置
KProperty类型。
可不填写类型。
特别注意
存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。
type - method
fun type(conditions: KTypeConditions): IndexTypeCondition
变更记录
v1.0.0 添加
功能描述
设置
KProperty类型条件。
可不填写类型。
特别注意
存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。
superClass - method
fun superClass(isOnlySuperClass: Boolean)
变更记录
v1.0.0 添加
功能描述
设置在
classSet的所有父类中查找当前KProperty。
注意
若当前 classSet 的父类较多可能会耗时,API 会自动循环到父类继承是 Any 前的最后一个类。
RemedyPlan - class
inner class RemedyPlan internal constructor()
变更记录
v1.0.0 添加
功能描述
KProperty重查找实现类,可累计失败次数直到查找成功。
property - method
inline fun property(initiate: KPropertyConditions): Result
变更记录
v1.0.0 添加
功能描述
创建需要重新查找的
KProperty。
你可以添加多个备选 KProperty,直到成功为止,若最后依然失败,将停止查找并输出错误日志。
Result - class
inner class Result internal constructor()
变更记录
v1.0.0 添加
功能描述
RemedyPlan结果实现类。
onFind - method
fun onFind(initiate: MutableList<KProperty>.() -> Unit)
变更记录
v1.0.0 添加
initiate 类型由 HashSet 修改为 MutableList
功能描述
当在
RemedyPlan中找到结果时。
功能示例
你可以方便地对重查找的 KProperty 实现 onFind 方法。
示例如下
property {
// Your code here.
}.onFind {
// Your code here.
}
Result - class
inner class Result internal constructor(internal val isNoSuch: Boolean, internal val throwable: Throwable?) : BaseResult
变更记录
v1.0.0 添加
功能描述
KProperty查找结果实现类。
getter - field
val getter: KFunctionFinder.Result
变更记录
v1.0.0 添加
功能描述
获取属性的 getter 组成的
KFunction查找结果实现类
setter - field
val setter: KFunctionFinder.Result
变更记录
v1.0.0 添加
功能描述
获取属性的 setter 组成的
KFunction查找结果实现类
all - method
fun all(instance: Any?): MutableList<Instance>
result - method
inline fun result(initiate: Result.() -> Unit): Result
变更记录
v1.0.0 添加
功能描述
创建监听结果事件方法体。
功能示例
你可以使用 lambda 形式创建 Result 类。
示例如下
property {
// Your code here.
}.result {
get(instance).set("something")
get(instance).string()
get(instance).cast<CustomClass>()
get().boolean()
all(instance)
give()
giveAll()
onNoSuchProperty {}
}
get - method
fun get(instance: Any?,extensionRef:Any?,isUseMember:Boolean): Instance
变更记录
v1.0.0 添加
功能描述
获得
KProperty实例处理类。
若有多个 KProperty 结果只会返回第一个。
功能示例
你可以轻松地得到 KProperty 的实例以及使用它进行设置实例。
示例如下
property {
// Your code here.
}.get(instance).set("something")
如果你取到的是静态 KProperty,可以不需要设置实例。
示例如下
property {
// Your code here.
}.get().set("something")
all - method
fun all(instance: Any?): MutableList<Instance>
变更记录
v1.0.0 添加
返回值类型由 ArrayList 修改为 MutableList
功能描述
获得
KProperty实例处理类数组。
返回全部查找条件匹配的多个 KProperty 实例结果。
功能示例
你可以通过此方法来获得当前条件结果中匹配的全部 KProperty,其 KProperty 所在实例用法与 get 相同。
示例如下
property {
// Your code here.
}.all(instance).forEach { instance ->
instance.self
}
give - method
fun give(): KProperty?
变更记录
v1.0.0 添加
功能描述
得到
KProperty本身。
若有多个 KProperty 结果只会返回第一个。
在查找条件找不到任何结果的时候将返回 null。
giveAll - method
fun giveAll(): MutableList<KProperty>
变更记录
v1.0.0 添加
返回值类型由 HashSet 修改为 MutableList
功能描述
得到
KProperty本身数组。
返回全部查找条件匹配的多个 KProperty 实例。
在查找条件找不到任何结果的时候将返回空的 MutableList。
wait - method
fun wait(instance: Any?, extensionRef:Any?, isUseMember:Boolean, initiate: Instance.() -> Unit)
变更记录
v1.0.0 添加
功能描述
获得
KProperty实例处理类,配合RemedyPlan使用。
若有多个 KProperty 结果只会返回第一个。
特别注意
若你设置了 remedys 必须使用此方法才能获得结果。
若你没有设置 remedys 此方法将不会被回调。
waitAll - method
fun waitAll(instance: Any?, extensionRef:Any?, isUseMember:Boolean, initiate: MutableList<Instance>.() -> Unit)
变更记录
v1.0.0 添加
initiate 类型由 ArrayList 修改为 MutableList
功能描述
获得
KProperty实例处理类数组,配合RemedyPlan使用。
返回全部查找条件匹配的多个 KProperty 实例结果。
特别注意
若你设置了 remedys 必须使用此方法才能获得结果。
若你没有设置 remedys 此方法将不会被回调。
remedys - method
inline fun remedys(initiate: RemedyPlan.() -> Unit): Result
变更记录
v1.0.0 添加
功能描述
创建
KProperty重查找功能。
功能示例
当你遇到一种 KProperty 可能存在不同形式的存在时,可以使用 RemedyPlan 重新查找它,而没有必要使用 onNoSuchProperty 捕获异常二次查找 KProperty。
若第一次查找失败了,你还可以在这里继续添加此方法体直到成功为止。
示例如下
property {
// Your code here.
}.remedys {
property {
// Your code here.
}
property {
// Your code here.
}
}
onNoSuchProperty - method
fun onNoSuchProperty(result: (Throwable) -> Unit): Result
变更记录
v1.0.0 添加
功能描述
监听找不到
KProperty时。
ignored - method
fun ignored(): Result
变更记录
v1.0.0 添加
功能描述
忽略异常并停止打印任何错误日志。
注意
此时若要监听异常结果,你需要手动实现 onNoSuchProperty 方法。
Instance - class
inner class Instance internal constructor(private val instance: Any?, private val property: KProperty<*>?): BaseInstance
变更记录
v1.0.0 添加
功能描述
KProperty实例变量处理类。
useMember - method
fun useMember(use:Boolean): Instance
变更记录
v1.0.0 添加
功能描述
是否将构造函数转换为Java方式构造
为true时实例执行将通过将 Kotlin构造函数 转换为 JavaMember 方式执行
如果目标属性无法用Java方式描述则此设置将会自动忽略
receiver - method
fun receiver(extensionRef:Any?): Instance
变更记录
v1.0.0 添加
功能描述
修改
extensionRefReceiver
当此属性是拓展属性时,你可能需要此方法额外的一个this属性进行设置
original - method
fun original(): Instance
变更记录
v1.0.0 添加
功能描述
标识需要调用当前
KProperty未经 Hook 的原始KProperty。
若当前 KProperty 并未 Hook 则会使用原始的 KProperty.call 方法调用
特别注意
此方法在 Hook Api 存在时将固定 isUseMember 为 true
你只能在 (Xposed) 宿主环境中使用此功能
此方法仅在 Hook Api 下有效
current - method
fun current(ignored: Boolean): KCurrentClass?
inline fun current(ignored: Boolean, initiate: KCurrentClass.() -> Unit): Any?
变更记录
v1.0.0 添加
功能描述
获得当前
KProperty自身self实例的类操作对象KCurrentClass。
cast - method
fun <T> cast(): T?
变更记录
v1.0.0 添加
功能描述
得到当前
KProperty实例。
byte - method
fun byte(): Byte?
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyByte 实例。
int - method
fun int(): Int
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyInt 实例。
long - method
fun long(): Long
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyLong 实例。
short - method
fun short(): Short
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyShort 实例。
double - method
fun double(): Double
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyDouble 实例。
float - method
fun float(): Float
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyFloat 实例。
string - method
fun string(): String
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyString 实例。
char - method
fun char(): Char
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyChar 实例。
boolean - method
fun boolean(): Boolean
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyBoolean 实例。
any - method
fun any(): Any?
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyAny 实例。
array - method
inline fun <reified T> array(): Array<T>
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyArray 实例。
list - method
inline fun <reified T> list(): List<T>
变更记录
v1.0.0 添加
功能描述
得到当前
KPropertyList 实例。
set - method
fun set(any: Any?)
变更记录
v1.0.0 添加
功能描述
设置当前
KProperty实例。
setTrue - method
fun setTrue()
变更记录
v1.0.0 添加
功能描述
设置当前
KProperty实例为true。
特别注意
请确保实例对象类型为 Boolean。
setFalse - method
fun setFalse()
变更记录
v1.0.0 添加
功能描述
设置当前
KProperty实例为false。
特别注意
请确保实例对象类型为 Boolean。
setNull - method
fun setNull()
变更记录
v1.0.0 添加
功能描述
设置当前
KProperty实例为null。
