0

0

VSCode调试器扩展_自定义调试适配器实现

betcha

betcha

发布时间:2025-11-22 15:52:03

|

504人浏览过

|

来源于php中文网

原创

首先实现自定义调试适配器,它作为VSCode前端与目标语言调试后端的桥梁,基于Debug Adapter Protocol(DAP)处理初始化、断点设置和程序控制;通过yo code生成调试扩展模板,配置package.json中的debuggers贡献点,指定调试类型和适配器启动方式;在debugAdapter.ts中继承LoggingDebugSession类,重写initializeRequest、launchRequest和setBreakPointsRequest等方法,响应DAP请求并发送事件;适配器可内联运行或作为独立进程启动,推荐使用vscode-debugadapter库简化JSON-RPC通信;最后在launch.json中配置对应调试类型,启用trace日志进行测试验证。

vscode调试器扩展_自定义调试适配器实现

要在 VSCode 中实现自定义调试器扩展,核心是开发一个“自定义调试适配器”(Debug Adapter),它作为 VSCode 调试前端与目标调试后端之间的桥梁。VSCode 本身不直接理解如何调试某种语言或运行时,而是通过调试协议(Debug Protocol)与调试适配器通信,由适配器负责与实际的调试引擎交互。

1. 理解 VSCode 调试架构

VSCode 的调试功能基于三层结构:

  • 前端(UI):VSCode 编辑器中的断点、变量查看、调用栈等界面元素。
  • 调试协议(Debug Protocol):基于 JSON-RPC 的通信协议,前后端通过 stdin/stdout 交换请求和响应。
  • 调试适配器(Debug Adapter):独立进程,解释调试请求,并与具体语言的调试工具(如解释器、虚拟机)交互。

你的任务就是实现这个调试适配器,使其能响应 VSCode 发来的初始化、设置断点、继续运行等指令。

2. 创建调试扩展的基本结构

使用 yo code 脚手架生成调试扩展模板:

yo code

选择“New Code Extension” → “Debug Adapter” 类型。这会生成包含以下关键部分的项目:

  • package.json:声明调试贡献点,如调试类型、启动方式、适配器可执行文件位置。
  • src/extension.ts:VSCode 插件主入口,启动调试适配器并管理会话。
  • src/debugAdapter.ts:调试适配器逻辑,处理来自 VSCode 的请求。
  • out/**:编译后的代码。

package.json 中,关键字段如下:

"contributes": { "debuggers": [{ "type": "mylang", "label": "My Language Debugger", "languages": ["mylang"], "configurationAttributes": { ... }, "initialConfigurations": [ ... ], "adapterExecutableCommand": "mylangDebugAdapter" }] }

其中 type: "mylang" 是你在 launch.json 中使用的调试类型。

3. 实现调试适配器

调试适配器需遵循 Debug Adapter Protocol (DAP)。你可以手动解析 JSON-RPC 消息,但推荐使用官方提供的 vscode-debugadapter 库。

安装依赖:

伴江行购物商城系统
伴江行购物商城系统

傻瓜式的程序安装和调试,用户无需考虑系统的安装维护,美观、友好的展示铺面,设计中应用了多种网络安全技术,顾客可以方便的查询并订购商品,用户可以方便的定义各种商品信息,系统选用强大的数据库保存各类信息,系统支持多种浏览器,功能模块清晰实用强大,系统有着良好的扩充性和升级性,强大的在线支付系统和订单系统登陆地址/admin/login.asp后台登陆账号:admin密码:admin

下载
npm install --save vscode-debugadapter

debugAdapter.ts 中,继承 LoggingDebugSession

import { LoggingDebugSession } from 'vscode-debugadapter'; import { DebugProtocol } from 'vscode-debugprotocol'; class MyDebugAdapter extends LoggingDebugSession { protected initializeRequest( response: DebugProtocol.InitializeResponse, args: DebugProtocol.InitializeRequestArguments ): void { response.body = response.body || {}; response.body.supportsConfigurationDoneRequest = true; this.sendResponse(response); } protected launchRequest( response: DebugProtocol.LaunchResponse, args: ILaunchRequestArguments ): void { // 启动目标程序,建立通信 this.sendResponse(response); // 示例:发送“调试已启动”事件 this.sendEvent(new InitializedEvent()); } protected setBreakPointsRequest( response: DebugProtocol.SetBreakpointsResponse, args: DebugProtocol.SetBreakpointsArguments ): void { // 解析源文件,设置断点,返回实际命中位置 const breakpoints = args.breakpoints.map(src => ({ verified: true, line: src.line })); response.body = { breakpoints }; this.sendResponse(response); } } // 启动适配器 DebugSession.start(MyDebugAdapter);

你需要根据你的语言运行时实现诸如解析脚本、注入断点、单步控制、变量求值等逻辑。

4. 启动方式:内联 vs 外部进程

调试适配器可以以内联方式(TypeScript 直接运行)或独立进程(Node.js 脚本、其他语言编译程序)运行。

  • 内联模式:适合简单场景,在 extension.ts 中直接创建适配器实例并通过管道连接。
  • 外部进程:更常见,适配器作为一个独立 Node.js 程序(如 debugAdapter.js),通过 debugServeradapterExecutableCommand 启动。

例如,在 extension.ts 中指定适配器路径:

const server = require.run([__dirname, "debugAdapter.js"]); const session = new DebugAdapterServer(server);

5. 测试与调试

按 F5 启动扩展开发主机,在子 VSCode 实例中创建 .vscode/launch.json,使用你定义的调试类型:

{ "type": "mylang", "request": "launch", "name": "Launch My Program", "program": "${workspaceFolder}/test.mylang" }

设置断点,启动调试,观察适配器输出和通信日志。启用 trace 可输出详细 DAP 消息:

"trace": true

基本上就这些。实现一个完整调试器需要处理变量作用域、调用栈、异常中断、表达式求值等,但起点就是让适配器正确响应初始化和断点请求。一旦通信建立,逐步扩展功能即可。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

465

2023.11.27

session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

307

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

732

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号