Spaces:
Build error
Build error
# EaglercraftX WASM-GC Runtime | |
This folder contains the Gradle project for compiling the EaglercraftX 1.8 client to WASM. This requires a special fork of TeaVM that has been modified for Eaglercraft. The `settings.gradle` and `build.gradle` are set up to download the binaries automatically but if you would like to build the TeaVM fork yourself you can use the TeaVM fork's `publishToMavenLocal` gradle task and replace the URL maven repository declarations in the gradle build scripts with `mavenLocal()` instead. | |
**TeaVM Fork: [https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm/tree/eagler-r1](https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm/tree/eagler-r1)** | |
### To compile the client: | |
1. Run `CompileEPK` to compile the assets.epk file | |
2. Run `CompileWASM` to compile the classes.wasm file | |
3. Run `CompileEagRuntimeJS` to compile the eagruntime.js file | |
4. Run `MakeWASMClientBundle` to bundle the client into an EPW file | |
The final assets.epw and offline download will be in the "javascript_dist" folder | |
### Optional Steps: | |
- Run `CompileBootstrapJS` to recompile bootstrap.js in the javascript_dist folder | |
- Run `CompileLoaderWASM`to recompile loader.js and loader.wasm (requires emscripten) | |
### Potential issues when porting: | |
- Disabling VSync causes bad input lag, the solution to this problem is to remove the vsync option and force people to play with vsync enabled, like all other browser games | |
- TeaVM's WASM GC backend is still under development and will sometimes generate broken code with nested try/finally statements in a try/catch block, or other strange runtime glitches | |
- Fewer reflection features are supported in WASM GC than the JavaScript backend (so far) | |
- Do not use `@Async` or any sort of callback (like addEventListener) in your Java, you must implement async functions in JavaScript in `../src/wasm-gc-teavm/js`, using JSPI to suspend/resume the thread for promises, or by pushing events into a queue that you can poll from your Java for event handlers. | |
- Functions imported via the `@Import` will not catch exceptions, if you want proper exception handling you must call the imported function through the JSO | |