现已推出!阅读有关 11 月新功能和修复的信息。

2018 年 9 月(1.28 版本)

更新 1.28.2:此更新解决了这些问题

更新 1.28.1:此更新解决了这些问题

下载:Windows:x64 | Mac:Intel | Linux 64 位:deb rpm tarball | 32 位:deb rpm tarball


欢迎使用 Visual Studio Code 2018 年 9 月版本。正如在9 月迭代计划中宣布的那样,我们专注于整理我们的 GitHub 问题和拉取请求。在我们的所有 VS Code 存储库中,我们关闭(已分类或已修复)了 3918 个问题。在我们关闭问题的同时,您创建了 2187 个新问题。这导致净减少了 1731 个问题。主要的vscode 存储库现在有 2472 个未解决的功能请求和 625 个未解决的错误。此外,我们关闭了 212 个拉取请求。

很高兴看到您如此关心我们的进展。Benjamin Lannon 发布了一个个人网站,其中包含我们主存储库中问题编号的实时跟踪器。它很好地展示了我们自 9 月 11 日以来的进展

Burn down of issues

它还显示了当我们停止关注减少问题时会发生什么。以下是上周最后三天在我们为本次发布做准备时的情况。正如您所看到的,在未来,我们将进行更多的问题整理迭代。

Increase of issues

在这个整理里程碑中,我们还解决了几个功能请求,社区拉取请求也促成了新功能的诞生。以下是一些发布亮点

如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的更新
您还可以观看 Cloud Developer Advocate Brian Clark 发布的此 1.28 版本亮点视频

内部人员:想尽快看到新功能吗?您可以下载每日内部人员构建版本,并尝试最新的更新。

工作台

默认情况下在 Windows 上使用自定义标题和菜单栏

在之前的发行说明中描述的自定义标题栏和可主题化菜单现在默认在 Windows 上启用。设置 "window.titleBarStyle" 在上个月的 Windows Insider 版本中,默认设置为 "custom",现在我们已准备好将其作为默认体验。

Custom title and menu bar with a dark theme on Windows

每个文件类型的文件图标

在 macOS 和 Windows 上,VS Code 注册为已知文件类型的默认编辑器。VS Code 现在为一些常见的 VS Code 文件类型提供自定义图标。当图标大小配置为中等到大时,这些图标将显示在操作系统资源管理器中。对于小图标尺寸,我们决定保留 VS Code 徽标作为图标。

File Icons

项目级代码片段

代码片段现在可以限定到项目范围并与您的团队共享。只需使用 首选项:配置用户代码片段命令,或在 .vscode 文件夹中创建 *.code-snippets 文件。项目代码片段的工作方式与其他代码片段一样,它们显示在 IntelliSense 和 插入代码片段 操作中,现在它们有自己的类别。

Project Level Snippet

代码片段现在还支持多个前缀。如果您无法决定您的版权标头代码片段应以 headerstub 还是 copyright 为前缀,您可以全部使用它们。只需使用字符串数组作为 prefix 属性。

{
  "prefix": ["header", "stub", "copyright"],
  "body": "Copyright. Foo Corp 2028",
  "description": "Adds copyright...",
  "scope": "javascript,typescript"
}

长期以来,VS Code 在打开时一直在解析到文件夹的符号链接。这意味着,即使符号链接有其存在的原因,VS Code 也会忽略它,并且始终打开解析的链接路径。我们已决定更改此行为并保留符号链接。

注意:当以符号链接的形式打开文件夹时,某些功能将以降低的功能运行(例如,调试Git 集成)。

记录和搜索键盘快捷键

在键盘快捷键编辑器中(⌘K ⌘S (Windows,Linux Ctrl+K Ctrl+S)),您现在可以通过键入击键来搜索键盘绑定,而不是键入按键名称(例如“shift”)。打开正在记录按键模式,并键入您要搜索的击键。

Record Keys

