在 VS Code 中尝试

2018 年 3 月 (版本 1.22)

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

下载: Windows | Mac | Linux 64 位: .tar.gz .deb .rpm | Linux 32 位: .tar.gz .deb .rpm


欢迎使用 2018 年 3 月发布的 Visual Studio Code。此版本中有许多重要的更新,我们希望您能喜欢。其中一些主要亮点包括

如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的更新页面。
您还可以观看云开发倡导者 Brian Clark 制作的 1.22 版本亮点视频

发行说明按 VS Code 重点领域相关部分进行编排。以下是一些进一步的更新

  • 编辑器 - Emmet 性能和智能匹配改进,新增代码片段日期变量。
  • 工作台 - Windows 上更流畅的滚动,搜索和替换期间自动保存。
  • 调试 - 改进的 Node.js 进程选择器,launch.json 中的 postDebugTask。
  • 任务 - 更好的命令和参数引用与转义支持。
  • 语言 - JSDoc 中更便捷的 IntelliSense,CSS 路径补全。
  • 扩展创作 - 支持取消的长时间运行操作,向诊断信息添加相关信息。

Insiders 版:想尽快体验新功能?您可以下载每晚更新的 Insiders 版,并尽快试用最新的更新。

编辑器

语法感知折叠

现在,HTML、JSON、Markdown、CSS、LESS 和 SCSS 中的折叠范围默认基于语言的语法计算,不再依赖于格式良好的缩进。

Syntax folding

也支持 TypeScript 和 JavaScript,可以通过设置 "typescript.experimental.syntaxFolding": true 启用。

如果您希望为上述一种(或所有)语言切换回基于缩进的折叠,请使用

  "[html]": {
    "editor.foldingStrategy": "indentation"
  },

提示: 查看如何在 Markdown 文件中折叠标题区域 时使用此功能。

提议了一个新的扩展 API proposed,以便其他语言也可以提供其语法感知折叠提供程序。

跨文件的错误和引用导航

在此版本中,通过 F8 (转到下一问题) 导航错误和警告时,会考虑所有报告的错误。它不会仅在一个文件内循环,而是会将您带到下一个包含错误的文件,然后再返回。

Visit All Diagnostics

类似地,还有一个新命令可以导航到引用搜索结果。在符号上触发查找所有引用,现在使用 F4⇧F4 (Windows, Linux Shift+F4) 访问每个引用。这非常有助于在引用符号的所有位置进行编辑,因为您的手指无需离开键盘。

Visit All References

编辑器中的提示

扩展 API 现在支持创建“提示”诊断。它们不是错误或警告,而是关于如何使某些内容变得更好的建议,例如,通过运行特定的重构。

我们在相关单词的开头下方使用省略号 ... 渲染提示诊断。

Hint Diagnostics

对于扩展作者来说,始终在代码操作中包含提示是一个好习惯,因为提示诊断有助于宣传代码操作。但是,有些用户可能不希望在编辑器中显示提示,因此也包含了禁用它们的支持。

提示: 在此版本中,我们为 JavaScript/TypeScript 重构 添加了多个提示。

扩展 API 现在支持向诊断信息添加相关信息,这些信息在显示诊断信息的所有位置显示:悬停时、错误速览窗口以及问题面板中。

在下面的示例中,您可以看到相关信息指出了一个被两次赋值的变量首次使用的位置

Related Diagnostics Information

更轻松地打开大文件

以前,在编辑器中打开大文件(约 2GB+)时,会提示您使用 --max-memory=NEWSIZE 标志从命令行重新启动。为了减少这种麻烦,当您尝试打开一个需要比应用程序当前允许使用的内存更多内存的文件时,将出现一个新的通知,让您可以快速重新启动应用程序,以便使用更多内存。重新启动后可用的最大内存可以通过新设置 files.maxMemoryForLargeFilesMB 进行配置,默认为 4096 (4GB)。

Large File Notification

语法高亮优化

