2024 年 3 月 (版本 1.88)
更新 1.88.1:此更新解决了这些问题。
下载:Windows:x64 Arm64 | Mac:通用 Intel Apple 芯片 | Linux:deb rpm tarball Arm snap
欢迎使用 Visual Studio Code 2024 年 3 月版本。此版本中有许多更新,我们希望您会喜欢,其中一些主要亮点包括:
- 为打开的编辑器应用自定义标签 - 区分具有相同文件名的编辑器。
- 锁定滚动 - 通过同步滚动并排比较编辑器。
- 扩展更新改进 - 无需重新加载即可重启扩展,并随 VS Code 版本更新扩展。
- 测试覆盖率 API - VS Code 中原生的代码覆盖率支持。
- 小地图中的折叠标记 - 从小地图轻松识别和导航到代码部分。
- 快速搜索改进 - 粘性文件路径分隔符和分隔符按钮。
- 笔记本在节中运行单元格 - 快速运行笔记本节中的所有单元格。
- Copilot 改进 - 改进的内联聊天 UI、提交消息和使用的引用。
- Python 自动检测改进 - 检测 Flask 和 Django 的启动文件,发现 Hatch 环境。
- 预览:终端内联聊天 - 直接从终端启动 Copilot 内联聊天对话。
如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的更新。Insiders:想尽快尝试新功能吗?您可以下载每晚Insiders版本并尽快尝试最新更新。
辅助功能
语音录制声音
我们为语音录制添加了新的可访问性信号声音
- 语音录制开始 - 使用
accessibility.signals.voiceRecordingStarted
设置进行配置 - 语音录制结束 - 使用
accessibility.signals.voiceRecordingStopped
设置进行配置
改进的差异编辑器可访问性
如果您正在使用屏幕阅读器,当差异编辑器成为活动编辑器时,您现在会收到通知。您可以使用 accessibility.verbosity.diffEditorActive
设置禁用此行为。
我们还在辅助功能帮助对话框中添加了有关差异编辑器:切换侧边(一个对键盘用户有用的命令)的信息。
辅助功能信号现在在差异编辑器的两侧都有效。以前,它们仅在修改侧可用。
可访问视图聊天代码块命令
当您在可访问视图中检查聊天响应时,您现在可以使用聊天视图中可用的代码块命令和键盘绑定。
其中包括聊天:在光标处插入、聊天:插入到终端和聊天:插入到新文件。
笔记本单元格 aria 标签更新
笔记本单元格的 Aria 标签现在会更新,以指示单元格当前是正在执行还是等待执行。
工作台
浮动窗口中的自定义编辑器支持
我们扩展了对在浮动窗口中打开自定义编辑器以及通常所有使用 webview API 的编辑器的支持。这包括 Markdown 预览、浏览器预览以及复杂的自定义编辑器,例如我们的十六进制编辑器。
注意: 由于技术限制,在窗口之间移动基于 webview 的编辑器需要重新加载该编辑器的内容。然后由编辑器恢复您之前累积的状态。在某些情况下,您的状态可能会被重置,就像您第一次打开编辑器一样。
为打开的编辑器自定义标签
我们现在允许您自定义编辑器选项卡和“打开的编辑器”视图的显示标签。此功能对于区分同名文件的编辑器很有用。
您可以通过在 workbench.editor.customLabels.patterns
设置下添加条目来自定义这些标签。每个条目应包括一个与文件路径匹配的全局模式和一个定义编辑器选项卡新名称的模板。此自定义仅在文件路径与指定模式匹配时应用。模式是否匹配取决于它是否定义为相对或绝对文件路径模式。
模板可以包含变量,例如 ${filename}
、${extname}
、${dirname}
和 ${dirname(N)}
,它们将根据文件路径中的值进行动态替换。
要启用或禁用这些自定义标签,请使用 workbench.editor.customLabels.enabled
设置。这使您可以随时切换回原始编辑器名称,而无需删除自定义模式。
锁定滚动
您现在可以使用视图:在编辑器之间切换锁定滚动命令来同步所有可见编辑器之间的滚动。这意味着当您在一个编辑器中滚动时,所有其他编辑器都会以相同的量滚动,保持一切对齐。如果您需要并排比较文件,此功能会很有用。
如果您想更精确地控制启用和禁用锁定滚动,您可以选择仅在按住特定键绑定时激活滚动同步。为 workbench.action.holdLockedScrolling
命令设置一个键盘快捷方式,您就可以在需要时暂时锁定编辑器之间的滚动。
底部活动栏
以前,我们引入了将活动栏移动到侧边栏顶部的选项。我们现在允许您将活动栏移动到底部。为此,请将 workbench.activityBar.location
设置更改为 bottom
。
当活动栏位于顶部时,我们也改进了它的外观和感觉,以确保它与界面的其余部分完美融合。
搜索编辑器单点击行为
您现在可以配置 search.searchEditor.singleClickBehaviour
设置,以确定单点击搜索编辑器条目时发生什么。目前,该设置仅支持打开窥视定义。
快速搜索改进
粘性文件路径
在快速搜索中,我们使文件名分隔符具有粘性,以更清楚地显示搜索结果与哪个文件相关联。当文件中出现大量搜索词时,这会很有用。
文件路径分隔符按钮
当您将鼠标悬停在特定文件的文件结果上,或者向下箭头指向结果时,文件路径分隔符也会出现按钮(例如,打开文件)。
快速选择分隔符导航键绑定
我们收到了反馈,希望能够在快速选择中导航分隔符。在此迭代中,我们添加了一个键绑定来完成此操作。在 Windows 和 Linux 上,您可以使用 Alt+Up/Down
,在 macOS 上是 Cmd+Up/Down
。在此示例视频中,您可以看到活动项在
- 命令面板中的
最近使用
和其他命令
分隔符之间 - 快速搜索中的文件路径分隔符之间
快速选择禁用复选框项
在此迭代中,我们更清楚地显示了快速选择显示禁用项的情况。您可以在“管理受信任扩展”快速选择中找到一个示例,该快速选择可用于您登录的任何帐户。
扩展更新改进
重启扩展
当扩展更新时,您现在可以重启扩展,而无需重新加载窗口。
注意: 当您连接到 WSL、SSH 或开发容器等远程服务器时,您仍然需要重新加载窗口才能更新扩展。
随 VS Code 更新扩展
当您启用 extensions auto update
时,VS Code 现在会更新与更新版本的 VS Code 兼容的扩展。如果较新版本的扩展与当前版本的 VS Code 不兼容,则较新版本的扩展仅在您更新 VS Code 后才会启用。
跳转到评论回复
“评论”视图中评论线程的上下文菜单现在包含“回复”操作,当评论线程允许回复时。这使您可以快速跳转到回复输入框并开始键入回复。
编辑器
小地图章节标题
小地图现在可以识别并渲染由折叠标记(例如 TypeScript 中的 //#region
或使用 MARK:
的注释)定义的章节。这使您可以快速扫描和导航大型文件。
重构预览键绑定
我们更新了重命名符号重构 (F2) 的编辑预览键绑定,以保持与其他上下文中的重构预览(例如代码操作)的一致性。您现在可以使用 ⌘Enter (Windows、Linux Ctrl+Enter) 预览编辑(以前是 Shift + Enter
)。
将鼠标悬停在代码操作上时,⌘Enter (Windows、Linux Ctrl+Enter) 也会在工作台中打开重构预览面板。
差异编辑器暂存/还原选择按钮
差异编辑器现在有一个单独的行号区域用于暂存和还原控件。这些操作使您能够暂存或还原更改的代码块。
如果您对某些更改执行文本选择,这些按钮允许您暂存或还原所选更改(选择中所有更改的字符)。
您可以将 diffEditor.renderGutterMenu
设置为 false
来隐藏差异编辑器行号区域。
重命名建议行为
我们改进了重命名建议的使用流程,使其与快速选择匹配。当您从列表中选择一个重命名建议时,输入值现在会相应地更新,这使您可以进一步修改建议。
源代码管理
传入更改文件装饰
为了帮助避免在合并/rebase 远程更改时可能出现的冲突,我们现在为所有具有传入更改且已获取但尚未合并/rebase 的文件显示文件装饰。要从该功能中受益,您应该同时启用 git.autofetch
和 git.decorations.enabled
设置。
主题:GitHub Sharp(在 vscode.dev 上预览)
终端
调试终端中的 shell 集成
为了向用户和扩展提供增强功能,现在在调试时启动的终端中自动启用shell 集成。
运行最近命令改进
由 shell 集成支持的运行最近命令 (⌃⌥R (Windows, Linux Ctrl+Alt+R)) 现在会尽可能地滚动并显示该命令上次运行的时间。运行该命令或取消快速选择会将终端返回到其先前的状态。
主题:Sapphire (在 vscode.dev 上预览)
打开检测到的链接改进
打开检测到的链接命令 (⇧⌘O (Windows, Linux Ctrl+Shift+O)) 现在会在编辑器中预览链接结果,并在终端中突出显示链接源。
此外,重复链接现在已从列表中过滤掉,并且所有链接都以一致的格式呈现。
单词链接的额外上下文
单词链接由 terminal.integrated.wordSeparators
设置定义,并且在找不到文件/文件夹/URI 时作为备用。激活后,这些链接现在包含额外的周围上下文,以添加搜索的行和列信息。
请注意,在屏幕截图中,选择了链接 terminalLinkParsing
,但结果搜索也包括链接后的行号。
新链接格式
现在可以在终端中检测到以下链接格式,即使路径包含空格也是如此
文件 路径:行:列
终端粘性滚动透明度支持
终端中的粘性滚动现在支持透明度。主题可以通过将 terminalStickyScroll.background
主题颜色配置为透明值,或者在 settings.json
中指定覆盖来使用此功能。例如:
{
"workbench.colorCustomizations": {
"[Default Dark Modern]": {
"terminalStickyScroll.background": "#181818c0"
}
}
}
这会产生透明的粘性滚动背景,让后面的文本透射出来
测试
测试覆盖率
在此迭代中,我们完成了测试覆盖率 API,为 VS Code 带来了原生覆盖率支持。如果您的测试系统支持,您可以使用新的运行覆盖率按钮获取覆盖率
同样,还有新的键绑定用于运行覆盖率,例如 Ctrl+; Ctrl+Shift+A 用于运行所有测试并带覆盖率,以及 Ctrl+; Ctrl+Shift+L 用于运行最后一套测试并带覆盖率。
默认情况下,覆盖率信息显示为行号上的覆盖层,但您可以切换内联覆盖率以查看源文件的完整详细信息
主题:Codesong(在vscode.dev上预览)
使用测试覆盖率需要您的扩展实现新的 API。一些扩展,例如Java 测试运行器和node:test 运行器已经支持它。在团队的12 月和1 月更新中了解有关 Java 测试覆盖率的更多信息。
扩展作者可以在测试 API 文档中找到有关测试覆盖率 API 的更多详细信息。
测试消息中的颜色代码支持
我们现在解析终端颜色代码以对文本测试消息进行着色,例如测试失败时显示的消息,而不是显示原始的“不可打印”数据代码。
语言
TypeScript 5.4
VS Code 现在包含 TypeScript 5.4。此重大更新为类型检查和 IntelliSense 带来了新的改进,并修复了多个错误。有关更多详细信息,请参阅TypeScript 5.4 发布博客文章。
Markdown 中更智能地插入图像和链接
当您将图像或文件拖放或粘贴到 Markdown 文件中时,VS Code 会自动为其插入 Markdown 图像或链接语法。我们现在还会在您插入到代码块和其他不支持 Markdown 语法的上下文中时智能地禁用此行为
您始终可以使用拖放/粘贴小部件切换回插入 Markdown 语法。您可以使用 markdown.editor.drop.enabled
和 markdown.editor.filePaste.enabled
设置来配置此行为。
Notebook
笔记本输出中的键盘快捷键
我们现在支持笔记本输出中的一些标准键盘快捷键
- 输出可以使用键盘分别通过 Ctrl+A 和 Ctrl+C 键绑定进行选择和复制。
- 可滚动输出可以使用键盘分别通过 Up 和 Down 键绑定进行滚动。
- 可滚动输出的顶部和底部滚动可以使用键盘分别通过 Ctrl+Home 和 Ctrl+End 键绑定实现(macOS 上为 Cmd+Up 和 Cmd+Down)。
- 从当前选择点到输出顶部或底部的输出选择可以使用键盘分别通过 Ctrl+Shift+Up 和 Ctrl+Shift+End 键绑定实现(macOS 上为 Shift+Cmd+Up 和 Shift+Cmd+Down)。
单元格错误诊断
扩展现在可以为失败的单元格提供错误详细信息,以便在单元格内显示错误诊断。当焦点位于单元格容器上时,notebook.cell.openFailureActions
(⌘. (Windows、Linux Ctrl+.)) 会跳转到该错误的快速操作菜单。诊断仅在语言模型可用以提供快速操作时显示。
在章节中运行单元格
为了更轻松地在笔记本中运行相关单元格,您现在可以使用在章节中运行单元格操作运行按 Markdown 章节标题分组的单元格。此操作在笔记本大纲视图和粘性滚动元素中可用。
在粘性滚动元素中,右键单击您选择的标题,并通过上下文菜单中的操作运行该章节。在大纲视图中,选择悬停或选择时出现的工具栏图标,然后通过显示的动作运行单个单元格或一组单元格。
大纲视图中的筛选器支持
您现在可以在笔记本大纲视图中使用筛选器,这使您可以控制 Markdown 标题、代码单元格和代码单元格符号的包含。筛选器对应于以下设置
notebook.outline.showMarkdownHeadersOnly
notebook.outline.showCodeCells
notebook.outline.showCodeCellSymbols
关闭时提示保存交互式窗口
通过启用 interactiveWindow.promptToSaveOnClose
设置,当交互式窗口关闭时,系统会提示您保存其中的内容,以确保您不会丢失任何工作。目前唯一支持的文件格式是 .ipynb
。
远程开发
远程开发扩展允许您通过 SSH 或远程隧道使用开发容器、远程机器或适用于 Linux 的 Windows 子系统 (WSL) 作为功能齐全的开发环境。
亮点包括:
- 具有扩展支持的发行版的备用服务器下载
- 基于 URI 查询字符串的端口转发
- Dev Containers 扩展自动启动 Docker
- 通过组策略限制对开发隧道和端口转发的访问
您可以在远程开发发行说明中了解有关这些功能的更多信息。
对扩展的贡献
VS Code Speech
延迟激活
VS Code 语音扩展现在仅在 VS Code 中请求语音转文本服务时激活。这确保了扩展不会对扩展主机启动时间产生负面影响。
使用显示语言作为默认语音语言
默认情况下,VS Code 语音扩展现在使用 VS Code 的显示语言作为语音语言,并在支持该语言的情况下选择相应的模型。
对于 accessibility.voice.speechLanguage
设置,auto
是新的默认值。
GitHub Copilot
内联聊天改进
内联聊天现在以浮动控件的形式启动,使其更加轻量级。首次请求后,控件会展开以占用更多空间。我们还调整了渲染,使其与其他聊天体验(例如聊天视图或快速聊天)更加一致。
主题:GitHub Light Colorblind (Beta)
我们已经重新定位了重跑和反馈控件,并使用于查看差异的切换控件与“接受”和“放弃”按钮一起更突出。
主题:GitHub Light Colorblind (Beta)
笔记本内核状态作为上下文
当您在笔记本中时,内核状态(例如,变量和可用包)现在会自动作为上下文包含在内联聊天中。这使得 Copilot 可以使用笔记本的当前状态来提供更相关的完成。
主题:GitHub Dark
提交消息生成改进
为了提高生成的提交消息的质量,我们现在还将存储库中最近 10 次提交的提交消息以及当前用户最近 10 次提交的提交消息作为额外上下文包含在内。
工作区创建改进
当检测到聊天提示的合适匹配时,@workspace /new
命令现在提供来自 GitHub 存储库的精选示例项目作为建议。
@workspace /new
命令也得到了增强,可以更有效地管理上下文和历史记录。这使您可以通过提出后续查询来优化建议的工作区结构和文件内容。例如,“使用 TypeScript 而不是 JavaScript”或“也添加 bootstrap”。
@terminal /explain 斜杠命令
新的 @terminal /explain
斜杠命令可用,它针对解释命令或错误进行了优化。如果没有 /explain
,@terminal
则针对建议修复进行了优化。此斜杠命令用于使用 Copilot 解释快速修复或解释选择操作。
预览:终端内联聊天
此版本提供了终端内联聊天的预览,它方便地直接在终端中访问 Copilot 的功能。
您可以使用 terminal.integrated.experimentalInlineChat
设置启用终端内联聊天。要在终端中调用内联聊天,请使用 ⌘I (Windows、Linux Ctrl+I) 键绑定。
终端内联聊天使用 @terminal
聊天参与者,它具有集成终端的 shell 及其内容的上下文。
一旦建议了命令,使用 ⌘Enter (Windows、Linux Ctrl+Enter) 在终端中运行命令,或使用 ⌥Enter (Windows、Linux Alt+Enter) 将命令插入终端。命令也可以在 Copilot 的响应中直接编辑,然后才能运行(目前在 Windows 和 Linux 上为 Ctrl+down、Tab、Tab;在 macOS 上为 Cmd+down、Tab、Tab)。
认证流程清晰度
认证的清晰度非常重要。我们希望明确我们如何认证以及我们要求什么。如果您在 VS Code 中打开一个私有仓库,并且我们没有此场景的正确认证,我们将显示一个认证对话框。该对话框包含对需要认证的原因的描述,以及一个了解更多按钮,以了解这些要求的更多信息。
了解更多按钮将您带到我们关于认证要求的文档。
变量引用
聊天响应中的已用引用部分提供了有关所用上下文的信息。以前,此部分仅显示隐式拉入的上下文。现在,它还显示您在聊天提示中明确提及的变量,例如 #file
或 #editor
。如果某个变量在“已用引用”中缺失,则可能表示它因对于语言模型的上下文窗口而言过大而被忽略。
次要聊天提交操作
在聊天视图中,聊天提交按钮现在有一个下拉菜单,可以方便地访问更多操作。
- 发送到 @workspace 将您的查询提交给
@workspace
聊天参与者,这对于有关工作区内容的问题很有用 - 发送到新聊天 启动一个新的空聊天,然后提交查询
使用 Copilot: Explain This
时的范围选择
当您在活动编辑器中未使用选择的情况下使用 /explain
,并且存在多个感兴趣的范围时,我们增加了支持提示以澄清要解释的符号或块范围。
此行为目前是可选的,由 github.copilot.chat.scopeSelection
设置控制。
Python
Flask 和 Django 调试配置选择改进
为 Flask 和 Django 应用程序创建启动配置变得更加容易!在为您的 Web 应用程序创建 launch.json
时,已改进了检测工作区中可能的启动文件。
对于 Django,Python 调试器扩展会在工作区的根目录或下一级子目录中查找 manage.py
或 app.py
文件。对于 Flask,该扩展会查找包含 Flask 应用程序声明的 wsgi.py
、app.py
或 init.py
文件(例如,app = Flask()
)。
如果这些文件在项目中未找到,下拉列表会显示相应项目类型的默认选项,即使该文件可能不存在。
Hatch 环境发现
Hatch 环境现在默认被发现和激活,类似于其他常见的环境,例如 Venv、Conda 和 Poetry。此外,在 Hatch 的情况下,如果没有注册明确的环境标识符,扩展能够从环境定位器确定环境类型 (Hatch)。
pipenv、pyenv 和 Poetry 项目的自动环境选择
如果您的工作区包含 pipenv、pyenv 或 Poetry 环境,则现在会自动为您的工作区选择相应的环境。以前,扩展可以正确发现这些环境,但选择了默认的全局解释器,这需要您手动为工作区选择适当的环境。
现在,Python 扩展会根据环境的存在和任何相应的配置文件推断激活的环境。例如,在 pyenv 的情况下,扩展会查看 .python-version
文件以自动为工作区选择适当的解释器。
报告问题命令改进
Python 和 Python 调试器扩展现在使您更容易向我们的仓库报告问题!如果您使用报告问题命令 (workbench.action.openIssueReporter
) 提交问题,大部分繁重的工作已经完成,您只需提供一些额外的信息,以便我们的团队能够高效地分类您遇到的问题。
要使用帮助:报告问题命令为 @vscode-python 或 @vscode-python-debugger 提交问题,请分别从扩展下拉列表中选择Python或Python 调试器。
GitHub 拉取请求
GitHub Pull Requests 扩展取得了更多进展,该扩展使您能够处理、创建和管理拉取请求和问题。新功能包括:
- 过时的评论在“评论”视图中以不同于当前评论的方式显示。
githubPullRequests.createDefaultBaseBranch
的新auto
值使用上游的默认分支作为 fork 仓库的基础分支。- “评论”视图中的评论线程具有内联操作(解决/取消解决和过时评论的“与 HEAD 比较评论”)和上下文菜单操作。
查看扩展 0.86.0 版本的更新日志以了解其他亮点。
Jupyter
单元格执行分析改进
通过最新的 Pylance 预发布版本,我们对 Jupyter 单元格的依赖分析有了更好的理解。它现在理解模块导入,当您有一个导入前一个单元格中定义的模块的单元格时,这尤其有用。
要启用此功能,请在 VS Code Insiders 中安装最新的Pylance 预发布版本,并启用 jupyter.executionAnalysis.enabled
和 notebook.consolidatedRunButton
设置。
扩展创作
使用“报告问题”命令报告扩展错误
上一次迭代,我们最终确定了一种让扩展在通过 VS Code 的问题报告器提交到 GitHub 时贡献额外数据或模板的方法。扩展可以贡献一个命令,可以通过帮助:报告问题...命令访问。选择他们的扩展会运行他们贡献的命令。请查阅我们的问题报告文档/发行说明,以了解此功能如何与您的扩展配合使用!
此外,所有已安装的扩展都可以通过快速打开快速报告。通过在快速打开 (⌘P (Windows、Linux Ctrl+P)) 中键入 issue
,您可以快速选择或搜索已安装的扩展进行报告。
某些扩展将开始采用这种新的问题报告流程,并且不再需要直接贡献到命令面板的自定义 报告问题...
命令。
预览功能
终端中重叠字形的重缩放
提供了一个新设置 terminal.integrated.rescaleOverlappingGlyphs
,它会重新缩放与后续单元格重叠的字形。这旨在解决模糊宽度字符,这些字符的字体字形可能与后端 pty/Unicode 版本认为的不同。例如,在大多数字体中,罗马数字 Unicode 字符 (U+2160+
) 通常占用多个单元格,因此当启用此设置时,它们会水平重新缩放。
未重缩放
已重缩放
重缩放的规则仍在调整中,我们正在考虑在未来稳定后默认启用此功能。如果您尝试此功能并看到字符被重缩放但不应该被重缩放,请创建问题。
本地工作区扩展
我们很高兴推出这项新的预览功能,它允许您直接在工作区中打包扩展。此功能旨在满足您的特定工作区需求,并提供更量身定制的开发体验。
要使用此功能,您需要将扩展打包到工作区中的 .vscode/extensions
文件夹中。VS Code 然后会在“扩展”视图的工作区建议部分显示此扩展,用户可以在其中安装它。VS Code 仅为该工作区安装此扩展。它还要求用户在安装和运行此扩展之前信任该工作区。
例如,考虑 VS Code 存储库中的 vscode-selfhost-test-provider
扩展。此扩展插入测试功能,使贡献者可以直接在工作区中查看和运行测试。以下屏幕截图显示了“扩展”视图的“工作区建议”部分中的 vscode-selfhost-test-provider
扩展以及安装它的功能。
此功能可在 Insiders 版本中通过 extensions.experimental.supportWorkspaceExtensions
进行预览。请尝试一下,并通过在 VS Code 存储库中创建问题来告诉我们您的反馈。
提议的 API
终端 shell 集成 API
现在提供了一个新的提议 API,该 API 允许访问 shell 集成激活的终端提供的一些信息。使用此 API,可以侦听在终端中执行的命令的传入数据和退出代码。它还引入了一种更可靠的方式来执行命令,该命令会等待提示可用,然后才发送命令,这有助于修复各种 shell 设置可能发生的一些冲突/竞争条件。
以下是使用 Terminal.shellIntegration.executeCommand
提案的示例
// Execute a command in a terminal immediately after being created
const myTerm = window.createTerminal();
window.onDidActivateTerminalShellIntegration(async ({ terminal, shellIntegration }) => {
if (terminal === myTerm) {
const command = shellIntegration.executeCommand('echo "Hello world"');
const code = await command.exitCode;
console.log(`Command exited with code ${code}`);
}
}));
// Fallback to sendText if there is no shell integration within 3 seconds of launching
setTimeout(() => {
if (!myTerm.shellIntegration) {
myTerm.sendText('echo "Hello world"');
// Without shell integration, we can't know when the command has finished or what the
// exit code was.
}
}, 3000);
以下是侦听命令数据流的示例
// Create a terminal and log all data via console.log
const myTerm = window.createTerminal();
window.onDidStartTerminalShellExecution(execution => {
if (execution.terminal === myTerm) {
const stream = execution.createDataStream();
for await (const data of stream) {
console.log(data);
}
}
});
您可以在此处查看新的 API。
认证 API 的“了解更多”属性
本次迭代中,我们添加了一个新的提案 API,允许您在 AuthenticationForceNewSessionOptions
中指定 learnMore
属性。其思想是,如果您使用选项中的 forceNewSession
属性调用 getSession
,则可以包含一个 URI
,该 URI 将呈现给用户,以了解您要求认证的原因。以下是它的外观示例
这是代码中的样子
vscode.authentication.getSession('github', ['repo'], {
forceNewSession: {
detail: l10n.t('To show you more relevant Copilot Chat results, we need permission to read the contents of your repository on GitHub.'),
learnMore: Uri.parse('https://aka.ms/copilotRepoScope')
};
});
您可以在此处查看新的 API。
过时的评论
新的评论线程 applicability
属性允许在“评论”视图中将评论线程标记为过时
您可以在此处查看 API 提案。
评论视图菜单
commentsView/commentThread/context
提案菜单允许将操作添加到“评论”视图中评论线程的右键上下文菜单。通常的 inline
组也受到尊重,以便操作在“评论”视图中内联显示。
工程
Electron 28 更新
在此迭代中,我们将 Electron 28 更新推广到稳定版的用户。此更新附带 Chromium 120.0.6099.291 和 Node.js 18.18.2。我们要感谢所有在 Insiders 版本上自托管并提供早期反馈的人。
值得注意的修复
- 204886 在简单文件选择器中打开不同路径但同名文件失败
感谢
最后但同样重要的是,向 VS Code 的贡献者们致以衷心的感谢。
问题跟踪
对我们问题跟踪的贡献
- @gjsjohnmurray (John Murray)
- @IllusionMH (Andrii Dieiev)
- @RedCMD (RedCMD)
- @starball5 (starball)
- @the-coder-o (Abdul basit)
- @ArturoDent (ArturoDent)
拉取请求
对 vscode
的贡献
- @333fred (Fred Silberberg):当作为字符串或正则表达式的一部分时,不要修剪空白 PR #198164
- @89netraM (Mårten Åsberg):为间隔设置渲染最终行号 PR #207227
- @a-stewart (Anthony Stewart)
- 在 QuickAccess 中更改前缀时阻止光标跳跃 - v2 PR #204702
- 在 nls.mock.ts 中导出 ILocalizedString PR #206449
- @akbyrd (Adam Byrd)
- 存在多个光标时,为主光标和次光标实现不同的颜色 PR #181991
- 将 editor.action.focusNextCursor 更改为显示主光标而不是所有光标 PR #182148
- @AndreasBackx (Andreas Backx):修复 Linux Wayland 平滑滚动。 PR #205122
- @andrewbranch (Andrew Branch):[typescript-language-features] 修复 autoImportFileExcludePatterns 格式使其在 Windows 上工作 PR #202762
- @andyscho (Andy Schoenberger):onDidChangeSelectedNotebooks 内核只有一个订阅者 PR #204417
- @BABA983 (BABA):更好的测试侧边栏重试颜色 PR #207949
- @BrandonXLF (Brandon Fowler):覆盖终端选项卡图像图标的 CSS 内容 PR #207220
- @BrookMaoDev (Brook Mao):改进了 editor.useTabStops 设置的描述 PR #206552
- @btwiuse:cli:向
code serve-web
命令添加 --server-base-path 标志 PR #207932 - @BusinessDuck (Dmitriy Yurov):修复浏览器自动填充表单事件的“e.getModifierState is not a function”错误 PR #206883
- @cchanche (Clément Chanchevrier):调整终端方向 PR #205015
- @CGNonofr (Loïc Mangeonjean)
- 修复键盘布局检测 PR #205193
- 修复不在 body 上时全屏容器尺寸检测 PR #205884
- @cpendery (Chapman Pendery)
- 修复:终端建议按模糊分数排序 PR #208486
- 修复:当键绑定发送到 shell 时不显示终端建议 PR #208523
- 修复:建议小部件在完成接受后仍然存在 PR #208524
- @deyihu (hu de yi):编辑器粘贴事件结果返回 ClipboardEvent PR #192732
- @dgileadi (David Gileadi):引入迷你地图章节标题,类似于 Xcode PR #190759
- @futurist (James Yang):特性:为 IPCServer 添加 ipcLogger 和 timeoutDelay PR #193896
- @gjsjohnmurray (John Murray):使通道日志级别可在输出视图中设置 PR #205159
- @harbin1053020115 (ermin.zem):修复:如果不存在内置演练,则在首次启动时选择第一个扩展演练。 PR #207303
- @hickford (M Hickford):排序行:如果未选择任何内容,则排序所有行。 PR #200325
- @hsfzxjy (谢景怡)
- 修复设置编辑器列表项溢出 PR #206681
- 在单击行号区域时添加日志点 PR #206684
- @IncognitaDev (Luis Sousa):特性:将 PascalCase 添加到 CaseActions PR #206259
- @its-miroma (Miroma):更改默认 YAML 扩展 PR #206447
- @jeanp413 (Jean Pierre):修复面包屑小部件未正确调整大小 PR #200591
- @jeremy-rifkin (Jeremy Rifkin):扩展君主功能以允许在规则中访问状态 PR #183463
- @jhasse (Jan Niklas Hasse):为 LineCommentCommand 使用 indentSize 而不是 tabSize PR #193811
- @Krzysztof-Cieslak (Krzysztof Cieślak)
- 修复内联编辑中渲染删除的差一错误 PR #205890
- 内联编辑 - 确保在失焦时取消正在进行的请求 PR #206430
- 内联编辑 - 确保在请求新编辑之前最终接受 PR #206525
- @lusingander (Kyosuke Fujimoto):修复
editor.cursorSurroundingLinesStyle
设置的描述损坏 PR #201482 - @mahmoudsalah1993 (Mahmoud Salah):对于 diff 编辑器,解决修改后的编辑器以允许在 c 中运行测试… PR #206026
- @marrej (Marcus Revaj):# 将部分接受类型添加到内联完成处理程序 PR #202668
- @mkasenberg:searchEditor:添加单击以窥视的选项 PR #204413
- @mroch (Marshall Roch):修复“Extension [object Object] is not known” PR #207764
- @NriotHrreion (NoahHrreion):修复悬停小部件的意外位置 PR #205502
- @orgads (Orgad Shaneh)
- 隧道:也将端口映射查找扩展到查询字符串(第二次尝试) PR #204807
- 隧道:重新添加端口映射的单元测试 PR #207249
- @PmcFizz (Fizz):更新 IActionDescriptor.precondition 描述 PR #176124
- @raphaelgpalma (Raphael Palma):修复语法错误:“But allow them if the are made from inside an…” PR #207584
- @rehmsen (Ole):也为浏览器上的并排视图记录
resource
遥测。 PR #208196 - @russelldavis (Russell Davis):修复 javascript 和 typescript 的 decreaseIndentPattern PR #201425
- @samdenty (Sam Denty):特性(web/lifecycleService):正确的 startupKind PR #206563
- @Sidebail (VLADIMIR VATSURIN):修复文件相对路径链接 PR #181475
- @SimonSiefke (Simon Siefke):修复:笔记本 baseCellViewModel 中的内存泄漏 PR #205499
- @solimant:遵守 GitHub 品牌名称大小写 PR #208503
- @thegecko (Rob Moran):Web 扩展主机启动时更新 extensionPaths PR #193849
- @vinistock (Vinicius Stock):修复 Ruby 注释中
in
和when
缩进意外取消缩进的错误 PR #206132 - @yamachu (Yusuke Yamada):修复在搜索结果中显示最深目录中的文件 PR #206609
- @Yesterday17 (Yesterday17):按节点深度顺序调度 GestureEvent PR #200612
- @yiliang114 (易良):修复 webview 中复制/剪切命令不起作用的问题 PR #206529
- @yutotnh (yutotnh):在单词操作中添加对识别单词区域设置的支持 (#_50045) PR #203605
对 vscode-css-languageservice
的贡献
- @balaji-sivasakthi (Balaji Sivasakthi):特性:支持 scss 的悬停工具提示 PR #367
对 vscode-eslint
的贡献
- @JoshuaKGoldberg (Josh Goldberg ✨):特性:在 eslint.probe 设置中支持 json, json5, jsonc PR #1787
- @remcohaszing (Remco Haszing)
对 vscode-extension-samples
的贡献
- @juliankasimir (Julian Kasimir):特性(lang):在 showQuickPick 函数中将德语替换为英语 PR #983
对 vscode-hexeditor
的贡献
对 vscode-js-debug
的贡献
- @Beanyy:修复当未设置描述时远程对象中数字 0 的格式 PR #1968
- @mdh1418 (Mitchell Hwang):[CDP] 为 DotnetDebugger 错误事件发送遥测数据 PR #1961
- @relief-melone (Relief.Melone):为构建添加代理支持 PR #1965
对 vscode-json-languageservice
的贡献
- @denisw (Denis Washington):修复嵌套尾随逗号情况下的排序错误 PR #223
对 vscode-pull-request-github
的贡献
- @ipcjs (ipcjs):修复:使
review.openLocalFile
支持从键盘触发。 PR #5840 - @mohamedamara1 (Mohamed Amara):修复 IssueOverviewPanel 的 ID PR #5822
对 vscode-pylint
的贡献
- @MGasiewski:添加逻辑以将波浪号替换为 HOME 环境 PR #524
对 vscode-python-debugger
的贡献
- @bersbersbers:更新
launch.json
架构 PR #243 - @StephanTLavavej (Stephan T. Lavavej):修复拼写错误 PR #217
对 debug-adapter-protocol
的贡献
- @andyw8 (Andy Waite):更新 Ruby LSP 的适配器列表 PR #471
- @svaante (Daniel Pettersson):将 Emacs dape 包添加到 Implementations 工具部分 PR #469
对 inno-updater
的贡献
- @ChayimFriedman2 (Chayim Refael Friedman):删除不需要的
unsafe impl Send
PR #25
对 language-server-protocol
的贡献
- @asukaminato0721 (Asuka Minato)
- @iliaamiri (Ilia Abedianamiri):摘要段落中的一个小错字 PR #1903
- @lukaskesch (Lukas Kesch):更新 footer.html 中的版权年份至 2024 PR #1909
- @MariaSolOs (Maria José Solano):诊断消息中 MarkupContent 支持的规范 PR #1905
- @oliviacrain (Olivia Crain):删除 rnix-lsp 的服务器条目 PR #1902
对 monaco-editor
的贡献
- @jeremy-rifkin (Jeremy Rifkin):修复 C++ 原始字符串文字高亮显示错误 PR #4436
对 node-pty
的贡献