您还可以使用⌥⌘K (Windows,Linux Alt+K)进入正在记录按键模式。按 Esc 键退出正在记录按键模式。

切换面板更改

我们决定重新审视用于切换面板(终端、输出、问题、调试控制台)的命令的行为。您可以在问题 19400 中查看更改的背景信息。

旧的行为是

  • 如果面板不可见,则显示面板。
  • 如果面板可见,则隐藏面板。

新的行为是

  • 如果面板不可见,则显示面板。
  • 如果面板具有键盘焦点,则隐藏面板。
  • 当面板可见但未获得焦点时,面板获得焦点。

要返回之前的行为,您可以在相关面板处于活动状态时配置一个键盘绑定以关闭面板。

例如,对于输出面板

{
  "key": "cmd+shift+u",
  "command": "workbench.action.closePanel",
  "when": "activePanel==workbench.panel.output"
}

面板标识符列表是

  • terminal - 集成终端
  • workbench.panel.markers - 问题面板
  • workbench.panel.output - 输出面板
  • workbench.panel.repl - 调试控制台面板

复制相对路径

将文件路径复制为相对路径的命令现在在文件资源管理器和编辑器选项卡的上下文菜单中更加突出地显示。

Copy Relative Path

从快速打开中排除最近打开的文件

新的设置 search.quickOpen.includeHistory 允许您控制最近打开的文件是否应属于快速打开文件选择器的一部分。默认情况下,最近打开的文件将显示在搜索顶部,工作区中的其他文件将显示在下方。如果您不希望在顶部看到最近打开的文件,可以将此设置更改为 false

删除文件时禁用回收站

如果您在从资源管理器中删除文件时看到文件移动到操作系统回收站的问题,现在可以将 files.enableTrash 设置为 false,以在删除时永远不使用操作系统回收站。这样做会更改文件资源管理器上的 删除 操作和键盘绑定,以绕过操作系统回收站并永久删除。删除之前,您仍然会看到提示。

如果检测到工作区文件,则提示打开

当打开根目录中包含一个或多个 .code-workspace 文件的文件夹时,VS Code 现在会显示一个通知,询问您是否要改为打开工作区文件。打开工作区文件通常会比仅打开文件夹提供更好的体验。您可以在我们的文档中了解有关多根工作区的更多信息。

Workspace file prompt

重新打开文件时不要恢复视图状态

即使在文件关闭后,VS Code 也会始终记住文件的视图状态(光标位置、折叠部分等)。现在有一个新的设置 workbench.editor.restoreViewState 可在关闭文件时删除此视图状态。这使您可以在重新打开文件后始终从文件顶部开始。

跨所有编辑器组关闭文件

新命令关闭所有组中的编辑器 (workbench.action.closeEditorInAllGroups) 允许您跨所有编辑器组关闭当前活动文件。

问题面板

显示错误代码

问题面板现在显示问题的错误代码(如果有)。

Problems panel shows error codes

改进的键盘导航

问题面板的键盘友好性更高了

  • 当面板获得焦点时,您可以开始键入以进行筛选。
  • 您可以使用 ⌘F (Windows,Linux Ctrl+F) 将焦点放在筛选框中,使用 ⌘↓ (Windows,Linux Ctrl+Down) 将焦点从筛选框转移到问题列表。

遥测事件的输出通道

在 7 月的发布版本中,我们添加了一项功能,如果您使用 开发者:设置日志级别... 命令将日志级别设置为跟踪,则 VS Code 发送的所有遥测事件也会记录到本地文件中。您现在可以在输出面板的 日志(遥测)通道中查看此文件的内容。与以前一样,您可以使用 开发者:打开日志文件... 命令直接查看该文件。

为自定义视图设置焦点

您现在可以使用命令为自定义视图设置焦点。为每个自定义视图提供了单独的命令。

Custom view focus commands

Linux URL 处理