在此版本中,打开文件后,我们将立即根据视口中内容的范围对视口进行语法高亮显示。这使得着色速度大大加快,如下所示,当用户使用转到定义命令打开新文件时。

: VS Code 1.21 : VS Code 1.22

Syntax highlighting optimization

大文件的查找和替换改进

我们在上一个版本中发布了一个新的文本缓冲区实现(请参阅我们的博客文章了解更多信息),并继续对大文件的查找和替换进行了优化。

可配置的保存时格式化超时

VS Code 可以在将文件保存到磁盘之前运行格式化程序,因此速度很重要,因为缓慢的扩展可能会减慢保存速度。因此,VS Code 对保存非常严格,并在 750ms 后取消格式化保存请求。对于某些扩展,特别是在处理大文件时,这时间不够,因此我们添加了一个新设置 "editor.formatOnSaveTimeout" 来配置超时。如果语言扩展知道格式化需要更多时间,则可以将其作为默认特定语言编辑器设置修改超时。

为了监控保存,现在状态栏上有一个进度指示器。

Save Participant

更多代码片段变量

有新的代码片段变量用于引用当前日期和时间。除了数字,例如 28/3/2018,您现在还可以使用诸如“三月 28 日”之类的名称。新变量是

  • ${CURRENT_DAY_NAME} - 星期名称(“Monday”)。
  • ${CURRENT_DAY_NAME_SHORT} - 星期简称(“Mon”)。
  • ${CURRENT_MONTH_NAME} - 月份全称(“July”)。
  • ${CURRENT_MONTH_NAME_SHORT} - 月份简称(“Jul”)。

Emmet

包裹缩写预览

当使用Emmet: Wrap with AbbreviationEmmet: Wrap Individual Lines with Abbreviation命令时,您现在可以预览包裹后的文本会是什么样子。

Wrap text with abbreviation preview

更快的缩写展开

现在,在大型 CSS/SCSS/Less 文件中展开 Emmet 缩写速度快得多。这是通过仅解析光标周围的小区域而不是整个文件来实现的,以此确定当前位置是否适合展开 Emmet 缩写。

更智能的代码片段匹配

样式表中的 Emmet 缩写与预定义代码片段进行模糊匹配,为您提供最接近的结果。您可以通过更改 emmet.preferences 中的 css.fuzzySearchMinScore 设置来控制模糊匹配的精度。css.fuzzySearchMinScore 设置了代码片段被视为匹配所需的最低得分。增加分数会产生更少但更准确的匹配。默认值为 0.3,您可以提供 0 到 1 之间的任何值。

"emmet.preferences": {
    "css.fuzzySearchMinScore": 0.3
}

工作台

Windows 上的自动后台更新

我们已经为 Windows 上的 Insider 用户推出了自动后台更新相当长一段时间了。我们决定在三月发布版本中为所有人启用此功能。

现在,运行时间最长的更新过程可以在您工作时在后台运行。准备就绪后,它应该通知您以应用最终更新,这是一个更短的步骤。这意味着在更新到最新的 VS Code 时,您可以继续工作更长时间!

如果您想恢复旧的行为,或者新更新过程在您的机器上存在问题,可以使用 update.enableWindowsBackgroundUpdates 配置设置禁用此功能。

Windows: 滚动延迟的权宜之计

