mirror of
https://github.com/HighCapable/YukiHookAPI.git
synced 2025-09-06 02:35:40 +08:00
841 lines
12 KiB
Markdown
841 lines
12 KiB
Markdown
## FieldFinder [class]
|
||
|
||
```kotlin
|
||
class FieldFinder internal constructor(override val hookInstance: YukiMemberHookCreater.MemberHookCreater?, override val classSet: Class<*>?) : BaseFinder()
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.2` `修改`
|
||
|
||
合并到 `BaseFinder`
|
||
|
||
**功能描述**
|
||
|
||
> `Field` 查找类。
|
||
|
||
可通过指定类型查找指定变量或一组变量。
|
||
|
||
### ~~classSet [field]~~ <!-- {docsify-ignore} -->
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.2` `移除`
|
||
|
||
### name [field]
|
||
|
||
```kotlin
|
||
var name: String
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.70` `修改`
|
||
|
||
允许不填写名称
|
||
|
||
**功能描述**
|
||
|
||
> 设置 `Field` 名称。
|
||
|
||
!> 若不填写名称则必须存在一个其它条件。
|
||
|
||
### type [field]
|
||
|
||
```kotlin
|
||
var type: Any?
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 设置 `Field` 类型。
|
||
|
||
可不填写类型。
|
||
|
||
### modifiers [method]
|
||
|
||
```kotlin
|
||
inline fun modifiers(initiate: ModifierRules.() -> Unit): IndexTypeCondition
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.67` `新增`
|
||
|
||
`v1.0.80` `修改`
|
||
|
||
将方法体进行 inline
|
||
|
||
**功能描述**
|
||
|
||
> 设置 `Field` 标识符筛选条件。
|
||
|
||
可不设置筛选条件。
|
||
|
||
!> 存在多个 `IndexTypeCondition` 时除了 `order` 只会生效最后一个。
|
||
|
||
### order [method]
|
||
|
||
```kotlin
|
||
fun order(): IndexTypeCondition
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.70` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 顺序筛选字节码的下标。
|
||
|
||
### name [method]
|
||
|
||
```kotlin
|
||
fun name(value: String): IndexTypeCondition
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.70` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 设置 `Field` 名称。
|
||
|
||
!> 若不填写名称则必须存在一个其它条件。
|
||
|
||
!> 存在多个 `IndexTypeCondition` 时除了 `order` 只会生效最后一个。
|
||
|
||
### name [method]
|
||
|
||
```kotlin
|
||
inline fun name(initiate: NameConditions.() -> Unit): IndexTypeCondition
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.88` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 设置 `Field` 名称条件。
|
||
|
||
!> 若不填写名称则必须存在一个其它条件。
|
||
|
||
!> 存在多个 `IndexTypeCondition` 时除了 `order` 只会生效最后一个。
|
||
|
||
### type [method]
|
||
|
||
```kotlin
|
||
fun type(value: Any): IndexTypeCondition
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.70` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 设置 `Field` 类型。
|
||
|
||
!> 可不填写类型。
|
||
|
||
!> 存在多个 `IndexTypeCondition` 时除了 `order` 只会生效最后一个。
|
||
|
||
### superClass [method]
|
||
|
||
```kotlin
|
||
fun superClass(isOnlySuperClass: Boolean)
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.80` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 设置在 `classSet` 的所有父类中查找当前 `Field`。
|
||
|
||
!> 若当前 `classSet` 的父类较多可能会耗时,API 会自动循环到父类继承是 `Any` 前的最后一个类。
|
||
|
||
### RemedyPlan [class]
|
||
|
||
```kotlin
|
||
inner class RemedyPlan internal constructor()
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> `Field` 重查找实现类,可累计失败次数直到查找成功。
|
||
|
||
#### field [method]
|
||
|
||
```kotlin
|
||
inline fun field(initiate: FieldCondition): Result
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 创建需要重新查找的 `Field`。
|
||
|
||
你可以添加多个备选 `Field`,直到成功为止,若最后依然失败,将停止查找并输出错误日志。
|
||
|
||
#### Result [class]
|
||
|
||
```kotlin
|
||
inner class Result internal constructor()
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> `RemedyPlan` 结果实现类。
|
||
|
||
##### onFind [method]
|
||
|
||
```kotlin
|
||
fun onFind(initiate: HashSet<Field>.() -> Unit)
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 当在 `RemedyPlan` 中找到结果时。
|
||
|
||
**功能示例**
|
||
|
||
你可以方便地对重查找的 `Field` 实现 `onFind` 方法。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
field {
|
||
// Your code here.
|
||
}.onFind {
|
||
// Your code here.
|
||
}
|
||
```
|
||
|
||
### Result [class]
|
||
|
||
```kotlin
|
||
inner class Result internal constructor(internal val isNoSuch: Boolean, private val throwable: Throwable?) : BaseResult
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.93` `修改`
|
||
|
||
继承到接口 `BaseResult`
|
||
|
||
**功能描述**
|
||
|
||
> `Field` 查找结果实现类。
|
||
|
||
#### result [method]
|
||
|
||
```kotlin
|
||
inline fun result(initiate: Result.() -> Unit): Result
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.80` `修改`
|
||
|
||
将方法体进行 inline
|
||
|
||
**功能描述**
|
||
|
||
> 创建监听结果事件方法体。
|
||
|
||
**功能示例**
|
||
|
||
你可以使用 `lambda` 形式创建 `Result` 类。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
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]
|
||
|
||
```kotlin
|
||
fun get(instance: Any?): Instance
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 获得 `Field` 实例处理类。
|
||
|
||
若有多个 `Field` 结果只会返回第一个。
|
||
|
||
**功能示例**
|
||
|
||
你可以轻松地得到 `Field` 的实例以及使用它进行设置实例。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
field {
|
||
// Your code here.
|
||
}.get(instance).set("something")
|
||
```
|
||
|
||
如果你取到的是静态 `Field`,可以不需要设置实例。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
field {
|
||
// Your code here.
|
||
}.get().set("something")
|
||
```
|
||
|
||
#### all [method]
|
||
|
||
```kotlin
|
||
fun all(instance: Any?): ArrayList<Instance>
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 获得 `Field` 实例处理类数组。
|
||
|
||
返回全部查询条件匹配的多个 `Field` 实例结果。
|
||
|
||
**功能示例**
|
||
|
||
你可以通过此方法来获得当前条件结果中匹配的全部 `Field`,其变量所在实例用法与 `get` 相同。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
field {
|
||
// Your code here.
|
||
}.all(instance).forEach { instance ->
|
||
instance.self
|
||
}
|
||
```
|
||
|
||
#### give [method]
|
||
|
||
```kotlin
|
||
fun give(): Field?
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 得到 `Field` 本身。
|
||
|
||
若有多个 Field 结果只会返回第一个。
|
||
|
||
在查询条件找不到任何结果的时候将返回 `null`。
|
||
|
||
#### giveAll [method]
|
||
|
||
```kotlin
|
||
fun giveAll(): HashSet<Field>
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 得到 `Field` 本身数组。
|
||
|
||
返回全部查询条件匹配的多个 `Field` 实例。
|
||
|
||
在查询条件找不到任何结果的时候将返回空的 `HashSet`。
|
||
|
||
#### wait [method]
|
||
|
||
```kotlin
|
||
fun wait(instance: Any?, initiate: Instance.() -> Unit)
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 获得 `Field` 实例处理类,配合 `RemedyPlan` 使用。
|
||
|
||
若有多个 `Field` 结果只会返回第一个。
|
||
|
||
!> 若你设置了 `remedys` 必须使用此方法才能获得结果。
|
||
|
||
!> 若你没有设置 `remedys` 此方法将不会被回调。
|
||
|
||
#### waitAll [method]
|
||
|
||
```kotlin
|
||
fun waitAll(instance: Any?, initiate: ArrayList<Instance>.() -> Unit)
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 获得 `Field` 实例处理类数组,配合 `RemedyPlan` 使用。
|
||
|
||
返回全部查询条件匹配的多个 `Field` 实例结果。
|
||
|
||
!> 若你设置了 `remedys` 必须使用此方法才能获得结果。
|
||
|
||
!> 若你没有设置 `remedys` 此方法将不会被回调。
|
||
|
||
#### remedys [method]
|
||
|
||
```kotlin
|
||
inline fun remedys(initiate: RemedyPlan.() -> Unit): Result
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 创建 `Field` 重查找功能。
|
||
|
||
**功能示例**
|
||
|
||
当你遇到一种 `Field` 可能存在不同形式的存在时,可以使用 `RemedyPlan` 重新查找它,而没有必要使用 `onNoSuchField` 捕获异常二次查找 `Field`。
|
||
|
||
若第一次查找失败了,你还可以在这里继续添加此方法体直到成功为止。
|
||
|
||
> 示例如下
|
||
|
||
```kotlin
|
||
field {
|
||
// Your code here.
|
||
}.remedys {
|
||
field {
|
||
// Your code here.
|
||
}
|
||
field {
|
||
// Your code here.
|
||
}
|
||
}
|
||
```
|
||
|
||
#### onNoSuchField [method]
|
||
|
||
```kotlin
|
||
fun onNoSuchField(result: (Throwable) -> Unit): Result
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 监听找不到 `Field` 时。
|
||
|
||
#### ignored [method]
|
||
|
||
```kotlin
|
||
fun ignored(): Result
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.93` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 忽略异常并停止打印任何错误日志。
|
||
|
||
若 `isNotIgnoredHookingFailure` 为 `false` 则自动忽略。
|
||
|
||
!> 此时若要监听异常结果,你需要手动实现 `onNoSuchField` 方法。
|
||
|
||
#### ~~ignoredError [method]~~ <!-- {docsify-ignore} -->
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.3` `新增`
|
||
|
||
`v1.0.93` `作废`
|
||
|
||
请转移到新方法 `ignored()`
|
||
|
||
#### Instance [class]
|
||
|
||
```kotlin
|
||
inner class Instance internal constructor(private val instance: Any?, private val field: Field?)
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.93` `修改`
|
||
|
||
新增 `field` 参数
|
||
|
||
不再对外公开 `self` 参数
|
||
|
||
**功能描述**
|
||
|
||
> `Field` 实例变量处理类。
|
||
|
||
##### ~~self [field]~~ <!-- {docsify-ignore} -->
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.93` `移除`
|
||
|
||
请直接使用 `any` 方法得到 `Field` 自身的实例化对象
|
||
|
||
##### cast [method]
|
||
|
||
```kotlin
|
||
fun <T> cast(): T?
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`of`~~ 为 `cast`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` 实例。
|
||
|
||
##### byte [method]
|
||
|
||
```kotlin
|
||
fun byte(): Byte?
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.68` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Byte 实例。
|
||
|
||
##### int [method]
|
||
|
||
```kotlin
|
||
fun int(): Int
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofInt`~~ 为 `int`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Int 实例。
|
||
|
||
##### long [method]
|
||
|
||
```kotlin
|
||
fun long(): Long
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofLong`~~ 为 `long`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Long 实例。
|
||
|
||
##### short [method]
|
||
|
||
```kotlin
|
||
fun short(): Short
|
||
```
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofShort`~~ 为 `short`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Short 实例。
|
||
|
||
##### double [method]
|
||
|
||
```kotlin
|
||
fun double(): Double
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofDouble`~~ 为 `double`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Double 实例。
|
||
|
||
##### float [method]
|
||
|
||
```kotlin
|
||
fun float(): Float
|
||
```
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofFloat`~~ 为 `float`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Float 实例。
|
||
|
||
##### string [method]
|
||
|
||
```kotlin
|
||
fun string(): String
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofString`~~ 为 `string`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` String 实例。
|
||
|
||
##### char [method]
|
||
|
||
```kotlin
|
||
fun char(): Char
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.68` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Char 实例。
|
||
|
||
##### boolean [method]
|
||
|
||
```kotlin
|
||
fun boolean(): Boolean
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofBoolean`~~ 为 `boolean`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Boolean 实例。
|
||
|
||
##### any [method]
|
||
|
||
```kotlin
|
||
fun any(): Any?
|
||
```
|
||
**变更记录**
|
||
|
||
`v1.0.65` `新增`
|
||
|
||
`v1.0.68` `修改`
|
||
|
||
修改 ~~`ofAny`~~ 为 `any`
|
||
|
||
移动方法到 `Instance`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Any 实例。
|
||
|
||
##### array [method]
|
||
|
||
```kotlin
|
||
inline fun <reified T> array(): Array<T>
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.68` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` Array 实例。
|
||
|
||
##### list [method]
|
||
|
||
```kotlin
|
||
inline fun <reified T> list(): List<T>
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0.68` `新增`
|
||
|
||
**功能描述**
|
||
|
||
> 得到当前 `Field` List 实例。
|
||
|
||
##### set [method]
|
||
|
||
```kotlin
|
||
fun set(any: Any?)
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 设置当前 `Field` 实例。
|
||
|
||
##### setTrue [method]
|
||
|
||
```kotlin
|
||
fun setTrue()
|
||
```
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 设置当前 `Field` 实例为 `true`。
|
||
|
||
!> 请确保实例对象类型为 `Boolean`。
|
||
|
||
##### setFalse [method]
|
||
|
||
```kotlin
|
||
fun setFalse()
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 设置当前 `Field` 实例为 `false`。
|
||
|
||
!> 请确保实例对象类型为 `Boolean`。
|
||
|
||
##### setNull [method]
|
||
|
||
```kotlin
|
||
fun setNull()
|
||
```
|
||
|
||
**变更记录**
|
||
|
||
`v1.0` `添加`
|
||
|
||
**功能描述**
|
||
|
||
> 设置当前 `Field` 实例为 `null`。 |