Files
YukiHookAPI/docs/api/public/FieldFinder.md

12 KiB
Raw Blame History

FieldFinder - class

class FieldFinder internal constructor(override val hookInstance: YukiMemberHookCreator.MemberHookCreator?, override val classSet: Class<*>?) : MemberBaseFinder

变更记录

v1.0 添加

v1.0.2 修改

合并到 BaseFinder

v1.0.93 修改

合并到 MemberBaseFinder

功能描述

Field 查找类。

可通过指定类型查找指定 Field 或一组 Field

classSet - field

变更记录

v1.0 添加

v1.0.2 移除

name - field

var name: String

变更记录

v1.0 添加

v1.0.70 修改

允许不填写名称

功能描述

设置 Field 名称。

!> 若不填写名称则必须存在一个其它条件。

type - field

var type: Any?

变更记录

v1.0 添加

功能描述

设置 Field 类型。

可不填写类型。

modifiers - method

inline fun modifiers(initiate: ModifierRules.() -> Unit): IndexTypeCondition

变更记录

v1.0.67 新增

v1.0.80 修改

将方法体进行 inline

功能描述

设置 Field 标识符筛选条件。

可不设置筛选条件。

!> 存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。

order - method

fun order(): IndexTypeCondition

变更记录

v1.0.70 新增

功能描述

顺序筛选字节码的下标。

name - method

fun name(value: String): IndexTypeCondition

变更记录

v1.0.70 新增

功能描述

设置 Field 名称。

!> 若不填写名称则必须存在一个其它条件。

!> 存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。

name - method

inline fun name(initiate: NameConditions.() -> Unit): IndexTypeCondition

变更记录

v1.0.88 新增

功能描述

设置 Field 名称条件。

!> 若不填写名称则必须存在一个其它条件。

!> 存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。

type - method

fun type(value: Any): IndexTypeCondition

变更记录

v1.0.70 新增

功能描述

设置 Field 类型。

!> 可不填写类型。

!> 存在多个 IndexTypeCondition 时除了 order 只会生效最后一个。

superClass - method

fun superClass(isOnlySuperClass: Boolean)

变更记录

v1.0.80 新增

功能描述

设置在 classSet 的所有父类中查找当前 Field

!> 若当前 classSet 的父类较多可能会耗时API 会自动循环到父类继承是 Any 前的最后一个类。

RemedyPlan - class

inner class RemedyPlan internal constructor()

变更记录

v1.0.93 新增

功能描述

Field 重查找实现类,可累计失败次数直到查找成功。

field - method

inline fun field(initiate: FieldCondition): Result

变更记录

v1.0.93 新增

功能描述

创建需要重新查找的 Field

你可以添加多个备选 Field,直到成功为止,若最后依然失败,将停止查找并输出错误日志。

Result - class

inner class Result internal constructor()

变更记录

v1.0.93 新增

功能描述

RemedyPlan 结果实现类。

onFind - method
fun onFind(initiate: HashSet<Field>.() -> Unit)

变更记录

v1.0.93 新增

功能描述

当在 RemedyPlan 中找到结果时。

功能示例

你可以方便地对重查找的 Field 实现 onFind 方法。

示例如下

field {
    // Your code here.
}.onFind {
    // Your code here.
}

Result - class

inner class Result internal constructor(internal val isNoSuch: Boolean, private val throwable: Throwable?) : BaseResult

变更记录

v1.0 添加

v1.0.93 修改

继承到接口 BaseResult

功能描述

Field 查找结果实现类。

result - method

inline fun result(initiate: Result.() -> Unit): Result

变更记录

v1.0 添加

v1.0.80 修改

将方法体进行 inline

功能描述

创建监听结果事件方法体。

功能示例

你可以使用 lambda 形式创建 Result 类。

示例如下

field {
    // Your code here.
}.result {
    get(instance).set("something")
    get(instance).string()
    get(instance).cast<CustomClass>()
    get().boolean()
    all(instance)
    give()
    giveAll()
    onNoSuchField {}
}

get - method

fun get(instance: Any?): Instance

变更记录

v1.0 添加

功能描述

获得 Field 实例处理类。

若有多个 Field 结果只会返回第一个。

功能示例

你可以轻松地得到 Field 的实例以及使用它进行设置实例。

示例如下

field {
    // Your code here.
}.get(instance).set("something")

如果你取到的是静态 Field,可以不需要设置实例。

示例如下

field {
    // Your code here.
}.get().set("something")

all - method

fun all(instance: Any?): ArrayList<Instance>

变更记录

v1.0.93 新增

功能描述

获得 Field 实例处理类数组。

返回全部查询条件匹配的多个 Field 实例结果。

功能示例

你可以通过此方法来获得当前条件结果中匹配的全部 Field,其 Field 所在实例用法与 get 相同。

示例如下

field {
    // Your code here.
}.all(instance).forEach { instance ->
    instance.self
}

give - method

fun give(): Field?

变更记录

v1.0 添加

功能描述

得到 Field 本身。

若有多个 Field 结果只会返回第一个。

在查询条件找不到任何结果的时候将返回 null

giveAll - method

fun giveAll(): HashSet<Field>