我们收到了报告称,在某些设备上 Windows 的滚动非常卡顿且不流畅(详见问题 #13612)。作为平滑滚动的权宜之计,可以将新设置 window.smoothScrollingWorkaround 设置为 true。由于这是一种权宜之计,并且在您从任务栏恢复窗口时可能会导致闪烁,因此此设置默认未启用。如果您启用此设置,应该不会看到其他副作用。

启动 VS Code 时不带参数打开空窗口

引入了一个新设置 window.openWithoutArgumentsInNewWindow,用于控制在不带参数启动 VS Code 时是聚焦上次活动的实例还是打开一个新的空窗口。在 Windows 和 Linux 上,此设置默认启用,以更好地匹配平台行为。启用后,从桌面双击 VS Code 图标或从命令行不带参数运行 VS Code 将打开一个新的空窗口。在 Windows 上,当在中键单击或 Shift+单击任务栏图标时也是如此。通过将 window.openWithoutArgumentsInNewWindow 明确设置为 off 来禁用此行为。

搜索和替换时自动保存

替换所有搜索结果时,您不再需要全部保存全部关闭。替换操作现在将替换并保存更改。

搜索包含/排除模式

搜索视图中用于包含和排除模式的框已合并为一个框。功能完全相同,只是排除模式必须以 ! 为前缀。例如,!*.js 将跳过搜索 .js 扩展名的文件。

Combined search patterns inputs

树视图:水平滚动支持

有一个新的全局设置 workbench.tree.horizontalScrolling,它为工作台中的多个树控件启用了水平滚动。使用它可以更好地阅读较宽的树元素,例如文件资源管理器中深层的文件系统层次结构。

集成终端

跨越多行的路径和 URL 现在将作为链接工作。

Multiline terminal links

实现中仍然存在一些问题,尤其是在调整窗口大小时。这些问题将在我们实现重排时得到修复。

命令跟踪

终端现在具有“命令跟踪”功能,它试图猜测命令何时运行,并允许在它们之间轻松导航和选择。

Terminal command tracking

此功能在 macOS 上具有以下默认键绑定

  • 滚动到上一个命令: Cmd+Up*
  • 滚动到下一个命令: Cmd+Down*
  • 选择到上一个命令: Cmd+Shift+Up
  • 选择到下一个命令: Cmd+Shift+Down

* 注意: 向上/向下滚动一行已移至 Cmd+Alt+PgUp/Cmd+Alt+PgDown

在 Windows 和 Linux 上,您可以通过将此内容添加到 keybindings.json 文件中来为这些命令配置自定义键绑定

{ "key": "ctrl+down",       "command": "workbench.action.terminal.scrollToNextCommand",
                               "when": "terminalFocus" },
{ "key": "ctrl+up",         "command": "workbench.action.terminal.scrollToPreviousCommand",
                               "when": "terminalFocus" },
{ "key": "ctrl+shift+down", "command": "workbench.action.terminal.selectToNextCommand",
                               "when": "terminalFocus" },
{ "key": "ctrl+shift+up",   "command": "workbench.action.terminal.selectToPreviousCommand",
                               "when": "terminalFocus" },

更自然的滚动

现在,终端应用程序内部的滚动将感觉更自然,因为已考虑了定义按像素、按行或按页滚动的操作系统滚动设置。

使用 VS Code 作为 Git 编辑器后重新聚焦终端

当使用 VS Code 作为 Git 编辑器,并且从集成终端触发 Git 时,在完成消息后,焦点将返回到终端。

调试

日志点

此里程碑包括我们对日志点的首次工作。日志点是断点的一种变体,它不会“中断”到调试器,而是将消息记录到控制台。日志点对于在调试无法停止的生产服务器时注入日志记录特别有用。

日志点由一个“菱形”图标表示。日志消息是纯文本,但可以包含要在大括号(“{}”)内计算的表达式。

Logpoints

就像常规断点一样,日志点可以启用或禁用,并且也可以通过条件和/或命中计数进行控制。

日志点目前由 VS Code 内置的 Node.js 调试器支持,但我们预计其他调试扩展很快也会支持。

launch.json 中的 postDebugTask

我们在 launch.json 中添加了 postDebugTask 支持。此任务在调试会话结束后运行。与 preLaunchTask 类似,您可以通过名称引用 tasks.json 中的任务。以下是使用 postDebugTask 的启动配置示例

{
  "name": "Attach to node server",
  "type": "node",
  "request": "attach",
  "port": 8008,
  "preLaunchTask": "Start Server",
  "postDebugTask": "Stop Server"
}

Node 调试

自动附加到 Node.js 进程

VS Code 的 Node.js 调试器中添加了新功能自动附加的第一个版本。如果启用,Node 调试器会自动附加到从 VS Code 集成终端以调试模式启动的 Node.js 进程。

Auto Attach

要启用此功能,可以使用切换自动附加操作,或者如果 Node 调试器已激活,可以使用自动附加状态栏项。

进程是否处于“调试模式”是通过分析程序参数来确定的。目前,我们检测模式 --inspect--inspect-brk--inspect-port--debug--debug-brk--debug-port(所有这些后面可以选择跟随“=”和端口号)。

请注意,此功能尚不(完全)适用于像“tmux”这样的终端复用器(其中启动的进程不是 VS Code 集成终端的子进程)。

改进的进程选择器

在之前的版本中,Node.js 进程的进程选择器仅作为“交互变量”可用,可以在启动配置中使用。

在此版本中,我们将该选择器作为附加到 Node 进程操作提供,无需启动配置即可使用。

为了使选择器和新操作更有用,我们现在支持通过调试端口(除了通过进程 id 附加)附加到 Node.js 进程。

除了 Node.js 进程,选择器现在还显示了所有以各种形式的 --debug--inspect 参数启动的程序。这使得可以附加到 Electron 或 VS Code 的辅助进程。

Node.js Process Picker

选择器中列出的各个进程项除了进程 id 外,还显示调试端口和检测到的协议。

任务

改进的参数引用

任务已更新,让用户更好地控制在 bash 或 PowerShell 等 shell 中执行时如何引用参数和命令本身。shell 类型的任务现在支持分别提供命令及其参数。以下是一个任务示例,它列出了名为 folder with spaces 的文件夹的目录(注意名称中的空格)。

{
  "label": "dir",
  "type": "shell",
  "command": "dir",
  "args": ["folder with spaces"]
}

由于 shell 任务单独指定了参数,VS Code 知道它应该作为一个参数传递给 'dir' 命令,并根据使用的 shell 来引用参数。对于 cmd.exe,VS Code 使用 ";对于 PowerShell,使用 ';对于 Linux 和 macOS 下的 shell,也使用 '。如果您想控制参数如何引用,参数可以是一个字面量,指定值和引用样式。例如

{
  "label": "dir",
  "type": "shell",
  "command": "dir",
  "args": [
    {
      "value": "folder with spaces",
      "quoting": "escape"
    }
  ]
}

这将使用 shell 的转义字符对参数中的空格进行转义,在 PowerShell 下是反引号,在 bash 下是 \。如果使用的 shell 不支持字符转义,则使用强引用。

除了转义,还支持以下值

  • strong: 使用 shell 的强引用机制,该机制会抑制字符串内部的所有求值。在 PowerShell 以及 Linux 和 macOS 下的 shell 中,使用单引号 (')。对于 cmd.exe,使用 "
  • weak: 使用 shell 的弱引用机制,该机制仍会求值字符串内部的表达式(例如,环境变量)。在 PowerShell 以及 Linux 和 macOS 下的 shell 中,使用双引号 (")。cmd.exe 不支持弱引用,因此 VS Code 也使用 "

如果命令本身包含空格,VS Code 默认也会对命令进行强引用。与参数一样,用户可以使用相同的字面量样式控制命令的引用。

请注意,仍然支持将整个命令行放在 command 属性中的旧样式。

相同的支持也已添加到任务 API 中,因此任务提供程序也可以完全控制引用和转义。

语言

按标题级别折叠 Markdown

您现在可以按标题折叠 Markdown 文档

Markdown folding

折叠标题会折叠该标题下的所有内容和子标题。

TypeScript 2.8

VS Code 现在附带 TypeScript 2.8。此更新带来了对一些很棒的新语言特性的支持,以及许多重要的错误修复和工具改进。

改进的 JSDoc 中的快速建议

您知道 VS Code 为 JSDoc 类型提供 IntelliSense 吗?此功能在几个版本之前已添加,但您可能没有注意到,因为只有手动调用时 IntelliSense 才会显示。在 VS Code 1.22 中,JSDoc 类型中的快速建议现在默认启用。只需开始输入,IntelliSense 就会启动

JSDoc suggestions

JavaScript 和 TypeScript 的建议代码操作

我们还改进了 JavaScript 和 TypeScript 建议代码操作的可发现性。这些是提议的更改,可以帮助您快速改进或清理源代码。它们使用灯泡小部件显示,但与快速修复不同,它们不针对源代码中的特定错误或警告。示例建议代码操作包括:将 ES5 类转换为 ES6 类,以及将 CommonJS 模块转换为 ES6 模块。

建议代码操作现在在编辑器中以 ... 表示

Triple dots in the editor indicate a suggested Code Action

将光标移动到 ... 上并单击灯泡或按 ⌘. (Windows, Linux Ctrl+.) 以显示可用的代码操作

Hovering over a suggestion indicator

Clicking on the lightbulb

After applying the Code Action

我们计划继续添加更多建议。如果您有任何想看到的建议,请告知我们。

JavaScript 和 TypeScript 中的建议代码操作默认启用。您可以通过设置 "typescript.suggestionActions.enabled": false"javascript.suggestionActions.enabled": false 来禁用它们

CSS 路径补全

除了 HTML,现在 CSS 也提供了路径补全

CSS Path Completion

扩展创作

将长时间运行的操作显示为带取消支持的通知

我们添加了一个新的 API,用于在通知中心显示带可选取消支持的长时间运行操作。在此显示长时间运行操作的好处是

  • 多个操作可以同时报告进度。
  • 您可以显示操作进度。
  • 用户可以选择取消操作。

long running task

使用新的进度位置 ProgressLocation.Notification 调用 window.withProgress。将 cancellable 设置为 true 以显示取消按钮,并在回调中检查提供的 CancellationToken 是否取消。要显示进度,请在报告进度时利用 increment 值。有关使用此新 API 的扩展示例,请参见进度示例

我们添加了一个 API 来为诊断信息提供相关信息 - DiagnosticRelatedInformation。想象一下,一个变量名在同一范围内被重复使用而导致的编译器错误。实际错误可能是“不允许重复定义符号 'Foo'”,并指向非法声明。通过在诊断信息中包含相关信息,您还可以指向符号 'Foo' 的首次声明,从而使错误更容易理解和修复。

处理 CancellationTokenSource 不再将 token 设置为已取消状态

以前,在 CancellationTokenSource 上调用 dispose() 会将 token 设置为已取消并触发取消事件。我们更改了此行为,以便能够在不取消 token 的情况下处理它们。如果您依赖 token 的取消,请调用 cancel() 方法。

简单编辑器不传递给扩展

使用编辑器的输入(例如调试 REPL 输入)不再作为编辑器传递给扩展。这意味着当用户聚焦调试 REPL 时,onDidChangeActiveTextEditor 不会触发,并且 onDidChangeTextDocument 也不会触发。此更改背后的原因是 REPL 输入使用编辑器作为实现细节,扩展不应该收到此通知,因为它不是“真正的编辑器”。

自定义视图

TreeView

您现在可以使用新的 TreeView API 对自定义视图执行操作。通过提供 viewIdTreeDataProvider,可以使用新的 API createTreeView 访问此功能。

const customView = vscode.window.createTreeView<string>('customView', {
  treeDataProvider: new CustomViewDataProvider<string>()
});

注意:现有的 registerTreeDataProvider API 仍然支持向视图贡献数据。您可以使用 registerTreeDataProvidercreateTreeView 来贡献 TreeDataProvider,但不能同时使用两者。

Reveal

目前,TreeView 暴露了一个 reveal 方法来显示并选择视图中的项目。

customView.reveal('element');

默认情况下,要显示的项会被选中。为了不选择该项,请将 select 选项设置为 false。例如

customView.reveal('element', { select: false });

您可以在此处找到更多 TreeView 示例。

注意:要启用 reveal API,贡献的 TreeDataProvider 必须实现 getParent 方法。

新主题颜色

新的“提示”诊断有两种颜色

  • editorHint.foreground: 编辑器中提示的前景色。
  • editorHint.border: 编辑器中提示的边框颜色。

编辑器可见范围

编辑器可见范围 API 现在已升级为 Stable。

export interface TextEditor {
  /**
   * The current visible ranges in the editor (vertically).
   * This accounts only for vertical scrolling, and not for horizontal scrolling.
   */
  readonly visibleRanges: Range[];
}

export namespace window {
  /**
   * An [event](#_Event) which fires when the selection in an editor has changed.
   */
  export const onDidChangeTextEditorVisibleRanges: Event<TextEditorVisibleRangesChangeEvent>;
}

调试适配器协议

日志点支持

新引入的日志点在调试适配器协议中体现为一个新的属性 logMessage(在 SourceBreakpoint 上)和一个新的功能 supportsLogPoints。支持日志点的调试适配器会针对 supportsLogPoints 功能返回 true,并且对于非空的 logMessage 属性不会“中断”(停止),而是记录消息。大括号 ('{...}') 内的表达式会被计算,结果会替换日志消息中的 '{...}'。

initialize 请求的新 clientName 属性

前端可以使用 initialize 请求上的新可选属性 clientName 将前端的人类可读名称传递给调试适配器。

新的 terminateThreads 请求

前端可以使用新的 terminateThreads 请求来终止一个或多个线程。相应的 supportsTerminateThreadsRequest 功能表明调试适配器支持此请求。

新的 setExpression 请求

新的 setExpression 请求可用于为可赋值表达式(即“左值”)赋值。相应的 supportsSetExpression 功能表明调试适配器支持此请求。

stopped 事件的新 preserveFocusHint

stopped 事件上的 true 值 preserveFocusHint 建议前端停止事件不应改变焦点。

多选 QuickPick

我们在 QuickPick API 中添加了一个选项,该选项通过一个新的 UI 返回选定项目的列表,该 UI 允许用户选择任意数量的项目

Multi-select QuickPick

请参阅 QuickPickOptions.canPickMany 选项和 QuickPickItem.picked 标志,了解如何将它们与现有的 window.showQuickPick API 函数一起使用。

提议的扩展 API

在这个里程碑中,我们添加了几个新的提议的扩展 API。一旦我们对它们足够自信,我们计划在未来的里程碑中将这些 API 添加到稳定版中。我们欢迎您提供关于它们如何适用于您的扩展的任何反馈。

注意:这些 API 仍处于提议阶段,因此要使用它们,您必须通过向 package.json 添加 "enableProposedApi": true 来选择加入,并且您必须将 vscode.proposed.d.ts 复制到您的扩展项目中。另请注意,您不能将使用 enableProposedApi 属性的扩展发布到 Marketplace。

折叠提供程序 API

为了使扩展能够提供语言感知折叠范围,提议了一个新的提供程序 API

export namespace languages {
  /**
   * Register a folding provider.
   *
   * Multiple folding can be registered for a language. In that case providers are sorted
   * by their [score](#_languages.match) and the best-matching provider is used. Failure
   * of the selected provider will cause a failure of the whole operation.
   *
   * @param selector A selector that defines the documents this provider is applicable to.
   * @param provider A folding provider.
   * @return A [disposable](#_Disposable) that unregisters this provider when being disposed.
   */
  export function registerFoldingProvider(
    selector: DocumentSelector,
    provider: FoldingProvider
  ): Disposable;
}

请参阅此处的完整 API。

相应的 API 在此处作为语言服务器协议的协议扩展被提议。欢迎提供反馈!

任务 API

现在有一个新的任务 API,支持

  • 查询系统中所有现有任务。
  • 以编程方式执行任务。
  • 终止正在运行的任务。
  • 监听任务启动和结束事件。

提议的 API 可以在此处找到

新的 API 还支持在未通过任务提供程序返回任务的情况下执行任务。下面的示例执行一个简单的 echo 任务。

let task = new vscode.Task(
  {
    type: 'myCustomTask'
  },
  'echo',
  'myExtension',
  new vscode.ShellExecution('echo', ['Hello World'])
);
vscode.workspace.executeTask(task);

可维护性

您现在可以在 VS Code 中报告扩展相关问题。问题报告器现在包含一个下拉菜单,用于选择您是报告 VS Code 本身的问题还是扩展的问题。如果该扩展在 GitHub 上有仓库,则类似问题搜索和在 GitHub 上预览提交按钮将使用该仓库。

report on extensions

预览功能

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

组织 JavaScript 和 TypeScript 的导入

新的组织导入命令 () 会移除未使用的导入并对剩余的导入进行排序

Organize Imports

该命令适用于 JavaScript 和 TypeScript 的 ES6 模块。

Electron 2.0 探索

在这个里程碑中,我们探索了将 Electron 2.0.0 打包到 VS Code 中。这是一个 Electron 的重要版本,包含 Chrome 61 和 Node.js 8.x(相比于我们当前版本中包含的 Chrome 58 和 Node.js 7.x,这是一个重大飞跃)。我们计划在四月初向 Insiders 用户推出此更新,以收集更多反馈。如果您有兴趣提供帮助,请务必安装 VS Code Insiders 版本

重要变更

  • 13905:Windows:鼠标中键点击任务栏图标无法打开新窗口
  • 35675:Linux 上字体渲染看起来很难看
  • 36307:实验性文件监视器 - 在“循环”符号链接上占用大量 CPU
  • 42401:更智能地对输出通道进行分组
  • 42402:添加选项以在通道内显示日志
  • 43813:更新后扩展不完整
  • 44411:启动时因无法解析的变量而中止
  • 44554:允许拖放多个根文件夹
  • 45872:安装本地化包后提示用户更改 UI 语言
  • 45972:资源管理器:减少 isEqualOrParent 的调用次数

致谢

最后但同样重要的是,要向以下帮助使 VS Code 变得更好的人们表达诚挚的感谢!

vscode 的贡献

vscode-extension-vscode 的贡献

  • Danny Tuppeny (@DanTup):
    • 检查 code 可执行文件是否存在,而不仅仅是文件夹 (#_95) PR #95
    • 将 VS Code 放置在 .vs-test 的 insiders/stable 子文件夹中 (#_97) PR #97
    • 在 Windows 上不要每次都下载 Code (#_102) PR #102
    • 添加对 Mocha 的 forbidOnly 的支持 (#_103) PR #103

vscode-nls 的贡献

language-server-protocol 的贡献

vscode-css-languageservice 的贡献

vscode-html-languageservice 的贡献

node-jsonc-parser 的贡献

vscode-generator-code 的贡献

vscode-languageserver-node 的贡献

vscode-loader 的贡献

vscode-azurecli 的贡献

vscode-azure-account 的贡献

vscode-chrome-debug 的贡献

vscode-chrome-debug-core 的贡献

  • Chance An (@changsi-an)
    • 引入了遥测收集器。 PR #314
    • 引入了批量发送遥测事件的机制。 PR #292
    • 更改错误消息显示到 UI 的方式。 PR #303
    • 批量发送部分事件通知的遥测。 PR #300
  • @digeff
    • 添加缺失的 await PR #306
    • 在发送遥测之前,不要等待全局遥测属性就绪 PR #310
    • 向遥测添加版本信息 PR #307
    • 现在启动计时事件可以包含失败原因 PR #316
    • 现在我们为某些错误发送更多遥测信息 PR #319
    • 报告从启动到显示用户页面之间不同任务的时间 PR #301
    • 以句子大小写发送启动计时事件的所有遥测属性 PR #313
    • 修复一些无法解释的断点行为 PR #296
    • 使用 break on load 时,在 onScriptParsed 而非 onScriptPaused 时解析待处理断点 PR #290
  • Raghav Katyal (@rakatyal):清除上下文以避免发送多个移除事件… PR #318

vscode-node-debug2 的贡献

vscode-recipes 的贡献

localization 的贡献

这个月是 VS Code 在 Transifex 上启动社区本地化一周年,始于 2017 年 4 月 10 日。

  • Transifex VS Code 项目团队中有超过 800 名成员,每月约有 100 名活跃贡献者。
  • 通过社区贡献,我们已成功为国际用户发布了 9 种核心语言的每月更新。
  • 此外,还有 4 种语言完全由社区成员本地化,并作为语言包 VS Code 扩展发布。更多语言即将推出。
  • 感谢 VS Code 社区本地化贡献者!!!

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

  • 法语: Antoine Griffard, Adrien Clerbois, Smrman.
  • 意大利语: Alessandro Alpi, Piero Azi, Aldo Donetti, Simone Chiaretta, Emilie Rollandin, Francesco Mugnai.
  • 德语: Dejan Dinic, Jakob von der Haar, Carsten Kneip, Jakob, Ettore Atalan.
  • 西班牙语: Alberto Poblacion, José M. Aguilar, David Silva, Alejandro M, Andy Gonzalez, AlanThinks, David Triana, Santiago Porras Rodríguez, Carlos Mendible, Jorge Serrano Pérez.
  • 日语: Shunya Tajima, Yuichi Nukiyama, Hiroyuki Mori, Takashi Takebayashi, Seiji Momoto, yoshioms, Yuki Ueda, 小島 富治雄, Satoshi Kajiura.
  • 中文(简体): Joel Yang.
  • 中文(繁体): Duran Hsieh, Winnie Lin, Poy Chang, balduran, Will 保哥.
  • 韩语: ChangJoon Lee, Ian Y. Choi.
  • 俄语: Ivan, Andrei Makarov.
  • 保加利亚语: Любомир Василев.
  • 匈牙利语: Tar Dániel.
  • 葡萄牙语(巴西): Roberto Fonseca, Matheus Palu, Rodrigo Crespi, Danilo Dantas, Douglas Ivatiuk Martim, Alessandro Fragnani, Kayky de Brito dos Santos.
  • 葡萄牙语(葡萄牙): Diogo Barros, Ruben Mateus, António Lourenço, João Mata, Gustavo Silva.
  • 土耳其语: Adem Coşkuner, Ömer Büyükçelik, Mustafa Turhan, Tuğrul Kaşıkcı.
  • 波斯尼亚语: Bahrudin Hrnjica, Muharem Basanovic, Ismar Bašanović, Almir Vuk.
  • 捷克语: Michal Vondracek, Vít Staniček, Filip Vlček, Vojtěch Habarta, Ferdinand Prantl.
  • 荷兰语: Maurits Kammer, Gerald Versluis, Marco van den Hout.
  • 芬兰语: Feetu Nyrhinen, Petri Niinimäki.
  • 希腊语: Dimitris Trachiotis.
  • 印度尼西亚语: Joseph Aditya P G, Najih Azkalhaq, Adrian M. R., Wildan Mubarok, G-RiNe Project, Lundy Orlando, Azhe-kun, Febrian Setianto, Riwut Libinuko, Laurensius Dede Suhardiman, Mulia Arifandi Nasution, Herman Prawiro.
  • 拉脱维亚语: Pēteris Kļaviņš, Simone Chiaretta, kozete, Lafriks.
  • 立陶宛语: Martynas Jusys.
  • 波兰语: Patryk Brejdak, Joanna Skurzyńska, Paweł Sołtysiak, KarbonKitty.
  • 塞尔维亚语: Марко М. Костић, Nikola Radovanović.
  • 瑞典语: Joakim Olsson, Kalle Wallin, Johan Hedén.
  • 泰语: Sirisak Lueangsaksri, Phongphan Bunlom, ภูมิไผท จันทรศรีวงศ์.
  • 乌克兰语: Андрій Іванченко, R.M., Max Plotitsyn, Svitlana Galianova.
  • 越南语: Hung Nguyen.