mixed debug between JavaScript and Rust. #4389
                  
                    
                      bvanjoi
                    
                  
                
                  started this conversation in
                Show and tell
              
            Replies: 2 comments 14 replies
-
| really nice explanation | 
Beta Was this translation helpful? Give feedback.
                  
                    0 replies
                  
                
            -
| 不知为何,在我的电脑上无法正常断点,总是自动结束 | 
Beta Was this translation helpful? Give feedback.
                  
                    14 replies
                  
                
            
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
        
    
Uh oh!
There was an error while loading. Please reload this page.
Uh oh!
There was an error while loading. Please reload this page.
-
This discussion aims to illustrate the method for mixed debugging between JavaScript and Rust.
Prerequisites
To illustrate this process, I'll use an example. Let's start by introduce the environment and example I have used.
rspack build ${projectRoot}/examples/basicFirstly, you need to build rspack in debug mode. To do this, execute the following commands in the project's root directory:
Configure
launch.jsonin vscodeIt's necessary to configure two debug configurations within 
.vscode/launch.json.{ "name": "attach:node”, "request": "attach", // refer: https://code.visualstudio.com/docs/editor/debugging#_launch-versus-attach-configurations "type": "node", // `9229` is the default port of message "port": 9229 }{ "name": "launch:rust-from-node", "request": "launch”, "type": "lldb", // it means we use `lldb` to launch the binary file of `node` "program": "node”, "args": [ "--inspect", "--enable-source-maps", "${workspaceFolder}/packages/rspack-cli/bin/rspack", "build", "-c", "${workspaceFolder}/examples/basic/rspack.config.js", ], // `cwd` is just for repack find the correclty entry. "cwd": "${workspaceFolder}/examples/basic/" }Next, we can utilize compounds to amalgamate the two commands:
{ "name": "mix-debug", "configurations": [ "attach:node", "launch:rust-from-node" ] }Finally, your
launch.jsonshould appear as follows:{ "configurations": [ { "name": "attach:node", "request": "attach", "type": "node", "port": 9229 }, { "name": "launch:rust-from-node", "request": "launch", "type": "lldb", "program": "node", "args": [ "--inspect", "--enable-source-maps", "${workspaceFolder}/packages/rspack-cli/bin/rspack", "build", "-c", "${workspaceFolder}/examples/basic/rspack.config.js", ], "cwd": "${workspaceFolder}/examples/basic/" } ], "compounds": [ { "name": "mix-debug", "configurations": [ "attach:node", "launch:rust-from-node" ] } ] }Debugging Attempt
Next, we can introduce some breakpoints and commence debugging.
The result appears as follows:
2023-10-23.13.59.08.mov
Beta Was this translation helpful? Give feedback.
All reactions