曾经仅限于 Windows 和 macOS 的功能,现在你也可以在 Linux 上打开 VS Code URL 了!这些 URL 对于许多不同的功能都很有用,例如自动安装扩展,例如 vscode-insiders:extension/vscodevim.vim

编辑器

Tab 补全

编辑器 Tab 补全现在可以完成各种建议。在设置 "editor.tabCompletion": "on" 之后,按 Tab 键将完成任何前缀,而不仅仅是代码片段。此外,按 Tab 键将插入下一个建议,按 ⇧Tab (Windows, Linux Shift+Tab) 键将插入上一个建议。

Tab completion

导航到上次编辑位置

添加了一个新命令 **转到上次编辑位置** (workbench.action.navigateToLastEditLocation),用于快速导航到文件中上次编辑的位置。默认快捷键是 ⌘K ⌘Q (Windows, Linux Ctrl+K Ctrl+Q)

保存时不进行格式化

新命令 **保存时不进行格式化** (workbench.action.files.saveWithoutFormatting) 可用于保存文件而不触发任何保存参与者(例如,格式化程序、删除尾随空格、最终换行符)。默认快捷键是 ⌘K S (Windows Ctrl+K Ctrl+Shift+S,Linux Ctrl+K S)。这在编辑正常项目之外的文件时很有用,这些文件可能具有不同的格式约定。

IntelliSense 局部性加成

现在可以根据建议与光标的距离对建议进行排序。设置 "editor.suggest.localityBonus": true,您将看到,例如,函数参数显示在 IntelliSense 列表的顶部。

Locality bonus

Emmet

我们在本次迭代中对 Emmet 功能进行了一些改进

  • 如果您在 JavaScript 文件中启用了 Emmet,那么现在可以在 HTML 文件中的 <script> 标签内进行 Emmet 缩写扩展。
  • **Emmet: 使用缩写包装** 功能不再局限于扩展名为 .html 的文件。
  • **Emmet: 平衡(向内)** 功能现在即使没有选择也适用于当前节点。
  • 现在已修复了在 SCSS 文件中错误地将带有 # 的 CSS 选择器视为有效缩写的 bug

源代码管理

更改 SCM 提交快捷键

现在可以使用 scm.acceptInput 命令更改 SCM 视图中接受提交消息的默认快捷键。

SCM 状态栏跟踪活动文件

左下角的 SCM 状态栏贡献现在跟踪当前活动文件所属的任何存储库。这减少了在多文件夹工作区中编辑文件时的混淆。

Git 集成

更好地处理删除冲突

VS Code 一直检测到删除冲突。现在有更好的 UI 流程来处理它们,当您打开更改时,您会看到未删除的版本,并且您可以在暂存时决定如何处理该文件:保留或删除它。

Keep or delete deletion conflicts

配置长提交消息警告阈值

git.inputValidationLength 设置现在允许您配置提交消息在编辑时出现警告之前的长度。

在 'git init' 后将文件夹添加到工作区

初始化 Git 存储库后,VS Code 现在会询问您是否要将其添加到当前工作区。

配置分支验证规则

您现在可以使用强大的 git.branchValidationRegexgit.branchWhitespaceChar 设置来控制分支名称验证的工作方式。有关详细信息,请参阅问题 50241

运行同步时始终进行变基

git.rebaseWhenSync 设置将允许您配置 **同步** 命令在运行时始终使用变基而不是合并。

禁用进度报告

使用 git.showProgress 设置,您现在可以在 Git 操作期间禁用显示进度。

强制推送 --force

在您日常开发中有时您会感觉想要冒险。运行 git push --force 就是一个很好的例子!VS Code 现在允许您强制将提交推送到远程,而无需进入终端。使用 git.allowForcePushgit.useForcePushWithLeasegit.confirmForcePush 设置来控制此行为。有关详细信息,请参阅问题 53286

储藏应用

以下 git stash apply 命令现在在全局命令面板中提供:**Git: 应用储藏...**、**Git: 应用最新储藏**。

