-
-
Notifications
You must be signed in to change notification settings - Fork 205
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Won't terminate after the first encountered breakpoint on vscode-js-debug #1166
Comments
I've delved a bit more into it and I can actually terminate the debuggee after the first breakpoint with firing 3 terminate commands (and in case of the second breakpoint too). I don't think this is expected... The terminate requests have to occur with some delay in between Btw, node version doesn't seem to matter |
vscode-js-debug starts multiple sub-sessions and terminate currently only terminates the active session. You can see the sessions using something like:
|
Thanks! Do you imagine some clean way of terminating all the children as well?
(and without |
+1 for this experience not being very good, whether or not it is in the scope of nvim-dap to fix it... |
Interestingly, I was experience the same "three strikes" behavior as you did @foxt451 , but if I open up the sessions list as described by @mfussenegger and then selecting the top level session before running |
The following hackish bind solves the issue for me right now. If someone can tell me how to actually tell it to set the top level session of the branch that I'm currently on, and not just the first best one, that would be awesome! {
"<leader>dt",
function()
local dap = require("dap")
local session_to_activate = nil
local sessions = dap.sessions()
for _, s in pairs(sessions) do
session_to_activate = s
break
end
if session_to_activate ~= nil then
dap.set_session(session)
end
dap.terminate()
end,
desc = "Terminate",
} |
Could you try with: local dap = require("dap")
local session = dap.session()
if session and session.parent then
dap.set_session(session.parent)
end
dap.terminate() Doing this implicitly within terminate() could be an option |
Cool, didn't know about session.parent! Will try. How about if the focused session is more than one level deep? Maybe a while loop to traverse until session.parent is nil? Not sure if this is a real world case though (but I know that these things go more than one level deep with JS, but it seems to always break at the 1-level deep session) |
Btw, how would you recommend setting a bind to terminate ALL sessions? |
Debug adapter definition and debug configuration
{
"microsoft/vscode-js-debug",
build = "npm install --legacy-peer-deps && npx gulp dapDebugServer && mv dist out",
}
{
"mfussenegger/nvim-dap",
dependencies = {
"microsoft/vscode-js-debug",
},
config = function()
require("dap").adapters["pwa-node"] = {
type = "server",
host = "localhost",
port = "${port}",
executable = {
command = "node",
args = {
vim.call("stdpath", "data") .. "/lazy/vscode-js-debug/out/src/dapDebugServer.js",
"${port}",
},
}
}
for _, language in ipairs({ "typescript", "javascript" }) do
require("dap").configurations[language] = {
{
type = "pwa-node",
name = "Node",
request = "launch",
program = "${file}",
cwd = "${workspaceFolder}",
console = "integratedTerminal",
skipFiles = {
"<node_internals>/",
"${workspaceFolder}/node_modules/"
},
},
}
end
Debug adapter version
vscode-js-debug - latest commit 1e5bf60; nvim-dap - too
Steps to Reproduce
Expected Result
Process terminates successfully during the second await too
Actual Result
Nothing happens when terminating during the second await
The text was updated successfully, but these errors were encountered: