From ccbe157b0796eb05fbe029f0d34b1eebe14c40cb Mon Sep 17 00:00:00 2001 From: ChristopherHX Date: Sat, 30 Nov 2024 12:13:18 +0100 Subject: [PATCH] Explain how debug ndk libraries in the docs --- .../advanced/debugging_ndk_libraries/index.md | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/src/extra/advanced/debugging_ndk_libraries/index.md b/src/extra/advanced/debugging_ndk_libraries/index.md index c4a2d3d..01bb93c 100644 --- a/src/extra/advanced/debugging_ndk_libraries/index.md +++ b/src/extra/advanced/debugging_ndk_libraries/index.md @@ -7,6 +7,22 @@ You get the load address with . Minecraft's load address is printed to the log as a hex number. +## codelldb + +Works on linux, macOS and windows on both arm64 and intel + +1. Install vscode +2. Install codelldb extension +3. Compile the launcher with `-DCMAKE_BUILD_TYPE=Debug` +4. Add the following property (only the python api seem to ignore that we load debug info of `.so` files into a macOS / windows process) + ```json + "preRunCommands": [ + "breakpoint set --name mcpelauncher_linker_notifylldb -C \"script lldb.debugger.GetSelectedTarget().SetModuleLoadAddress(lldb.debugger.GetSelectedTarget().AddModule(lldb.process.ReadCStringFromMemory(lldb.frame.FindVariable('filename').unsigned, 255, lldb.SBError()), '', ''), lldb.frame.FindVariable('offset').unsigned)\" --auto-continue true", + ] + ``` + mcpelauncher-linker exposes this function used as an automated breakpoint and calls it before calling the constructor of the game, the address is available in the cli output as well. +5. Enjoy having step debugging in mods compiled with debug information and better stack traces of the minecraft game + ## Development Utilities Use readelf to list symbols of `libminecraftpe.so`