始终可见的暂存更改部分

您现在可以使用 git.alwaysShowStagedChangesResourceGroup 设置,始终使 **暂存更改** 部分在 SCM 视图中保持可见,即使它是空的。

Staged changes visible

终端

定义发送自定义序列的快捷键

添加了新命令 workbench.action.terminal.sendSequence,它允许您直接向活动终端发送自定义序列。这允许使用 \u 格式发送 Unicode 字符来发送箭头键、回车等。

{
  "key": "ctrl+u",
  "command": "workbench.action.terminal.sendSequence",
  "args": { "text": "\u001b[1;5D\u007f" }
}

查找改进

终端中的查找功能已得到改进,现在的行为更像编辑器中的查找功能

  • 支持正则表达式、区分大小写和匹配单词。
  • 标准的查找下一个/上一个快捷键 (F3, Shift+F3) 现在可以使用。
  • 返回跨行包装的查找结果。

语言

TypeScript 3.1

VS Code 1.28 附带 TypeScript 3.1.1。此版本带来了新的语言功能,例如 可映射的元组和数组类型,以及一些工具改进和 bug 修复。

重命名导入路径

意识到导入的文件可以使用更好的名称?现在可以通过重命名导入来重命名引用的文件

Renaming an JavaScript import to rename a file

转换为异步函数

JavaScript 和 TypeScript 的新 **转换为异步函数** 建议将使用 .then Promise 链的函数重写为使用 asyncawait

Converting a promise chain to an async function

请注意,此功能需要将设置 javascript.validate.enable 设置为 true。

用于 JS/TS 建议的新设置

我们清理了 JavaScript 和 TypeScript 建议的设置名称,并添加了一些提供更精细控制的其他设置

  • 所有与建议相关的设置现在都在 javascript.suggest.*typescript.suggest.* 下。
  • typescript.useCodeSnippetOnMethodSuggest 已重命名为 javascript.suggest.completeFunctionCallstypescript.suggest.completeFunctionCalls
  • javascript.nameSuggestions 已重命名为 javascript.suggest.names
  • typescript.autoImportSuggestions.enabled 已重命名为 javascript.suggest.autoImportstypescriptscript.suggest.autoImports
  • 新的 javascript.suggest.enabledtypescript.suggest.enabled 允许您完全禁用 JS 或 TS 建议。

分号作为 JS/TS 的提交字符