变更记录

v1.0.93 新增

功能描述

得到 Field 本身数组。

返回全部查询条件匹配的多个 Field 实例。

在查询条件找不到任何结果的时候将返回空的 HashSet

wait - method

fun wait(instance: Any?, initiate: Instance.() -> Unit)

变更记录

v1.0.93 新增

功能描述

获得 Field 实例处理类,配合 RemedyPlan 使用。

若有多个 Field 结果只会返回第一个。

!> 若你设置了 remedys 必须使用此方法才能获得结果。

!> 若你没有设置 remedys 此方法将不会被回调。

waitAll - method

fun waitAll(instance: Any?, initiate: ArrayList<Instance>.() -> Unit)

变更记录

v1.0.93 新增

功能描述

获得 Field 实例处理类数组,配合 RemedyPlan 使用。

返回全部查询条件匹配的多个 Field 实例结果。

!> 若你设置了 remedys 必须使用此方法才能获得结果。

!> 若你没有设置 remedys 此方法将不会被回调。

remedys - method

inline fun remedys(initiate: RemedyPlan.() -> Unit): Result

变更记录

v1.0.93 新增

功能描述

创建 Field 重查找功能。

功能示例

当你遇到一种 Field 可能存在不同形式的存在时,可以使用 RemedyPlan 重新查找它,而没有必要使用 onNoSuchField 捕获异常二次查找 Field

若第一次查找失败了,你还可以在这里继续添加此方法体直到成功为止。

示例如下

field {
    // Your code here.
}.remedys {
    field {
        // Your code here.
    }
    field {
        // Your code here.
    }
}

onNoSuchField - method

fun onNoSuchField(result: (Throwable) -> Unit): Result

变更记录

v1.0 添加

功能描述

监听找不到 Field 时。

ignored - method

fun ignored(): Result

变更记录

v1.0.93 新增

功能描述

忽略异常并停止打印任何错误日志。

isNotIgnoredHookingFailurefalse 则自动忽略。

!> 此时若要监听异常结果,你需要手动实现 onNoSuchField 方法。

ignoredError - method

变更记录

v1.0.3 新增

v1.0.93 作废

请转移到新方法 ignored()

Instance - class

inner class Instance internal constructor(private val instance: Any?, private val field: Field?)

变更记录

v1.0 添加

v1.0.93 修改

新增 field 参数

不再对外公开 self 参数

功能描述

Field 实例变量处理类。

self - field

变更记录

v1.0 添加

v1.0.93 移除

请直接使用 any 方法得到 Field 自身的实例化对象

current - method
fun current(ignored: Boolean): CurrentClass?
inline fun current(ignored: Boolean, initiate: CurrentClass.() -> Unit): Any?

变更记录

v1.0.93 新增

功能描述

获得当前 Field 自身 self 实例的类操作对象 CurrentClass

cast - method
fun <T> cast(): T?

变更记录

v1.0 添加

v1.0.68 修改

修改 ofcast

移动方法到 Instance

功能描述

得到当前 Field 实例。

byte - method
fun byte(): Byte?

变更记录

v1.0.68 新增

功能描述

得到当前 Field Byte 实例。

int - method
fun int(): Int

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofIntint

移动方法到 Instance

功能描述

得到当前 Field Int 实例。

long - method
fun long(): Long

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofLonglong

移动方法到 Instance

功能描述

得到当前 Field Long 实例。

short - method
fun short(): Short

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofShortshort

移动方法到 Instance

功能描述

得到当前 Field Short 实例。

double - method
fun double(): Double

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofDoubledouble

移动方法到 Instance

功能描述

得到当前 Field Double 实例。

float - method
fun float(): Float

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofFloatfloat

移动方法到 Instance

功能描述

得到当前 Field Float 实例。

string - method
fun string(): String

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofStringstring

移动方法到 Instance

功能描述

得到当前 Field String 实例。

char - method
fun char(): Char

变更记录

v1.0.68 新增

功能描述

得到当前 Field Char 实例。

boolean - method
fun boolean(): Boolean

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofBooleanboolean

移动方法到 Instance

功能描述

得到当前 Field Boolean 实例。

any - method
fun any(): Any?

变更记录

v1.0.65 新增

v1.0.68 修改

修改 ofAnyany

移动方法到 Instance

功能描述

得到当前 Field Any 实例。

array - method
inline fun <reified T> array(): Array<T>

变更记录

v1.0.68 新增

功能描述

得到当前 Field Array 实例。

list - method
inline fun <reified T> list(): List<T>

变更记录

v1.0.68 新增

功能描述

得到当前 Field List 实例。

set - method
fun set(any: Any?)

变更记录

v1.0 添加

功能描述

设置当前 Field 实例。

setTrue - method
fun setTrue()

变更记录

v1.0 添加

功能描述

设置当前 Field 实例为 true

!> 请确保实例对象类型为 Boolean

setFalse - method
fun setFalse()

变更记录

v1.0 添加

功能描述

设置当前 Field 实例为 false

!> 请确保实例对象类型为 Boolean

setNull - method
fun setNull()

变更记录

v1.0 添加

功能描述

设置当前 Field 实例为 null