tutorial:mixin_tips
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revision | |||
tutorial:mixin_tips [2023/12/18 01:54] – solidblock | tutorial:mixin_tips [2023/12/18 02:06] (current) – solidblock | ||
---|---|---|---|
Line 5: | Line 5: | ||
This is a collection of different tips some might find useful. It's recommended to read the previous articles to understand the tips. | This is a collection of different tips some might find useful. It's recommended to read the previous articles to understand the tips. | ||
- | ===== Why make a class abstract? ===== | + | ===== Make abstract |
- | + | ||
- | ==== 1. Prevent instantiation | + | |
It's fair to say that you should never instantiate a mixin class, mainly because the class doesn' | It's fair to say that you should never instantiate a mixin class, mainly because the class doesn' | ||
Line 17: | Line 15: | ||
</ | </ | ||
- | + | ===== Make abstract | |
- | ==== 2. Make more elegant | + | |
If you want to access a unaccessible method or field from your target class into your mixin class, you need to use '' | If you want to access a unaccessible method or field from your target class into your mixin class, you need to use '' | ||
Line 37: | Line 34: | ||
Note: this doesn' | Note: this doesn' | ||
- | ==== 3. Access the '' | + | ===== Access the '' |
- | In mixin, if you want to access the " | + | In mixin, if you want to access the "'' |
<code java> | <code java> | ||
Line 100: | Line 97: | ||
These are the same as the static inaccessible inner classes, the only difference is that since they don't have a name, they are declared by appearance order, for example: the anonymous inner class if declared in our previous example class first would be named Outer$1, a second one would be named Outer$2, a third one Outer$3 and so on (the declaration order is on source level). | These are the same as the static inaccessible inner classes, the only difference is that since they don't have a name, they are declared by appearance order, for example: the anonymous inner class if declared in our previous example class first would be named Outer$1, a second one would be named Outer$2, a third one Outer$3 and so on (the declaration order is on source level). | ||
- | ** UNDER CONSTRUCTION ** | + | ===== How to mixin to lambdas ===== |
+ | Sometimes you want to mixin to lambdas. However, lambda do not have visible names. In this case, remember that **mixin is applied to bytecode instead of source**. Therefore, you can view the bytecode to view lambdas. | ||
+ | |||
+ | For example, we want to inject the lambda in '' | ||
+ | <code java> | ||
+ | public class EntitySelectorOptions { | ||
+ | public static void register() { | ||
+ | if (...) { | ||
+ | putOption(" | ||
+ | // Assume that you want to mixin to here | ||
+ | int i = reader.getReader().getCursor(); | ||
+ | // ... | ||
+ | } | ||
+ | // ... | ||
+ | } | ||
+ | } | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | If you directly injects to '' | ||
+ | <code java> | ||
+ | private static synthetic method_9982(Lnet/ | ||
+ | L0 | ||
+ | // ... | ||
+ | </ | ||
+ | |||
+ | Therefore, the method name of the lambda you want to mixin should be '' | ||
+ | |||
+ | ===== Mixin to those not remapped ===== | ||
+ | |||
+ | If you want to mixin to classes, methods or fields that are not remapped in yarn, such as '' | ||
+ | <code java> | ||
+ | @Mixin(value = StringReader.class, | ||
+ | public abstract class StringReaderMixin { ... } | ||
+ | </ | ||
+ | |||
+ | Another example is: | ||
+ | |||
+ | <code java> | ||
+ | @Mixin(EntitySelectorReader.class) | ||
+ | public abstract class EntitySelectorReaderMixin { | ||
+ | @Inject(method = " | ||
+ | // your injection method ... | ||
+ | } | ||
+ | </ |
tutorial/mixin_tips.txt · Last modified: 2023/12/18 02:06 by solidblock