EaglerForgeInjector

TeaVM Quirks and Caveats

When TeaVM compiles code, it sometimes does strange things.

Property Suffixes

TeaVM will add suffixes to some variables, seemingly randomly. An example is the property inGround of any entity. When accessing this on the ModAPI.player.fishEntity object, TeaVM has renamed it to inGround2. Can be mitigated with ModAPI.util.getNearestProperty, or, even better, using a corrective version of ModAPI.player.

Collapsing Methods

When I was trying to hook into the server-side processing of chat messages, I found that chat packets were handled by the method processChatMessage in NetHandlerPlayServer. However, in the compiled JavaScript, this method no longer exists. This is because it is only used once, in the processPacket method of C01PacketChatMessage. TeaVM automatically saw this, and collapsed one method into the other.

Dedicated Server Not Responding / Client Not Responding

Incorrectly patching methods with ModAPI.hooks (such as returning false instead of 0, or a javascript string without using ModAPI.str()) will effectively cause the memory stack to implode, along with all crash handlers. I came across this when I was using the processcommand event with preventDefault set to true. I didn’t return any value when patching methods for the event being preventDefaulted, when the output expected was a java boolean (0/1). This would cause the dedicated server to freeze/lock up, without triggering any form of crash.

Update 13/09/2024: Any form of incorrect data type, even passing the wrong values, can cause this sort of hang. I encountered this when trying to set a block in the world to any form of wood or leaf block, without adding iproperties to the tree type.

Update 13/09/2024: Calling methods while the TeaVM thread is in a critical transition state (see ModAPI.util.isCritical()) will shift the call stack, cause methods to access the incorrect values at runtime, and also cause the stack to implode. Gotta love TeaVM.

Update 22/09/2024: See Asynchronous Code

Update 4/10/2024: @Async issue solved, see PromisifyDocumentation

TeaVM thread suspension/resumption

TeaVM allows for writing asynchronous callbacks, which eaglercraft uses for file operations and downloading from URIs. However, when a method that makes use of an async callback gets run from ModAPI, it triggers a stack implosion due to mismatches in value types upon return (as well as a whole other myriad of symptoms). Currently this is not supported by ModAPI, and it will take some time until it will be. In the meanwhile, avoid using constructors or methods that access a file or use other asynchronous apis. Examples:

Potential workarounds: This isn’t confirmed yet, but there is a probable chance that overriding or patching methods in classes like VFile2 or PlatformFilesystem is a viable workaround. (22/09/2024). I’ll be verifying this is the future and if it is possible, releasing a library for it. (the maybe-library is going to be called AsyncSink if it will exist)