分号现在是 JavaScript 和 TypeScript 建议的提交字符。这意味着您可以通过键入 ; 来接受当前建议。现有提交字符还包括 .(

您可以通过设置 "editor.acceptSuggestionOnCommitCharacter": false 来禁用提交字符。

HTML 和 CSS 路径完成排除点文件

现在从路径完成结果中排除以 . 开头的文件。

更好的 Markdown 折叠

多行列表、围栏代码块和原始 HTML 现在可以在 Markdown 文件中折叠

Folding Markdown code blocks and lists

在 Markdown 预览中,单击指向本地文件的链接现在将打开该文件的预览

Local file link open in preview

这使得浏览文档更容易。使用 markdown.preview.openMarkdownLinks 设置来配置如何处理链接。有效设置值为

  • inEditor - 在编辑器中打开本地 Markdown 链接。
  • inPreview - 在当前预览中打开本地 Markdown 链接。这是新的默认行为。

扩展

搜索过滤改进

您现在可以使用 @category 过滤器以及其他已安装扩展的过滤器,例如 @installed@enabled@disabled@outdated 来组成您的扩展搜索查询。例如,您可以使用查询 @installed @category:themes 搜索已安装的主题,或使用 @installed @category:snippets 搜索提供代码片段的已安装扩展。

禁用的扩展不会被视为过时

活动栏上用于扩展视图的徽章会显示过时扩展的数量,现在将排除禁用的扩展。此徽章的目的是让您知道您可能想要更新的过时扩展。由于禁用的扩展当前未使用,因此将其包括在计数中只会分散注意力。

扩展主机无响应

VS Code 在一个名为 **扩展主机** 的单独进程中执行扩展。此进程使用消息传递与渲染器/UI 进程进行通信。我们添加了对扩展主机的消息的更好跟踪,如果消息在 10 秒内未被确认,我们将显示以下通知

Extension Host Unresponsive

**这意味着什么**:最有可能的是,某个扩展正在执行 CPU 密集型操作,最终**阻塞了扩展主机进程超过 10 秒**。

操作方法:一种选择是等待操作完成,然后忽略通知。另一种选择是转到运行扩展视图,并开始分析扩展主机,以调查哪个扩展导致 CPU 使用率过高。然后,您可以直接针对有问题的扩展创建一个问题。最后,如果您认为该扩展程序已进入无限循环,并且似乎不会恢复,则可以重启扩展主机。

工程

扩展程序和 webpack

我们继续进行 webpack 的工作,现在大多数捆绑的扩展程序都已 webpack 化。作为回顾:这有助于减少扩展程序的启动时间,因为需要加载的文件更少,需要解析的源代码也更少。它还有助于减少安装时间,因为需要提取和写入磁盘的文件更少。

在这个里程碑中,我们又减少了 2803 个文件。7 月份,我们从 9000 个文件开始,到 8 月份减少到 4650 个,到 9 月份减少到 1847 个!

预览功能

预览功能尚未准备好发布,但功能足以使用。我们欢迎您在开发过程中提供早期反馈。

继续探索 Electron 3.0

在此里程碑中,我们继续探索将 Electron 3.0.0 捆绑到 VS Code 中。这是一个主要的 Electron 版本,附带 Chrome 66 和 Node.js 10.x(与我们当前具有 Chrome 61 和 Node.js 8.x 的版本相比,这是一个重大飞跃)。我们计划在不久的将来向我们的 Insiders 用户推送更新,以收集更多反馈。如果您有兴趣提供帮助,请务必安装 VS Code Insiders

杂项

macOS Mojave 上的模糊问题

如果您已更新到 macOS 10.14 (Mojave),您可能会注意到,如果您没有使用高 DPI 显示器,VS Code 中的字体看起来会模糊。

一种解决方法是运行

defaults write com.microsoft.VSCode.helper CGFontRenderingFontSmoothingDisabled -bool NO

从终端,然后重启计算机。

请注意,此更改对每个应用程序都是全局的,而不是特定于 VS Code 的。有关相关讨论,请参阅问题 51132

Electron 更新

在此版本中,我们从 Electron 2.0.7 更新到 2.0.9。最值得注意的是,这允许 VS Code 再次在 ArchLinux 上运行(问题 55934)。

扩展创作

处理未安装扩展的 URL

早在 7 月,我们就发布了 URI 处理程序 API,供扩展程序处理系统范围的 URI。在最新版本中,VS Code 甚至可以处理尚未安装的扩展程序的 URI。一旦用户打开此类 URI,VS Code 将在 Marketplace 中搜索该扩展程序,建议用户安装它,并通过传入 URI 来启动 VS Code。这允许扩展程序具有流畅的启动流程,使用户从网页跳转到运行具有特定状态的扩展程序。

诊断错误代码

由于诊断错误代码现在在问题面板中显示,因此扩展程序不再需要在 Diagnostic.message 属性中添加错误代码。

更好的配置 when 子句

在编写键盘快捷键或菜单可见性时,会使用 when 子句。在 when 子句中,您可以通过添加前缀 config. 来引用配置(设置)值,例如 config.editor.tabCompletion。以前仅支持布尔配置属性,但在此版本中,您还可以使用字符串和数字值。

更改文本文档的语言

有一个新的 API 函数可以更改文档的语言模式,vscode.languages.setTextDocumentLanguage。API 接受一个文档和您要使用的语言标识符。要了解有哪些可用的语言 ID,请使用 vscode.languages.getLanguages

workspaceContains 激活

当打开一个包含与某些模式匹配的文件的工作区时,扩展程序可以使用 workspaceContains 激活事件来激活。例如,当打开一个包含与 **/*.php 匹配的文件的的工作区时,PHP 扩展程序可能会请求激活。这不是什么新功能,但用户指出,当打开大型工作区时,搜索过程可能会运行很长时间并占用大量 CPU。

我们进行了一些更改以减少这些搜索的影响。首先,这些搜索现在将遵循用户的 files.excludesearch.excludesearch.useIgnoreFiles 设置。换句话说,如果用户无法通过普通文本搜索或通过快速打开的文件搜索找到文件,则 workspaceContains 模式将不会匹配该文件。这大大减少了我们必须搜索 workspaceContains 的文件数量,并减少了在匹配实际上不是项目一部分的文件时(例如,埋在 node_modules/ 中的一些文件)的不正确激活。

第二个更改是对这些搜索施加 7 秒的限制。如果搜索在 7 秒后仍未完成,我们将终止搜索过程并激活扩展程序。

总的来说,这应该减少在 VS Code 中打开大型工作区后笔记本电脑莫名其妙地发热的情况。

新的主题颜色

有新的主题颜色

  • menu.separatorBackground:菜单中分隔符菜单项的颜色。
  • sideBarSectionHeader.border:侧边栏部分标题边框颜色。
  • inputValidation.infoForeground:信息严重性的输入验证前景色。
  • inputValidation.warningForeground:警告严重性的输入验证前景色。
  • inputValidation.errorForeground:错误严重性的输入验证前景色。
  • editor.snippetTabstopHighlightBackground:代码片段制表位的高亮背景色。
  • editor.snippetTabstopHighlightBorder:代码片段制表位的高亮边框颜色。
  • editor.snippetFinalTabstopHighlightBackground:代码片段最后一个制表位的高亮背景色。
  • editor.snippetFinalTabstopHighlightBorder:代码片段最后一个制表位的高亮边框颜色。
  • activityBar.inactiveForeground:活动栏项目处于非活动状态时的前景色。

调试 API

resolveDebugConfiguration 需要显式返回 null 才能打开 launch.json

以前,如果 resolveDebugConfiguration 返回的启动配置没有 type 属性,则 VS Code 会自动打开底层的 launch.json 文件。在收到扩展作者的反馈后,我们决定让扩展程序更好地控制这种情况。

现在,resolveDebugConfiguration 必须显式返回 null 值,才能阻止调试会话启动并改为打开 launch.json。返回 undefined 值只会阻止调试会话启动。和以前一样,返回带有 type 属性的配置将启动调试会话。

建议的扩展 API

每个里程碑都附带新的建议 API,扩展作者可以试用它们。与往常一样,我们渴望您的反馈。以下是您试用建议 API 需要执行的操作

  • 您必须使用 Insiders 版本,因为建议的 API 会频繁更改。
  • 您必须在扩展程序的 package.json 文件中添加此行:"enableProposedApi": true
  • vscode.proposed.d.ts 文件的最新版本复制到您的项目中。

请注意,您不能发布使用建议的 API 的扩展程序。我们很可能会在下一个版本中进行重大更改,并且我们绝不希望破坏现有扩展程序。

调试 API

新的 DebugConfigurationProvider.provideDebugAdapter 替代了 DebugConfigurationProvider.debugAdapterExecutable 命令

之前,我们添加了建议的 API DebugConfigurationProvider.debugAdapterExecutable,以便扩展程序可以返回由 VS Code 即将启动的调试适配器的动态计算路径(以及相应的程序参数)。在这个里程碑中,我们正在根据收到的反馈(例如 #45220#56646#57706#54465)修改初始设计。

新的 API 方法名为 provideDebugAdapter,现在我们传入调试会话、工作区文件夹、package.json 中的可执行文件信息以及已解析的启动配置。有了这些信息,扩展程序在被要求创建调试适配器时就有了“全局视图”。

此外,我们现在支持更多启动和连接到调试适配器实现的方法。为此,可以从 provideDebugAdapter 方法返回描述符对象

  • 可以使用 DebugAdapterExecutable 描述符来启动调试适配器作为每个会话的外部进程,并通过 stdin/stdout 与之通信。通过新的 API,现在可以指定调试适配器的工作目录和环境变量。
  • DebugAdapterServer 描述了一个处理多个会话并通过套接字通信的服务器进程。
  • DebugAdapterImplementation 可用于没有通信开销的就地实现。此选项依赖于对用于 DAP 的 基于 Node.js 的客户端库的小修改,并计划在 10 月份推出。

请注意,这是一个建议的 API,不能用于在 Marketplace 上发布的扩展程序。但是,我们感谢您对问题 45220 上关于 DebugConfigurationProvider.provideDebugAdapter 的反馈。

评论编辑和删除

在上次迭代中,我们引入了 DocumentCommentProvider,允许扩展程序在编辑器中创建和管理评论。我们向此提供程序添加了新方法,以支持评论的编辑和删除。评论本身现在也具有标志,指示它们是否支持编辑或删除。如果扩展程序设置了这些标志之一并提供了适当的编辑或删除方法,则当悬停或聚焦编辑器内的评论时,将显示用于编辑或删除评论的操作。

Comment editing

新命令

按键 命令 命令 ID
⌘K ⌘Q (Windows, Linux Ctrl+K Ctrl+Q) 导航到上次编辑的位置 workbench.action.navigateToLastEditLocation
⌘K S (Windows Ctrl+K Ctrl+Shift+S, Linux Ctrl+K S) 保存文件而不运行保存参与者(格式化程序等) workbench.action.files.saveWithoutFormatting
关闭所有编辑器组中的活动文件 workbench.action.closeEditorInAllGroups
切换差异编辑器内联和并排模式(弃用 toggle.diff.editorMode toggle.diff.renderSideBySide

新文档

GitHub 拉取请求扩展程序博客文章

您可以阅读 Kenneth 最近的博客文章,其中宣布了新的 GitHub 拉取请求扩展程序,并讨论了 VS Code 和 GitHub 编辑器团队之间的合作。

使用 Azure Pipelines 博客文章

使用 Azure Pipelines 的 Visual Studio Code 中,VS Code 工程师 João Moreno 描述了 VS Code 现在如何使用 Azure Pipelines 进行其构建和持续集成 (CI) 基础架构。

新的 PowerShell 主题

Visual Studio Code 中的 PowerShell 通过 Microsoft PowerShell 扩展程序展示了 PowerShell 集成。该扩展程序支持强大的语言功能,例如 IntelliSense、转到定义和查找所有引用,以及调试和代码片段。

新的 Python Django 教程

有一个新的 在 Visual Studio Code 中使用 Django 教程,展示了如何在 VS Code 中快速创建、编辑和调试 Python Django Web 应用程序。

值得注意的修复

  • 48051: 格式化后需要向左滚动
  • 31619: 必须在代码片段中跳过已删除的制表位
  • 58327: 调试工具栏按钮被禁用
  • 35935: “清除最近打开”也应清除编辑器快速选择历史记录
  • 58799: 保存时显示未命名文件
  • 29553: 在按下 Esc 键时保留快速打开输入
  • 58222: UriDisplayService 缺少远程共享路径名称
  • 54213: 在不显示 launch.json 的情况下中止调试启动的机制
  • 52511: 调试悬停小部件 - 启用小部件大小调整,以显示溢出隐藏的长项目
  • 50569: 如果断点已禁用,则条件断点提示应提供启用断点的选项
  • 42737: 扩展: 允许右键单击以弹出齿轮菜单
  • 58434: 使用 --force 参数来防止从 CLI 安装扩展时出现提示。

感谢

最后但并非最不重要的,非常感谢以下人士帮助使 VS Code 更加出色

vscode 的贡献

language-server-protocol 的贡献

vscode-languageserver-node 的贡献

debug-adapter-protocol 的贡献

vscode-recipes 的贡献

vscode-chrome-debug 的贡献

vscode-chrome-debug-core 的贡献

  • @digeff
    • 更新日志机制,不记录来源 PR #355
    • 修复 chrome 69 的第一行断点问题 PR #352
    • 修复加载时中断,使附加时的断点正常工作 PR #332

localization 的贡献

在 Transifex VS Code 项目团队中,有近 1200 名成员,每月约有 100 名活跃贡献者。我们感谢你们的贡献,无论是提供新的翻译、为翻译投票,还是提出流程改进建议。

以下是本次发布的贡献者快照。有关项目(包括贡献者姓名列表)的详细信息,请访问项目网站 https://aka.ms/vscodeloc

  • 孟加拉语: Anisuzzaman Khan, abm_prottoy, Mushiar Khan, Mehedi Hassan。
  • 保加利亚语: Любомир Василев。
  • 克罗地亚语: Nikša Mihaica。
  • 捷克语: Vít Staniček。
  • 丹麦语: Kenneth Greig, Johan Fagerberg, Martin Fruensgaard。
  • 荷兰语: Gerald Versluis, Marco van den Hout。
  • 法语: Antoine Griffard, MayakoLyyn, Smrman, Etienne Blanc-Coquand。
  • 德语: J.M., Carsten Kneip, Volkmar Rigo, SetTrend。
  • 希腊语: Nikolaos Maliakkas。
  • 印地语: Ashwini Gupta, Shaswat Rungta。
  • 匈牙利语: Tar Dániel。
  • 简体中文: Joel Yang, 子实 王, pluwen, Chris Pan 潘冬冬, danyeh。
  • 繁体中文: Duran Hsieh, Poy Chang, Alan Tsai, Han Lin, Shih-Ming Tung, Will 保哥。
  • 印尼语: G-RiNe Project, Wildan Mubarok, Rizki A. Wibowo, Riwut Libinuko, Azhe-kun, rodin, Febrian Setianto (Feber)。
  • 意大利语: Luigi Bruno, Luca Bruni, Alessandro Alpi, Emilie Rollandin, Pascal Brax, Andrea Dottor, Riccardo Cappello。
  • 日语: Satoshi Kajiura, Shunya Tajima, Yuichi Nukiyama, yoshioms, daisuke osada (daiskeh)。
  • 韩语: Kyunghee Ko, jaeyeon Kim, Junseong Jang, Jisan Oh。
  • 立陶宛语: Martynas Jusys。
  • 马拉雅拉姆语: Kiren Paul。
  • 挪威语: Espen Klein Nilsen。
  • 波兰语: Artur, Patryk Brejdak, Adam Borowski, Mateusz Wyczawski。
  • 葡萄牙语(巴西): Roberto Fonseca, Bruno Sonnino, Danilo Dantas, Marcelo Fernandes, Thiago Custodio, Rodrigo Crespi, Marcelo Andrade, Alessandro Fragnani, Lucas Miranda, Otacilio Saraiva Maia Neto。
  • 葡萄牙语(葡萄牙): António Santos,Diogo Barros, António Lourenço, jp2masa, Ruben Mateus, Henrique Silva, André Vala。
  • 俄语: Ivan Kuzmenko, Roman Slauta。
  • 西班牙语: Jorge Serrano Pérez, José M. Aguilar, Alberto Poblacion, Carlos Mendible, Alejandro Medina, Andy Gonzalez,Carlos Herrera。
  • 泰米尔语: Vijay Nirmal, rajakvk, Anand AV。
  • 土耳其语: Mustafa Turhan, Fırat Payalan, Selim Ata。