VS Code: How to access debug variables from within extension?

怎甘沉沦 提交于 2019-12-09 14:09:15

问题


I am writing an extension for visual studio code where I want to evaluate the current variables of a javascript debug session. These variables are normally shown when one have open the debug pane under the section VARIABLES. See the attached screenshot.

I want to get access to these variables when the user right clicks the editor, but I don't know how.

My current extension setting for this is like that: in the package.json I have registered a menu contribution along with a command:

"contributes": {
    "menus": {
        "editor/context": [{
            "command": "extension.showVariables",
            "group": "navigation"
        }]
    }
}

In my extension.ts I register the command like that:

export function activate(context: vscode.ExtensionContext) {

    let disposable = vscode.commands.registerCommand('extension.showVariables', () => {

        // TODO: let variables = vscode.debug.activeDebugSession.variables.toString();

        vscode.window.showInformationMessage(variables);
    });
}

I have tried to get them through vscode.debug.activeDebugSession but there is no API for variables here. I also tried to register an event handler for vscode.debug.onDidReceiveDebugSessionCustomEvent but I can't figure out where to search for the debug variables.

Is it even possible to access these variables in an vs extension or do I need to implement my own debugger?


回答1:


I have managed to get access to the local variables although this is not a general solution - it may only work in a single threaded debugger. If you know any better way, please answer or comment.

Say, the debugger breaks in a method that has a local variable car.

To get the value of car, I am using the customRequest method on the active debug session:

const session = vscode.debug.activeDebugSession;
const response = await session.customRequest('evaluate', { expression: 'car', frameId: frameId });
const car = response.result;

To get the frameId, I use another call of customRequest:

const session = vscode.debug.activeDebugSession;
const response = await session.customRequest('stackTrace', { threadId: 1 })
const frameId = response.stackFrames[0].id;

To get a real car object (not a string representation) in my extension, I pass "JSON.stringify(car)" as expression in the evaluate customRequest. Then, I can use JSON.parse(response.result).

To get all scopes, stacks and variables, have a look at the Debug Session API and the specification of the DebugProtocol.



来源:https://stackoverflow.com/questions/50287482/vs-code-how-to-access-debug-variables-from-within-extension

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!