From lynx-debug
Remaps function_id:pc_index from Lynx main-thread.js runtime errors to original source positions using debug-info.json in rspeedy/rsbuild projects.
npx claudepluginhub lynx-community/skills --plugin lynx-debugThis skill uses the workspace's default tool permissions.
In Lynx, main thread script is encoded to bytecode and uses an external debugging information scheme. Under this scheme, the row and column numbers in the runtime error messages are not the actual row and column numbers. The row and column numbers need to be deciphered from the external `debug-info.json` file.
Parses error messages and stack traces, correlates logs, and applies hypothesis-driven methodology to isolate and resolve bugs. Use for error investigation, root cause analysis, troubleshooting crashes.
Guides debugging of errors, unexpected behavior, and code flow tracing using CocoSearch semantic/symbol search with index/dependency health checks.
Parses error messages and stack traces, correlates log entries, and applies hypothesis-driven methodology to isolate and resolve bugs. Use for error investigation, crash troubleshooting, root cause analysis, and log analysis.
Share bugs, ideas, or general feedback.
In Lynx, main thread script is encoded to bytecode and uses an external debugging information scheme. Under this scheme, the row and column numbers in the runtime error messages are not the actual row and column numbers. The row and column numbers need to be deciphered from the external debug-info.json file.
debug-info.json format is as follows:
{
"lepusNG_debug_info": {
"function_info": [
{
"function_id": 1,
"function_name": "App",
"line_col": [
{ "line": 1, "column": 1 },
{ "line": 2, "column": 1 },
{ "line": 3, "column": 1 }
]
}
]
}
}
This skill is useful when you want to remap the function_id:pc_index to the original source code position.
When the user encounters a runtime error message with function_id:pc_index, along with main-thread.js and debug-info.json in the error message, for example:
main-thread.js exception: App render failed at main thread backtrace:
at App (file:///main-thread.js:1356:13)
at doRender (file:///main-thread.js:1002:12)
at call (native)
at render (file:///main-thread.js:466:52)
at _renderToString (file:///main-thread.js:1001:569)
at renderToString (file:///main-thread.js:998:191)
at renderMainThread (file:///main-thread.js:766:45)
at renderPage (file:///main-thread.js:853:69)
Where function_id:pc_index is 1356:13.
function_id:pc_indexUser should provide the function_id:pc_index in the error message. Or give you the full backtrace.
You should check if it is a main-thread backtrace. Since background thread backtrace does not need remapping.
Ask the user for the debug-info.json path. For example in a rspeedy project with main entry it will locate at:
main-thread.js: $PROJECT_DIR/dist/.rspeedy/main/main-thread.jsdebug-info.json: $PROJECT_DIR/dist/.rspeedy/main/debug-info.jsonIf the user uses rspeedy build and there is no .rspeedy folder, remind them to build the project with DEBUG='rspeedy,rsbuild' rspeedy build.
For each function_id:pc_index pair in the stack trace, run the remapping script.
node ${CLAUDE_PLUGIN_ROOT}/skills/debug-info-remapping/scripts/index.mjs $PROJECT_DIR/[dist]/.rspeedy/[main]/debug-info.json $function_id $pc_index
The remapping script will output the remapped position in the format of line:column.
You should output the remapped position for each function_id:pc_index pair.
Replace the function_id:pc_index pair in the stack trace with the remapped position and show the remapped stack trace.
If you can reach the main-thread.js file, show the remapped stack trace with the remapped positions source code.
The final output should be something like this:
main-thread.js exception: App render failed at main thread backtrace:
at App (./dist/.rspeedy/main/main-thread.js:9368:56)
at doRender (./dist/.rspeedy/main/main-thread.js:7237:44)
at call (native)
at render (./dist/.rspeedy/main/main-thread.js:3706:72)
at _renderToString (./dist/.rspeedy/main/main-thread.js:7177:78)
at renderToString (./dist/.rspeedy/main/main-thread.js:7067:91)
at renderMainThread (./dist/.rspeedy/main/main-thread.js:5423:113)
at renderPage (./dist/.rspeedy/main/main-thread.js:6199:46)
╭─[5:55]
3 │ export function App() {
4 │ if (__MAIN_THREAD__) {
5 │ throw new Error('App render failed at main thread');
· ─┬
· ╰── main-thread.js exception: App render failed at main thread backtrace
6 │ }
7 │
╰────
... (the same for other callstacks such as doRender, call, render, _renderToString, renderToString, renderMainThread, renderPage here)
Files used:
- Debug Info: ./dist/.rspeedy/main/debug-info.json
- Source File: ./dist/.rspeedy/main/main-thread.js
The ./dist/.rspeedy/main/main-thread.js:9368:56 will make sure it is clickable in the editor/terminal.