2024 年 10 月 (版本 1.95)
安全更新:以下扩展具有安全更新:ms-python.python 和 ms-vscode-remote.remote-ssh。
更新 1.95.1:此更新解决了这些问题。
更新 1.95.2:此更新解决了这些问题。
更新 1.95.3:此更新解决了这些问题。
下载:Windows:x64 Arm64 | Mac:通用 Intel Apple 芯片 | Linux:deb rpm tarball Arm snap
欢迎来到 Visual Studio Code 2024 年 10 月更新。此版本中有许多更新,我们希望您会喜欢,其中一些主要亮点包括
- Copilot 编辑 - 快速迭代对多个文件的重大更改
- Copilot Chat 在辅助侧边栏中 - 让 Copilot Chat 保持开启并随时可用,同时您工作
- 多个 GitHub 帐户 - 同时在 VS Code 中登录多个 GitHub 帐户
- Copilot 代码审查 - 快速审查或更深入地审查未提交的更改
- 使用 Pylance 生成 Docstrings - 为类或方法生成 Docstring 模板
- 预览设置指示器 - 在设置编辑器中查看实验性和预览设置
- Copilot 可扩展性 - 展示 VS Code 中的 Copilot 可扩展性
如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的更新页面。Insiders 版本:想尽快试用新功能?您可以下载每晚的 Insiders 构建版本,并在最新更新可用时立即试用。
GitHub Copilot
Copilot 功能可能会经历不同的抢先体验阶段,这些阶段通常通过设置启用和配置。
-
实验性功能 - 查看实验性功能 (
@tag:experimental
)此设置控制一项正在积极开发中的新功能,该功能可能不稳定。它可能会发生变化或被移除。
-
预览功能 - 查看预览功能 (
@tag:preview
)此设置控制一项仍在完善但已可使用的新功能。欢迎提供反馈。
使用 Copilot Edits 开始代码编辑会话
Copilot Edits 当前处于预览阶段
设置:github.copilot.chat.edits.enabled
通过 Copilot Edits,您可以开始一个 AI 驱动的代码编辑会话,在该会话中可以快速迭代代码更改。根据您的提示,Copilot Edits 会在工作区的多个文件中提议代码更改。这些编辑直接应用于编辑器中,因此您可以在上下文中快速就地审查它们,并查看完整的周围代码。
Copilot Edits 非常适合迭代多个文件的重大更改。它将 Copilot Chat 的对话流程和 Inline Chat 的快速反馈结合在一个体验中。您可以在旁边进行持续的多轮聊天对话,同时受益于内联代码建议。
只需三个步骤即可开始使用 Copilot Edits
-
从聊天菜单中选择打开 Copilot Edits 或按下 来开始编辑会话。
-
将相关文件添加到工作集中,以指示 Copilot 您想要处理哪些文件。
-
输入提示,告诉 Copilot 您想要进行的编辑!例如,
Add a simple navigation bar to all pages
或Use vitest instead of jest
。
在我们的文档中获取有关 Copilot Edits 的更多详细信息。立即试用并通过我们的问题跟踪器提供您的反馈!
在辅助侧边栏中使用聊天
聊天视图新的默认位置是辅助侧边栏。通过使用辅助侧边栏,您可以随时打开聊天,同时仍然可以使用文件资源管理器或源代码管理等其他视图。这为您在 VS Code 中提供了更集成的 AI 体验。您可以使用 ⌃⌘I (Windows、Linux Ctrl+Alt+I) 键盘快捷方式快速打开聊天。
随着 Command Center 旁边新聊天菜单的引入,只需点击一下即可打开包含聊天的辅助侧边栏
聊天菜单让您可以访问 Copilot Chat 的最常见任务。如果您希望隐藏此菜单,提供了一个新设置 chat.commandCenter.enabled。
注意:如果您之前安装过 GitHub Copilot,在您之前使用聊天的地方会显示一个视图,使您能够将聊天视图恢复到旧位置,如果这更适合您的话。
Copilot 代码审查
Copilot 代码审查当前处于预览阶段
借助 Visual Studio Code 中的 GitHub Copilot 代码审查,您现在可以在编写代码时获得快速、AI 驱动的代码反馈,或者在推送之前请求对所有更改进行审查。Visual Studio Code 中的 GitHub Copilot 代码审查当前处于预览阶段。立即试用并通过我们的问题跟踪器提供反馈。
在 VS Code 中使用 Copilot 代码审查有两种方法
-
审查选定内容:进行快速审查,在编辑器中选择代码,然后从编辑器上下文菜单中选择 Copilot > 审查并评论,或使用 Command Palette 中的GitHub Copilot: Review and Comment 命令。(此功能处于预览阶段。)
-
审查更改:对所有未提交的更改进行更深入的审查,在源代码管理视图中选择Copilot 代码审查按钮,您也可以在 GitHub.com 上的拉取请求中执行此操作。(加入等候列表,对所有 Copilot 订阅者开放)
Copilot 的反馈以注释形式显示在编辑器中,附加到您的代码行上。如果可能,注释中包含可操作的代码建议,您可以通过一次操作应用这些建议。
要了解有关 Copilot 代码审查的更多信息,请访问GitHub 代码审查文档。
Copilot 对选定代码的快速审查可以提供与您的团队或项目特定实践相匹配的反馈,前提是您提供了正确的上下文。使用自定义审查指令审查选定内容时,您可以通过 github.copilot.chat.reviewSelection.instructions 设置定义这些特定要求。类似于代码生成和测试生成指令,您可以直接在设置中定义指令,也可以将它们存储在单独的文件中并在设置中引用该文件。
以下代码片段显示了审查指令的示例
"github.copilot.chat.reviewSelection.instructions": [
{
"text": "Logging should be done with the Log4j ."
},
{
"text": "Always use the Polly library for fault-handling."
},
{
"file": "code-style.md" // import instructions from file `code-style.md`
}
],
code-style.md
文件的内容示例
Private fields should start with an underscore.
A file can only contain one class declaration.
自动检测聊天参与者
设置:chat.experimental.detectParticipant.enabled
GitHub Copilot 有几个内置的聊天参与者,例如 @workspace
,并且您可能还安装了贡献聊天参与者的其他扩展。
为了更容易地使用自然语言与聊天参与者交互,Copilot Chat 会在可能的情况下自动将您的问题路由到合适的参与者或聊天命令。
如果自动选择的参与者不适合您的问题,您仍然可以在聊天回复顶部选择不带此重新运行链接,将您的问题重新发送给 Copilot。
本月,我们还添加了一个操作,允许您按请求跳过此检测行为。输入聊天提示时的默认操作是发送并分派,其中包括参与者检测。如果您选择发送,请求将直接发送到 Copilot Chat,而不会自动分派给聊天参与者。
您还可以通过 chat.experimental.detectParticipant.enabled 设置完全禁用自动参与者检测。
控制当前编辑器上下文
Copilot Chat 始终会自动将您当前的选定内容或当前可见代码作为上下文包含在您的聊天请求中。大型语言模型 (LLM) 通常擅长理解上下文是否相关。但有时,当您提出与当前编辑器无关的问题时,包含此上下文可能会影响模型如何解释您的问题。
我们现在在聊天输入框中显示一个特殊的附件控件,它提供有关编辑器上下文的提示,并允许您切换是否包含编辑器上下文。
编辑器上下文的行为没有变化。当活动编辑器中有选定内容时,仅包含选定内容。否则,仅包含滚动到视图中的代码。您仍然可以使用回形针按钮或在聊天提示中键入 #
来附加其他文件或整个文件。
交互式工作区符号链接
Copilot Chat 的常见用例是询问有关工作区代码的问题,例如使用 /tests
为选定的代码生成新的单元测试,或者使用 @workspace
在您的项目中查找特定的类或函数。在此里程碑中,我们为 Copilot 在聊天回复中提及的任何工作区符号添加了增强的链接。这些符号链接可以帮助您更好地理解 Copilot 的回复,并了解其中使用的符号。
符号链接在回复中以小药丸的形式呈现,就像我们在上一个里程碑中添加的文件链接一样。要开始了解更多关于符号的信息,只需选择符号链接即可跳转到该符号的定义处
您也可以将鼠标悬停在符号链接上,查看该符号在哪个文件中定义
要开始更详细地探索符号,只需右键点击符号链接即可调出上下文菜单,其中包含诸如转到实现和转到引用之类的选项
基本符号链接应适用于支持“转到定义”的任何语言。更高级的 IntelliSense 选项(例如“转到实现”)也需要该语言的支持。请务必安装语言扩展,以便为 Copilot 回复中使用的任何编程语言获得最佳的符号支持。
在问题悬停提示中使用 Copilot 修复操作
当您将鼠标悬停在编辑器中的问题上时,现在会包含一个使用 Copilot 修复问题的操作。此操作适用于有可用修复的问题,且该修复由 Copilot 生成。
工作区索引
@workspace
允许您询问有关当前项目代码的问题。这可以通过GitHub 的代码搜索或 VS Code 构建的智能本地索引来实现。在此里程碑中,我们添加了更多 UI 元素,让您了解此工作区索引的使用方式。
首先,新的GitHub Copilot: Build Local Workspace index 命令允许您显式开始索引当前工作区。此索引通常在您首次提出 @workspace
问题时自动启动。使用新命令,您可以随时开始索引。该命令还支持对更大的工作区进行索引,目前最多支持 2000 个文件(不包括被忽略的文件,例如 node_modules
或 out
目录)。
在索引构建过程中,我们现在还在状态栏中显示一个进度项
索引包含数百个文件的工作区可能需要一些时间。如果在索引构建过程中尝试提出 @workspace
问题,Copilot 会尝试通过使用可以更快构建的更简单的本地索引来快速响应,而不是等待。发生这种情况时,我们现在会在回复中显示警告
请注意,在这种情况下,即使 Copilot 使用了更简单的本地索引而不是更高级的索引,它仍然能够回答问题。情况通常如此,尽管更模糊或复杂的问题可能只有在构建了更智能的索引后才能回答。另请记住,如果您的工作区由 GitHub 仓库支持,我们可以使用GitHub 的代码搜索来回答问题。这意味着将使用代码搜索,而不是更简单的本地索引。
聊天后续改进
设置:github.copilot.chat.followUps
为了在聊天视图中为聊天对话腾出更多空间,我们使后续提示更加简洁,并且默认情况下它们仅在第一轮出现。配置 github.copilot.chat.followUps 设置来更改后续提示何时出现
firstOnly
(默认)- 后续提示仅在第一轮出现always
- 后续提示始终出现never
- 禁用后续提示
在语义搜索中按相关性排序(实验性)
设置:github.copilot.chat.search.semanticTextResults
在上一个里程碑中,我们引入了使用 Copilot 执行语义搜索以获取与您的查询在语义上相关的搜索结果的能力。我们现在通过按相关性对搜索结果进行排序来改进了搜索结果。来自更相关片段的关键词匹配被认为整体上更具相关性。
工作台
多个 GitHub 帐户
将上个月的功能升级为默认行为,现在可以在 VS Code 中同时登录多个 GitHub 帐户了。
以下是您可能需要多个帐户的几个场景
- 使用帐户 1 进行设置同步,使用帐户 2 用于 GitHub 拉取请求扩展
- 使用帐户 1 用于 GitHub 扩展(推送),使用帐户 2 用于 GitHub Copilot
要使用此功能,只需触发登录操作(使用内置功能如设置同步或使用扩展),您就会获得登录不同帐户的选项。如果之后需要更改选定的帐户,此功能与帐户首选项快速选择也配合得很好。
虽然大多数功能应继续与您现有的扩展协同工作,但某些行为可能尚不能完美地适应这个多帐户世界。如果您认为有改进空间,请在这些扩展上提出问题。借助相对较新的 vscode.authentication.getAccounts('github')
API,扩展在处理多个帐户方面拥有很大的能力。
更改帐户首选项时添加其他帐户
上个月,我们引入了帐户首选项快速选择,它对于在需要时更改扩展首选使用的帐户非常有用。
我们收到的反馈之一是希望有一种简便的方法来添加尚未登录的帐户。在此里程碑中,我们在 Quick Pick 中引入了一个新项,使您能够做到这一点。使用使用新帐户... 项来启动身份验证流程并一次性将帐户首选项设置为该帐户。
设置编辑器中的实验性和预览设置指示器
以前,从设置编辑器中查看哪些设置是实验性或预览性的并不总是清楚。为了突出实验性和即将推出的功能,设置编辑器现在在实验性和预览设置旁边显示指示器。您可以在设置编辑器搜索框中键入 @tag:experimental
或 @tag:preview
以相应地筛选设置。
扩展作者可以在其设置中添加“experimental”或“preview”标签,以在设置编辑器中显示相应的指示器。
主题:Light Pink(在 vscode.dev 上预览)
更多配置文件的图标
在此里程碑中,我们为配置文件添加了更多图标。您现在可以从更广泛的图标中进行选择来自定义您的配置文件。
在面板中查看图标
在工作台面板区域,视图通常在标题栏中显示为标签(例如,终端或输出)。然而,在较小的屏幕上,这些标签可能会超出可用空间,导致某些视图溢出到下拉菜单中。
为解决此问题,我们添加了一个新设置:workbench.panel.showLabels。禁用后,视图将显示为图标而不是标签,从而节省水平空间并减少溢出。
workbench.panel.showLabels: true
workbench.panel.showLabels: false
编辑器
匹配项高亮延迟
在此里程碑中,我们引入了 editor.occurrencesHighlightDelay 设置,让您可以控制在编辑器中高亮匹配项之前的延迟。降低此延迟值可以在使用语义高亮时带来更响应的编辑器体验。
Web 版 VS Code
Web 版 VS Code 支持本地文件事件
当使用版本 129 及更高版本的 Chrome 或 Edge 时,使用本地文件夹打开 https://insiders.vscode.dev 现在支持文件事件。如果在浏览器外部对已打开工作区的文件和文件夹进行更改,这些更改会立即反映在浏览器内部。
此功能利用了作为新的 Web API 提议的 FileSystemObserver
接口。
对扩展的贡献
Copilot 扩展展示
在此里程碑中,团队致力于构建几个扩展,展示了VS Code 中的 Copilot 可扩展性。这些扩展展示了以下能力
- 聊天参与者与工具 API
- prompt-tsx
- 如何利用 GitHub Copilot 提供的语言模型
试用这些扩展,看看如何在您自己的扩展中扩展 Copilot。
扩展 | 链接 |
---|---|
GitHub 拉取请求 | 市场 |
面向 Copilot 的 Web 搜索 | 市场,源代码 |
使用 Copilot 生成 MermAId 图 | 市场 |
面向 Copilot 的数据分析 | 市场,源代码 |
VS Code Commander | 市场 |
面向 Copilot 的视觉预览 | 市场 |
GitHub 拉取请求
版本 0.100.0 的 GitHub Pull Requests 扩展增加了 Copilot 集成
- 在聊天视图中使用
@githubpr
聊天参与者来搜索问题、总结问题/prs,并为问题提供修复建议。@githubpr
使用多种语言模型工具来实现此功能。 - 还有一个新的通知视图,它显示 GitHub 通知,并带有使用 Copilot 优先处理这些通知的操作。
要尝试所有功能,您可以设置以下设置
使用 Copilot 搜索问题
新的 @githubpr
聊天参与者可以在 GitHub 上搜索问题。
显示问题时,@githubpr
会显示一个 Markdown 表格,并根据搜索结果尝试选择最佳列进行显示。
使用 Copilot 总结和修复
在问题视图中列出的每个问题现在都有一个新的操作,使用 Copilot 总结,它会打开聊天面板并总结选定的问题。我们还添加了另一个操作,使用 Copilot 修复,它会总结选定的问题并使用工作区上下文建议修复方案。
使用 Copilot 优先处理通知(实验性)
在此里程碑中,我们添加了一个实验性的通知视图,列出您在所有仓库中的未读通知。默认情况下,通知按最近更新时间降序排序,但您可以使用视图标题 ...
菜单中的使用 Copilot 按优先级排序操作,让 Copilot 优先处理通知。选择每个通知会触发一个使用 Copilot 总结通知的操作。该视图还包含易于访问的操作,可将通知标记为已读或在 GitHub.com 上打开通知。
面向 Copilot 的 Web 搜索
此扩展展示了
- 聊天参与者与工具 API
- prompt-tsx
- 如何利用 GitHub Copilot 提供的语言模型
源代码可在 GitHub 上获取。
描述
直接在 Copilot 中获取来自网络的最新且最相关的信息。
这由以下两种不同的搜索引擎之一提供支持,通过 websearch.preferredEngine 配置
作为用户,您需要从这些服务之一获取 API 密钥才能使用此扩展。首次使用时,它会要求您提供该密钥,并使用 VS Code 内置的秘密存储进行存储,也可以像管理您的 GitHub 帐户一样通过 VS Code 的身份验证堆栈进行管理。
聊天参与者
此扩展贡献了 @websearch
聊天参与者,它能够处理可能需要来自互联网实时信息的问题。您可以使用 @websearch when did Workspace Trust ship in vscode?
手动调用它。
聊天工具
此扩展还贡献了 #websearch
聊天语言模型工具,它类似于参与者,但在其他聊天参与者中提供来自网络的上下文很有用。例如
@workspace /new #websearch create a new web app written in Python using the most popular framework
此外,如果您正在开发自己的聊天参与者或工具,可以通过 vscode.lm.invokeTool
API 使用此聊天工具。
使用 Copilot 生成 MermAId 图
vscode-mermAId (vscode:extension/ms-vscode.copilot-mermaid-diagram
) 扩展为 GitHub Copilot 贡献了一个新的聊天参与者,以便使用 Mermaid(一种受 Markdown 启发的图表绘制工具)为您的代码构建和修改可视化效果。
创建和渲染图表
通过聊天对话创建任何类型的 Mermaid 支持的图表,并使用 /iterate
斜杠命令来优化图表。特定图表提供了斜杠命令,以便为模型提供额外指导。
为某些图表类型(如流程图)添加了链接,指向用于构建图表所收集的参考。
Mermaid 可视化大纲视图
打开可视化大纲视图,从活动编辑器动态生成图表。您可以切换到聊天以进行更精细的控制。
聊天工具
此扩展贡献了一个工具,用于收集文件内或整个工作区的符号信息,并且在安装此扩展后可供其他聊天参与者使用。
面向 Copilot 的数据分析
面向 Copilot 的数据分析扩展赋能数据科学领域的人员。从清理 .csv
文件,到利用不同的统计度量、图表和预测模型进行更高层次的数据分析,@data
聊天参与者通过为数据任务提供量身定制的见解和交互性,帮助做出更高级和明智的决策。
此扩展贡献了一个工具,LLM 可以使用 Pyodide 请求执行 Python 代码,并获取相关 Python 代码执行的结果。在出现错误时,它还能够智能地重试以获得更好或更合适的执行结果。您还可以将用于执行分析(或生成可视化效果)的代码导出到 Jupyter Notebook 或 Python 文件中。
您可以从市场下载该扩展,源代码可在 GitHub 上获取。
数据分析和可视化
- 给定一个 CSV 文件,输入一个提示,例如
Analyze the file #<file name>
或编写更具体的提示(请参见下方录屏) - 提供后续提示,以请求生成可视化效果,例如图表、绘图等
导出用于执行数据分析的代码
- 可以查看用于执行分析和生成可视化效果的 Python 代码
- 代码可以导出为 Jupyter notebook 或 Python 文件
针对 CSV 文件的编辑器和资源管理器集成
- 右键点击 CSV 文件进行分析
- 打开 CSV 文件并使用 Copilot 图标分析文件
VS Code Commander 扩展
VS Code Commander 扩展 (vscode:extension/ms-vscode.vscode-commander
) 在 VS Code 中充当您的个人助手。这个强大的工具使您能够使用对话式、自由形式的文本配置您的 VS Code 环境。通过 VS Code Commander,您可以
- 发现和探索各种设置和命令
- 根据您的需求定制开发环境
这些操作可以通过简单直观的聊天界面执行,使管理您的 VS Code 配置比以往任何时候都更容易。
面向 Copilot 的视觉预览扩展
用于 Copilot Preview 的 Vision 扩展 (<vscode:extension/ms-vscode.vscode-copilot-vision
>) 使你能够直接附加图像作为上下文输入,丰富对话并支持更动态、更具视觉支持的响应。为了支持 Github Copilot Chat 内置的图像流程,此扩展最终将被弃用。
聊天中的视觉功能
目前,你可以使用自己的 OpenAI、Azure OpenAI、Anthropic 或 Gemini 密钥在“聊天”视图中体验图像附加流程。通过从剪贴板轻松附加图像或直接将它们拖动到聊天中来开始使用。
主题:Sapphire(在vscode.dev上预览)
带有快速修复的视觉功能
此外,你可以使用提供的代码操作为 markdown、HTML、JSX 或 TSX 文档中的图像生成或优化 alt 文本,从而简化了合并描述性文本的过程,以获得更好的上下文和可访问性。Alt 文本快速修复适用于工作区中的图像和图像 URL。
此扩展使用 <ChatReferenceBinaryData
> 提议的 API。欢迎查看如何在源代码中使用它的示例,可以在 GitHub 上查看。
Python
原生 REPL 变量视图
原生 Python REPL 现在为内置的“变量”视图提供最新的变量。这使你可以在从文件或通过 REPL 输入框执行代码时深入研究解释器的状态。
使用 Pylance 生成文档字符串
现在,你可以使用Pylance的文档字符串模板生成功能更方便地为你的 Python 代码生成文档!你可以通过输入 <"""
> 或 <'''
>、按下Ctrl+Space或选择灯泡来调用生成文档字符串代码操作,为类或方法生成文档字符串模板。生成的文档字符串包含函数的描述、参数、参数类型、返回值和返回值类型的字段。
此功能目前是一个实验性设置,但我们期待很快将其设置为默认体验。你可以通过启用python.analysis.supportDocstringTemplate设置来立即试用。
折叠所有文档字符串
文档字符串对于为代码提供上下文和解释非常有用,但有时你可能希望折叠它们以专注于代码本身。现在,你可以通过使用新的Pylance: 折叠所有文档字符串命令更轻松地折叠文档字符串,该命令也可以绑定到你选择的快捷键。要展开它们,请使用Pylance: 展开所有文档字符串命令。
改进的导入建议
Pylance 的强大功能之一是它提供自动导入建议的能力。默认情况下,Pylance 从符号的定义位置提供导入建议,但你可能希望它从导入符号的文件(即别名文件)中导入。使用新的python.analysis.includeAliasesFromUserFiles设置,你现在可以控制 Pylance 是否在其自动导入建议或添加导入快速修复中包含用户文件中的别名符号。
请注意,启用此设置可能会对性能产生负面影响,特别是在大型代码库中,因为 Pylance 可能需要索引更多符号并监视更多文件更改,这会增加资源使用量。
实验性 AI 代码操作:实现抽象类
现在,你可以通过新的实验性代码操作来同时利用 AI 和静态分析的优势来实现抽象类!此功能需要Pylance和GitHub Copilot扩展。要试用,你可以在定义继承自抽象类的类时选择使用 Copilot 实现所有继承的抽象类代码操作。
你可以在用户设置中设置 <"python.analysis.aiCodeActions": {"implementAbstractClasses": false}
> 来禁用此功能。
扩展创作
语言模型工具
我们已经确定了<LanguageModelTool
> API!此 API 使聊天扩展能够通过将语言模型连接到外部数据源或执行操作来构建更强大的体验。该 API 包含两个主要部分:
-
扩展注册工具的能力。工具是一项旨在供语言模型使用的功能。例如,读取文件的 Git 历史记录。当使用 <
lm.registerTool
> 方法注册工具时,其他扩展也可以在 <lm.tools
> 列表中访问它。这将使聊天扩展能够通过共享工具生态系统与其他扩展无缝集成。 -
语言模型支持工具的机制,例如扩展在发出请求时传递工具、语言模型请求调用工具以及扩展反馈工具调用结果。
语言模型工具的使用很复杂,此 API 并未隐藏这种复杂性。如果你想注册工具或在聊天参与者中使用工具,我们建议从扩展示例开始。
聊天参与者检测
我们已经确定了用于聊天参与者检测的 API,它允许 GitHub Copilot 自动选择你的聊天参与者或参与者命令来处理用户的提问。请查看我们的文档以获取详细的教程和建议。
VS Code Speech
VS Code Speech扩展已更新至 August 版本的Azure Speech SDK,并提供了更新的语音转文本识别模型。通过此更新,你应该会在 VS Code 中的语音转文本集成(例如 Copilot Chat)中看到改进的结果。
评论线程 collapsibleState
可以使用新的 <CommentThread.collapsibleState
> 属性更改 <CommentThread
> 的展开/折叠状态,即使在线程已显示后也是如此。以前,此属性仅在首次显示评论线程时才被尊重。
欢迎视图中的 Codicons
欢迎视图现在支持渲染 codicons。你可以在欢迎视图中使用常见的 <$(icon-name)
> 来实现。
聊天参与者访问模型选择器
你可能已经注意到“聊天”视图中的模型选择器,它允许你选择用于聊天请求的模型。
你的聊天参与者扩展需要采用新的 API 才能使用此模型选择器。我们刚刚确定了 <ChatRequest
> 对象上的新 <model
> 属性,该属性将设置为选择器中模型的 <LanguageModelChat
> 实例。你可以使用它而不是 <lm.selectChatModels
> 方法。如果你的扩展想要使用选定模型之外的特定模型,仍然可以使用 <lm.selectChatModels
>。
预览功能
TypeScript 5.7
我们持续改进对即将发布的 TypeScript 5.7 的支持。查看TypeScript 5.7 测试版博客文章和TypeScript 5.7 计划以获取详细信息。
要开始使用 TypeScript 5.7 的预览版本,请安装TypeScript Nightly 扩展。
粘贴时更新 JavaScript 和 TypeScript 的导入
厌倦了在文件之间移动代码后必须添加导入吗?试试我们实验性的粘贴时更新导入的支持!当你将代码复制粘贴到编辑器之间时,VS Code 会在粘贴代码时自动添加导入。
请注意它是如何不仅添加了导入,甚至还为粘贴的代码中使用的局部变量添加了新的导出!
要立即试用此功能,请确保你正在使用 TypeScript 5.7+。然后启用 <javascript.experimental.updateImportsOnPaste
> / <typescript.experimental.updateImportsOnPaste
>。目前仅支持在同一 VS Code 窗口内的文本编辑器之间粘贴时使用。
提议的 API
用于图像附件的 Chat Reference Binary Data
如果存在使用 <ChatReferenceBinaryData
> 提议 API 的扩展,我们现在允许将图像(<png
>、<jpeg
>、<bmp
>、<gif
> 和 <tiff
>)粘贴到聊天中。
export class ChatReferenceBinaryData {
/**
* The MIME type of the binary data.
*/
readonly mimeType: string;
/**
* Retrieves the binary data of the reference.
* @returns A promise that resolves to the binary data as a Uint8Array.
*/
data(): Thenable<Uint8Array>;
/**
* @param mimeType The MIME type of the binary data.
* @param data The binary data of the reference.
*/
constructor(mimeType: string, data: () => Thenable<Uint8Array>);
}
扩展作者可以在创建聊天处理程序后通过 <request.references
> 访问此数据,当通过拖放或快速选择附加图像时,它可能是一个 <URI
>,对于粘贴的图像,它将是 <ChatReferenceBinaryData
>。
工程
大型语言模型的提示构建库
本月,我们开源了@vscode/prompt-tsx库,我们在过去一年中在 Copilot Chat 中开发和使用该库来构建语言模型提示。该库使开发人员能够使用类似于 React 的 TSX/JSX 语法创建提示,并包含各种工具,以充分利用提示的 token 预算。
删除 AMD 代码并在 web 中更多地使用 ESM
我们已经从源代码中删除了 AMD (Asynchronous Module Definition) 的最后痕迹,主要是在我们为了支持 AMD 而仍然保留的构建脚本中,以备恢复版本需要。
此外,https://vscode.dev 现在也完全使用 ESM (ECMAScript Modules) 运行。
迁移到 ESLint 9
我们已经更新了主 VS Code 仓库和所有扩展示例以使用 ESLint 9。这包括将我们所有的 ESLint 配置迁移到使用现代平面配置。
Electron 32 更新
在此里程碑中,我们将 Electron 32 更新推广到稳定版本的用户。此更新包含 Chromium 128.0.6613.186 和 Node.js 20.18.0。我们要感谢所有在 Insiders 版本上自行托管并提供早期反馈的用户。
值得关注的修复
- 177046 在扩展面板中搜索后会崩溃
感谢
最后但同样重要的是,向 VS Code 的贡献者致以诚挚的谢意。
问题跟踪
对我们的问题跟踪的贡献
Pull 请求
对 vscode
的贡献
- @Abrifq (Arda Aydın): Change <
window.experimentalControlOverlay
>s scope to application PR #230593 - @asemdreibati (Asem Dreibati): handle edge case in slice function in Iterable namespace (#_230683) PR #232134
- @BABA983 (BABA)
- Add developer action to show gpu status PR #222291
- Fix debug console is cleared on style changed PR #224694
- Support open in editor in git editor PR #226967
- @Bistard (SIHAN LI): Fix typo: context view anchor option might be dismissed when using <
||
> PR #228896 - @cobey (Cody Beyer): added mistral ai npm package PR #229865
- @elias-pap (Elias Papavasileiou): fix: improve settings descriptions for actions triggered on save PR #230052
- @gjsjohnmurray (John Murray): Correct Menu Contexts info on extension's Commands page (fix #229258) PR #229260
- @hamirmahal (Hamir Mahal): style: simplify string formatting for readability PR #231763
- @injust (Justin Su): Fix "in none full screen mode" typo PR #229914
- @jamesharris-garmin (James Harris): Fix missing __dirname in --locate-shell-integration-path PR #231423
- @jeanp413 (Jean Pierre): Fix if logOutputChannel is created again after being disposed, it will disappear PR #225709
- @Kaidesuyoo (Kaidesuyo): Performance optimization PR #230804
- @kkshinkai (Kk Shinkai): Correctly trigger the <
onDidAddListener
> event in emitter options PR #230259 - @Parasaran-Python (Parasaran): 228640: Hiding prelaunch task popup if the setting to hide it is enabled PR #231225
- @quiple (Minseo Lee): Change Korean font priority PR #230195
- @r3m0t (Tomer Chachamu): Fix scrolling of Test Results when a new test starts (fixes #229531) PR #229532
- @sandersn (Nathan Shively-Sanders): TS extension: register call to CopilotRelated with copilot extension PR #228610
- @ShadowRZ (夜坂雅): fix: Use a proper desktop name in package.json PR #231472
- @trevor-scheer (Trevor Scheer): Marker message white-space <
nowrap
> -> <pre
> PR #229454 - @vietanhtwdk: rerender on resize stickyscroll PR #227400
- @yanglb (Yanblb): add type checking to decorators PR #230626
对 vscode-docs
的贡献
- @Cecil0o0 (hj)
- @echofly: Update v1_94.md PR #7677
- @ghosted-sound
- @gjsjohnmurray (John Murray)
- @oleschri: add argument --update-extensions PR #7681
- @partev: fix URL redirect PR #7640
- @ptrptrd: docs: remove double entries in theme color references PR #7639
- @RonakRahane: Added documentation for new Code Coverage in C# Fixes #7635 PR #7664
对 vscode-js-debug
的贡献
- @marcusball (Marcus Ball): feat: use <
remoteHostHeader
> option when looking up websocket address PR #2111
对 vscode-languageserver-node
的贡献
- @DanTup (Danny Tuppeny): Add support for CompletionList "applyKind" to control how defaults and per-item commitCharacters/data are combined PR #1558
对 vscode-mypy
的贡献
- @jwhitaker-gridcog (Jarrad): run mypy in the directory of the nearest pyproject.toml or mypy.ini PR #316
对 vscode-vsce
的贡献
- @andrewlayer: Added unpublish to api.ts PR #1061
- @deribaucourt (Enguerrand de Ribaucourt): Fix regression with workdir symlinks PR #1053
- @dtivel (Damon Tivel): Quote <
filename
> value in <Content-Disposition
> header PR #1060
对 language-server-protocol
的贡献
- @asukaminato0721 (Asuka Minato)
- @DanTup (Danny Tuppeny): Add support for <
completionList.applyKind
> to determine how values from <completionList.itemDefaults
> and <completion
> are combined. PR #2018 - @DavyLandman (Davy Landman): Added Rascal to relevant LSP implementor sections PR #2029
- @g-plane (Pig Fang): fix punctuation typo PR #2048
- @nthykier (Niels Thykier): Add the <
debputy
> language server PR #2044 - @RainCmd (渴望蓝天): Add Rain language server to LSP PR #2039
- @WilsonZiweiWang (ziweiwang): Add BitBake language server PR #2049
- @yasmewad (Yash Mewada): Add Smithy language server links to LSP PR #2036
对 lsprotocol
的贡献
- @nobodywasishere (Margret Riegert): Add Crystal plugin to README PR #403
对 tolerant-php-parser
的贡献
- @TysonAndre (Tyson Andre): Fix php 8.4 notices about implicitly nullable parameters PR #410