Class BeforeFinalReturn
java.lang.Object
org.spongepowered.asm.mixin.injection.InjectionPoint
org.spongepowered.asm.mixin.injection.points.BeforeFinalReturn
This injection point searches for the last RETURN opcode in the target method and returns it. Note that the last RETURN opcode may not correspond to the notional "bottom" of a method in the original Java source, since conditional expressions can cause the bytecode emitted to differ significantly in order from the original Java.
Example:
@At(value = "TAIL")
Note that if value is the only parameter specified, it can be omitted:
@At("TAIL")
-
Nested Class Summary
Nested classes/interfaces inherited from class org.spongepowered.asm.mixin.injection.InjectionPoint
InjectionPoint.AtCode, InjectionPoint.Flags, InjectionPoint.RestrictTargetLevel, InjectionPoint.Specifier -
Field Summary
Fields inherited from class org.spongepowered.asm.mixin.injection.InjectionPoint
DEFAULT_ALLOWED_SHIFT_BY, MAX_ALLOWED_SHIFT_BY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionbooleancheckPriority(int targetPriority, int ownerPriority) Runs a priority check in the context of this injection point.booleanfind(String desc, org.objectweb.asm.tree.InsnList insns, Collection<org.objectweb.asm.tree.AbstractInsnNode> nodes) Find injection points in the supplied insn listReturns the target restriction level for this injection point.
-
Constructor Details
-
BeforeFinalReturn
-
-
Method Details
-
checkPriority
public boolean checkPriority(int targetPriority, int ownerPriority) Description copied from class:InjectionPointRuns a priority check in the context of this injection point. A priority check should return true if the injection point is allowed to inject given the relative priorities of the target (a method merged by another mixin with targetPriority) and the incoming mixin with priority mixinPriority.- Overrides:
checkPriorityin classInjectionPoint- Parameters:
targetPriority- Priority of the mixin which originally merged the target method in questionownerPriority- Priority of the mixin which owns the owning injector- Returns:
- true if the priority check succeeds
-
getTargetRestriction
Description copied from class:InjectionPointReturns the target restriction level for this injection point. This level defines whether an injection point is valid in its current state when being used by a restricted injector (currentlyCallbackInjector).- Overrides:
getTargetRestrictionin classInjectionPoint- Parameters:
context- injection-specific context- Returns:
- restriction level
-
find
public boolean find(String desc, org.objectweb.asm.tree.InsnList insns, Collection<org.objectweb.asm.tree.AbstractInsnNode> nodes) Description copied from class:InjectionPointFind injection points in the supplied insn list- Specified by:
findin classInjectionPoint- Parameters:
desc- Method descriptor, supplied to allow return types and arguments etc. to be determinedinsns- Insn list to search in, the strategy MUST ONLY add nodes from this list to thenodescollectionnodes- Collection of nodes to populate. Injectors should NOT make any assumptions about the state of this collection and should only call the add() method- Returns:
- true if one or more injection points were found
-