在 VS Code 中试试

2019 年 8 月 (版本 1.38)

更新 1.38.1:本次更新解决了这些 问题

下载:Windows:x64 | Mac:Intel | Linux:deb rpm tarball snap


欢迎来到 Visual Studio Code 2019 年 8 月发布版本。此版本中有许多我们希望您会喜欢的更新,其中一些主要亮点包括

如果您想在线阅读这些发行说明,请访问 code.visualstudio.com 上的更新页面。

Insiders 版本: 想尽快体验新功能吗?您可以下载每夜构建的 Insiders 版本,并在最新更新发布后立即试用。要获取最新的 Visual Studio Code 新闻、更新和内容,请在 Twitter 上关注我们 @code

工作台

搜索和替换中保留大小写

在 1.37 版本中,我们在编辑器的查找/替换控件中添加了保留大小写选项。现在,在全局搜索和替换中,该选项也作为 AB 图标提供。

对于连字符分隔的单词,还有一种新的大小写保留模式。

Preserve Case button in search

更新的取消搜索图标

运行长时间搜索时,我们更新了用于取消搜索的图标,使其更好地表示该操作。

Cancel search icon

字符串数组设置的验证

如果当前值不满足指定的 minItemsmaxItemsitem.enumitem.pattern 模式,设置编辑器现在会显示字符串数组项的错误。

String of array error validation

VS Code 现在在打开出站链接之前显示提示。

Link protection prompt

您可以直接打开链接或信任特定域以绕过此提示。通过配置受信任域按钮或命令,您可以为特定域或所有出站链接启用/禁用链接保护。

资源管理器改进

顶级资源创建

我们改进了在资源管理器中创建顶级文件和文件夹的过程。现在有三种方法可以在文件资源管理器根目录中创建文件或文件夹

  • 滚动到最后一个元素之外,以便在空白区域调用上下文菜单。
  • 按下 Escape 键会清除资源管理器中的焦点和选择,从而使标题区域的操作在资源管理器根目录上执行。
  • 在滚动条上使用上下文菜单。

打开文件并保留焦点

现在可以从资源管理器中预览打开文件,同时保持焦点在资源管理器中。新命令是 filesExplorer.openFilePreserveFocus,默认情况下,可以通过 Space 键触发它。

资源管理器文件命名

有一个新设置 explorer.incrementalNaming 用于控制重复文件命名,其值可以是 simplesmart

  • simple - 在重复名称的末尾附加单词“copy”,可能后跟一个数字。这是 VS Code 当前稳定版本的行为。
  • smart - 在重复名称的末尾添加一个数字。如果名称已经是数字的一部分,则递增该数字。

最大化编辑器切换命令

一个新的命令切换编辑器组大小 (workbench.action.toggleEditorWidths) 将在最大化活动编辑器组和平均分配编辑器组宽度之间切换。

工作台的网格布局

工作台的布局引擎已重写,使用与编辑器区域本身相同的网格组件。这项工作已经进行了一段时间,过去几个迭代的 Insiders 版本默认启用了此功能。该设置是 workbench.useExperimentalGridLayout,现在将默认启用。

切换编辑器区域 / 最大化面板

新引擎为未来的工作台布局提供了更大的灵活性。目前,这体现在隐藏编辑器区域的能力上。网格布局提供了一个新命令切换编辑器区域,它将隐藏编辑器区域并允许面板(例如“输出”或“调试控制台”)填充布局。切换最大化面板命令也具有相同的效果。这意味着最大化的面板现在真正实现了最大化,而不再有之前编辑器左侧的微小间隙。

您可以在下方看到最大化的集成终端

Maximized panel

如果您尝试从面板或侧边栏等任何位置打开文件,编辑器将自动重新出现。

隐藏单个 macOS Touch Bar 条目

一个新的设置 keyboard.touchbar.ignored 可以选择性地从 macOS Touch Bar 中移除 VS Code 命令。VS Code 默认添加以下命令

  • workbench.action.navigateBack
  • workbench.action.navigateForward
  • workbench.action.debug.start
  • workbench.action.debug.run
  • workbench.action.debug.continue
  • workbench.action.debug.pause
  • workbench.action.debug.stepOver
  • workbench.action.debug.stepInto
  • workbench.action.debug.stepOut
  • workbench.action.debug.restart
  • workbench.action.debug.stop

新的编辑器组上下文键

有两个新的 when 子句上下文用于有条件地绑定键盘快捷键

  • activeEditorGroupIndex - 一个从 1 开始的数字,反映编辑器网格中编辑器组的位置。索引为 1 的组将是左上角的第一个组。
  • activeEditorGroupLast - 对于编辑器网格中的最后一个编辑器组,其值为 true

注意:有关 when 子句上下文的完整列表,请参阅 when 子句上下文参考

辅助功能改进

在此里程碑中,我们继续修复辅助功能问题。亮点包括

  • 单词导航现在遵循 NVDA 和 VoiceOver 的预期。在编辑器中使用单词导航时,会正确宣布单词。
  • Windows 放大镜工具现在可以在编辑器中跟随光标。

截屏模式

截屏模式(开发者:切换截屏模式)进行了一些改进

  • 现在对截屏模式键绑定标签的长度设置了限制。
  • 键绑定标签的垂直位置可以通过 screencastMode.verticalOffset 设置进行调整。
  • 可以通过 screencastMode.onlyKeyboardShortcuts 设置配置键绑定标签,使其仅渲染实际的键盘快捷键。
  • 键盘快捷键的渲染样式得到了改进。

编辑器

光标周围行数 (scrollOff)

现在,您可以通过设置 editor.cursorSurroundingLines 来自定义当光标移向文件开头或结尾时,光标周围显示的可见行数。在 Vim 编辑器中,此功能称为 scrollOff

Cursor surrounding lines

查找中的多行搜索

编辑器查找控件现在支持多行文本搜索和替换。通过按下 Ctrl+Enter,您可以在输入框中插入新行。

Multi-line search in the editor

内联差异编辑器中的复制和还原

使用内联差异编辑器时,现在提供了复制或还原已删除内容的新操作。将鼠标悬停在内联差异编辑器中已删除的内容上,您现在可以

  • 复制整个已删除的内容
  • 复制特定行
  • 还原更改

Diff actions

“转到行”支持负行号

您现在可以在转到行选取器中输入负行号,以便从文件末尾导航。例如,输入 -1 将显示文件的最后一行。

全局搜索小地图装饰

小地图(代码概览)现在显示文件内搜索和全局搜索的结果。

集成终端

在 terminal.integrated.cwd 中使用变量时改进的 fallback 行为

当在 cwd 设置中使用变量时,例如

"terminal.integrated.cwd": "${fileDirname}"

当变量无法解析时,终端现在会记录错误到控制台并回退到工作区目录,而不是抛出错误。

自动化 shell 设置

除了为集成终端设置 shell 外,您现在还可以为自动化(例如任务)指定 shell。如果您使用 tmux 作为 shell,这将特别有用,因为它不适用于所有自动化。

"terminal.integrated.shell.osx": "/Users/user/bin/tmux_script"
"terminal.integrated.automationShell.osx": "bash",

语言

HTML 和 CSS 的 MDN 参考

VS Code 现在在 HTML 和 CSS 实体的补全和悬停中显示指向相关 MDN 参考的 URL

HTML & CSS MDN Reference

我们感谢 MDN 文档团队为整理 mdn-data / mdn-browser-compat-data 并使 VS Code 易于访问 MDN 资源所做的努力。

改进的 Less 支持

VS Code 现在支持许多新的 Less.js 功能,包括根函数、映射查找和匿名混入。

非标准和过时 CSS 属性的弃用标记

CSS 语言服务器采用了 弃用标签实验性 API,并在自动补全中为标记为 nonstandardobsolete 的 CSS 属性显示弃用标记。

CSS deprecated properties

TypeScript 3.6

VS Code 现在捆绑了 TypeScript 3.6.2。此主要更新带来了一些 TypeScript 语言改进,包括更严格的生成器import.meta 的支持,以及一些针对 JavaScript 和 TypeScript 的新工具功能。一如既往,此版本还包括许多重要的错误修复。

您可以在TS 3.6 博客文章中阅读有关 TypeScript 3.6 功能的更多信息。

添加缺失的 await 快速修复

您的代码是否有点超前了?新的添加 'await' 快速修复可帮助您 await 在异步代码中可能遗漏的值

Detect missing calls to await in JavaScript using @ts-check and Quick Fix them

此快速修复适用于已启用类型检查的 TypeScript 和 JavaScript 源代码。

JavaScript 和 TypeScript 中分号感知的编辑

当您在 JavaScript 或 TypeScript 源代码中添加 import 或应用重构时,VS Code 现在会尝试根据文件中现有代码推断是否包含分号

No semicolons

您可以在添加此功能的 pull request 中找到有关此分号检测工作方式的详细信息。一些快速修复和重构仍然不具备分号感知能力,但我们将在未来的更新中努力解决这个问题。

JSDoc 注释不再合并用于 IntelliSense

以前,如果多个 JSDoc 注释出现在定义之前,我们的 JavaScript 和 TypeScript IntelliSense 会将它们合并。在下面的示例中,请注意 User 类型的文档如何与 getUser 函数的文档合并

Older TS versions merged multiple JSDoc comments

使用 TypeScript 3.6,我们的 IntelliSense 现在仅使用紧邻其前的 JSDoc 注释来获取文档和类型信息

TS 3.6 only uses the immediately preceding JSDoc comment

源代码管理

Git: Commit 输入中显示分支名称

当前 Git 分支名称现在显示在 commit 输入框中,以避免在错误的分支上提交

Git branch name in input box

Git: 按字母顺序排序分支列表

有一个新的 git.branchSortOrder 设置,用于在使用Git: Checkout to... 命令切换分支时更改分支的排序顺序。

Git: 支持取消拉取

启用 git.supportCancellation 设置后,您将有机会取消正在进行的 Git Pull 请求,这在从慢速远程仓库拉取时非常有用。

调试

值改变时中断(数据断点)

在“变量”视图中,现在可以创建数据断点,当基础变量的值改变时,这些断点会被命中。与其他断点一样,数据断点可以在“断点”视图中禁用/启用和移除。

Data breakpoints

请注意,数据断点需要底层运行时或调试器的特定支持,我们预计未来只有少数调试扩展(如 C++ 和 C#,但不包括 Node.js)会选择支持此功能。在此版本中,只有我们的示例调试器 Mock Debug 会“模拟”数据断点。

调用堆栈视图改进

我们对“调用堆栈”视图进行了一些改进,其中最显著的是

  • 当调试会话只有一个线程时,我们将始终隐藏线程并直接显示调用堆栈。
  • 在“调用堆栈”视图中点击线程和调试会话不再会展开/折叠它们。只有显式点击展开/折叠图标才会进行展开。进行此更改的原因是,在不进行不需要的展开的情况下更改焦点会话是很麻烦的。在我们的“大纲”视图中也可以看到相同的行为。
  • 以前,当有一个新的调试会话时,“调试”视图会获得焦点。现在,只有当会话实际中断时,“调试”视图才会获得焦点。
  • 调试会话元素仅在实际存在该会话的线程时显示展开/折叠图标。

启动调试目标的新 shell 设置

在集成终端中启动调试目标时,VS Code 现在尊重新的“自动化 shell”设置 (terminal.integrated.automationShell...)。如果您为集成终端使用特定的默认 shell(例如 tmux),并且该 shell 在启动调试目标时不适用于自动化,则此设置非常有用。

"terminal.integrated.shell.osx": "/Users/user/bin/tmux_script"
"terminal.integrated.automationShell.osx": "bash",

对扩展的贡献

帮助 webview 扩展添加内容安全策略

我们发现一些创建Webviews 的扩展没有内容安全策略。虽然这不构成直接问题,但所有 webview 都应该有一个内容安全策略,这是良好的安全最佳实践。在此迭代中,我们已开始针对这些扩展提交问题,让他们意识到此建议。

如果您有兴趣让您日常使用的一些扩展更安全一点,请查看VS Code 问题 #79340 并提交 PR 来帮助他们。

GitHub Pull Requests

在此里程碑中,我们继续改进 GitHub Pull Requests 扩展,包括 bug 修复和功能,例如合并 pull request 后删除分支和远程仓库。有关更多详细信息,请参阅我们的8 月里程碑计划

远程开发 (预览)

远程开发扩展的工作仍在继续,这些扩展允许您使用容器、远程机器或 适用于 Linux 的 Windows 子系统 (WSL) 作为功能齐全的开发环境。

为了帮助您开始使用远程开发扩展,有三个入门教程

您还可以阅读最近一篇描述使用 WSL 和 Visual Studio Code 进行 Linux 开发的技巧和诀窍的博客文章。

1.38 中的功能亮点包括

  • VS Code 稳定版预览支持 Alpine Linux 容器、Alpine WSL 发行版以及 ARMv7l / AArch32 SSH 主机。
  • VS Code Insiders 实验性支持 ARMv8l / AArch64 SSH 主机。
  • 开发容器的改进,包括新的容器资源管理器!

您可以在远程开发发行说明中了解新的扩展功能和 bug 修复。

扩展开发

VS Code 图标库

我们发布了一个包含所有VS Code 图标的仓库,供扩展作者使用。每个图标都有深色/浅色版本,我们还链接到了我们的Figma 设计文件

VS Code icons

Webview.asWebviewUri 和 Webview.cspSource

webview 上有两个新属性

  • Webview.asWebviewUri - 将本地文件系统的 URI 转换为可在 webview 中使用的 URI。

    对于桌面版 VS Code,这将把 file: URI 转换为 vscode-resource: URI。

  • Webview.cspSource - webview 资源的内容安全策略源。

    对于桌面版 VS Code,这将是字符串 vscode-resource:

const panel = vscode.window.createWebviewPanel(
  CatCodingPanel.viewType,
  'Cat Coding',
  vscode.ViewColumn.One,
  {
    // Restrict the webview to only loading local content from our extension's `media` directory.
    localResourceRoots: [vscode.Uri.file(path.join(extensionPath, 'media'))]
  }
);

const imagePath = vscode.Uri.file(path.join(extensionPath, 'media'));

panel.html = `<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="Content-Security-Policy" content="default-src 'none'; img-src ${
      panel.webview.cspSource
    } https:;">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Cat Coding</title>
</head>
<body>
    <img src="${panel.webview.asWebviewUri(imagePath)}/cat.gif" width="300" />
</body>
</html>`;

创建没有内容安全策略的 webview 时发出警告

在开发使用Webview API的扩展时,如果您创建的 webview 没有设置内容安全策略,我们现在会记录警告。

Debug warning for a webview that lacks a CSP

所有 webview(即使是非常简单的)都应该设置内容安全策略。这有助于限制内容注入的潜在影响,通常是纵深防御的良好措施。我们已在Webview 扩展指南中记录了如何向 VS Code webview 添加内容安全策略。

机器特有的可覆盖设置

您现在可以使用作用域 machine-overridable 定义机器特有的设置,该设置可以在工作区和文件夹级别被覆盖。

"configuration": {
  "title": "My Extension Settings",
  "properties": {
   "myextension.libPath": {
      "type": [
        "string",
        "null"
      ],
      "markdownDescription": "Specify the path to the library.",
      "default": null,
      "scope": "machine-overridable"
    }
  }
}

自定义树视图中的多选

通过 createTreeView 贡献的树现在可以将 canSelectMany 选项添加到 TreeViewOptions<T> 中。这使得贡献的树视图支持多选,并导致对树元素运行的命令在第二个命令参数中接收所有选定的树元素作为数组。

markdown.api.render

VS Code 内置 Markdown 扩展中的新命令 markdown.api.render 接受 Markdown stringvscode.TextDocument,并返回渲染为 HTML 的 Markdown

import * as vscode from 'vscode';

export function activate(context: vscode.ExtensionContext) {
  vscode.commands.executeCommand('markdown.api.render', '# Hello Markdown').then(result => {
    console.log(`rendered markdown: ${result}`);
  });
}

日志

rendered markdown: <h1 id="hello-markdown" data-line="0" class="code-line">Hello Markdown</h1>

自定义数据标记为稳定

2019 年 1 月 1.31 版本中作为实验性功能引入的自定义数据格式现已标记为稳定。

  • html.experimental.customData - 此设置已弃用,由 html.customData 取代。
  • css.experimental.customData - 此设置已弃用,由 css.customData 取代。
  • contributes.html.experimental.customData - 此贡献点已弃用,由 contributes.html.customData 取代。
  • contributes.css.experimental.customData - 此贡献点已弃用,由 contributes.css.customData 取代。

您可以在 microsoft/vscode-custom-data 的文档和示例中了解如何使用自定义数据格式增强 VS Code 的 HTML/CSS 语言支持。

已弃用的 workspace.rootPath

当我们添加对多根工作区的支持时,我们弃用了 workspace.rootPath API,转而推荐使用 workspace.workspaceFoldersworkspace.getWorkspaceFolder。我们注意到许多扩展仍然使用此 API,尽管它在多根工作区中无法正常工作。如果您拥有使用此 API 的扩展,请更新它,因为我们将来可能会移除此 API。您可以在 采用多根工作区 API wiki 页面上找到有关弃用 rootPath 的更多详细信息。

调试适配器协议

补全建议改进

调试适配器现在可以使用新功能 completionTriggerCharacters 来声明前端 UI 应该使用哪些字符来触发 REPL 或调试控制台中的补全建议 UI。如果没有指定,前端 UI 应使用 '.' 字符来触发建议 UI。

此外,我们还为 CompletionItem 类型添加了一个可选的 sortText 属性。使用此属性,调试适配器可以控制前端 UI 如何对适配器返回的补全建议进行排序。如果缺少该属性,前端可能会根据 label 属性对项目进行排序。

修复了 DAP JSON 模式中的类型问题

调试适配器协议 JSON 模式中,我们在浮点类型没有意义的地方(例如 ID)将类型指定符 number 更改为 integer

提议的扩展 API

每个里程碑都会带来新的提议 API,扩展作者可以试用它们。一如既往,我们非常期待您的反馈。以下是试用提议 API 需要做的事情

  • 您必须使用 Insiders 版本,因为提议的 API 经常更改。
  • 您的扩展的 package.json 文件中必须有这一行:"enableProposedApi": true
  • 将最新版本的 vscode.proposed.d.ts 文件复制到您的项目中。

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

符号和补全的弃用标签

补全和文档/工作区符号的 API 现在支持将项目标记为已弃用。补全和符号有一个新的可选属性 tags,它是一组 CompletionItemTagSymbolTag。目前仅支持弃用标记,但计划添加更多标记,例如用于访问修饰符和其他修饰符的标记。

以下代码片段显示了一个最小的补全项提供者,它渲染一个标记为已弃用的项目。

vscode.languages.registerCompletionItemProvider('plaintext', {
  provideCompletionItems() {
    const item = new vscode.CompletionItem('deprecated_completion');
    item.tags = [vscode.CompletionItemTag.Deprecated];
    return [item];
  }
});

显示已弃用的补全或符号时,会在名称上绘制删除线,项目会稍微变暗,并且不显示高亮。

Deprecated items in smart completions

Pseudoterminal.onDidClose 现在接受一个数字

提议的 Pseudoterminal.onDidClose 已从 Event<void> 更改为 Event<void | number>,允许扩展作者指示终端或 CustomExecution2 任务失败。

移除已弃用的提议终端 API

已移除弃用的 TerminalOptions.runInBackgroundcreateTerminalRenderer API。如果您需要从这些 API 迁移,应分别使用 TerminalOptions.hideFromUser(稳定)和 ExtensionTerminalOptions(提议)。

新命令

我们现在公开了一些命令,用于在编辑器、集成终端、扩展详细信息视图和 Webview 的查找控件中导航搜索结果。

按键 命令 命令 ID
Enter 在编辑器中查找下一个结果 editor.action.nextMatchFindAction
⇧Enter (Windows, Linux Shift+Enter) 在编辑器中查找上一个结果 editor.action.previousMatchFindAction
⇧Enter (Windows, Linux Shift+Enter) 在集成终端中查找下一个结果 workbench.action.terminal.findNext
Enter 在集成终端中查找上一个结果 workbench.action.terminal.findPrevious
Enter 在扩展详细信息视图中查找下一个结果 editor.action.extensioneditor.findNext
⇧Enter (Windows, Linux Shift+Enter) 在扩展详细信息视图中查找上一个结果 editor.action.extensioneditor.findPrevious
Enter 在 Webview 中查找下一个结果 editor.action.webvieweditor.findNext
⇧Enter (Windows, Linux Shift+Enter) 在 Webview 中查找上一个结果 editor.action.webvieweditor.findPrevious

重要修复

  • 26012: 自动插入括号与补全交互不佳,导致字符重复
  • 47292: 任务创建的诊断信息对扩展不可访问
  • 73884: Linux: 从 FTP 连接打开的文件显示为空白
  • 75054: macOS 简单全屏功能恢复正常
  • 77293: 在 provideDebugConfigurations 和 resolveDebugConfigurations 中尊重 CancelationToken 以取消调试
  • 77735: 如果后面有 RenameFile 操作,workspace.applyEdit 会丢弃 TextEdit
  • 77747: 文件名中包含 $(xx) 时在文件夹视图中显示不正确
  • 77990: 启动时打开 TS/JS 文件比打开其他文件慢得多
  • 77996: 文件 > 另存为 会将光标移动到文件开头
  • 78147: 配置任务操作应显示新添加的任务并将光标定位在那里
  • 78179: 使用类型过滤器调用 'tasks.fetchTask()' 会获取所有任务
  • 79478: 高亮显示 markdown 文件中的自定义 html 标签
  • 79704: 支持 JSDoc 中的 @example <caption>
  • 79763: 编辑器:可以关闭所有编辑器,即使有未保存的更改
  • 79798: 编辑器:设置 workbench.editor.revealIfOpen 为 true 时,组未激活
  • 78046: SCM: 支持对文件暂存选定的更改,感谢 Darrien Singleton (@OneThatWalks)PR #78562 中的贡献
  • 79625: 为 "preLaunchTask" 结构提供代码补全

感谢

最后但同样重要的是,向以下帮助改进 VS Code 的朋友们致以崇高的感谢!

vscode 的贡献

对我们的问题跟踪的贡献

如果您想帮助我们管理接收到的问题,请查看我们的社区问题跟踪页面。

vscode-css-languageservice 的贡献

vscode-html-languageservice 的贡献

vscode-eslint 的贡献

language-server-protocol 的贡献

debug-adapter-protocol 的贡献

vscode-loader 的贡献

vscode-recipes 的贡献

对本地化的贡献

超过 800 位Cloud + AI 本地化社区成员正在使用 Microsoft 本地化社区平台 (MLCP),其中约 100 位是 Visual Studio Code 的活跃贡献者。我们感谢您的贡献,无论是提供新的翻译、对翻译投票,还是提出流程改进建议。

这是贡献者的快照。有关项目详情,包括贡献者姓名列表,请访问项目网站:https://aka.ms/vscodeloc

  • 波斯尼亚语: Ismar Bašanović, Ernad Husremovic.
  • 保加利亚语: Hristiqn Hristov, Иван Иванов, Любомир Василев, Gheorghi Penkov.
  • 捷克语: Tadeáš Cvrček, Daniel Padrta, David Jareš, Jan Hajek, Jakub Stibůrek, Michal Franc, Jan Kos, Radim Hampl, Jiří Hofman, Samuel Tulach, Jan Brudný.
  • 丹麦语: René Pape, Lasse Stilvang, Allan Kimmer Jensen, Lars Vange Jørgensen, Alexander Matzen, Martin Liversage, Johan Fagerberg, Thomas Larsen, Anders Lund, Anton Ariens.
  • 荷兰语: Leroy Witteveen, Laurens Kwanten, Pieterjan De Clippel, Maxim Janssens, Luc Sieben, Hans Zoons, Jos Verlinde, Eric Algera, Damien van Gageldonk, Maxim Van Damme, Sven Klaasen, Tom Meulemans, Sujith Quintelier.
  • 英语(英国): Martin Littlecott, Alexander Ogilvie, Tobias Collier, William Wood, Cloud Sky, Fabio Zuin, Mohit Nain, sonali Dixit, Dan Jacobs, Giorgi Jambazishvili, Sulkhan Ninidze, alshyab wa3ed, YASHU MITTAL, Tejas kale, Mohammad Idrees, Chris Dias.
  • 芬兰语: Petri Niinimäki, Kiti Suupohja, Lasse Leppänen, Sebastian de Mel, Riku Riikonen, Valtteri Vatanen.
  • 法语: Griffard, Thierry DEMAN-BARCELÒ, Corwin D'Ambre, Mohamed Sahbi, Rodolphe NOEL, Maxime Coquerel, Steven Dugois, Cédric M., Michael VAUDIN, Bastien Boussouf, Alicia lic, francois-joseph du fou, franto, DJ Dakta.
  • 德语: Julian Pritzi, Joscha Mathis, Jan Widmer, Jakob von der Haar, Frank Lindecke, Dejan Dinic, Florian Erbs, Patrick Burke, Mario Koschischek, Florian Berger, Christof Opresnik, Hans Meiser, Carsten Kneip, Ettore Atalan, Thorsten Hans, Meghana Garise, Sebastian Seidl.
  • 希腊语: Δημήτρης Παπαϊωάννου, Sotiris Koukios-Panopoulos, Jim Spentzos, Θοδωρής Τσιρπάνης, Stratos Kourtzanidis, Charalampos Fanoulis, John D, Stavros Papadakis, Vassilis Vouvonikos.
  • 希伯来语: חיים לבוב, Shalom Craimer, Matan Amos, Eyal Ellenbogen, Snir Broshi, Kyle Orin.
  • 印地语: Satish Yadav, Amit Gusain, Sanyam Jain, Abhirav Kushwaha, Ashok Kumar Rathore, nirav adatiya, Rajeev Desai, shaswat rungta, Kumar Vaibhav, Pramit Das, Jagjeet Singh, Pratishek PII, Kiren Paul, Chethana S, Piyush Sonagara, KRISHNA TANDON, Kishan K, Dhanvi Kapila.
  • 匈牙利语: Levente Borbély, Péter Nagy, Alex Kiss, Levente Hallai Seiler, Dániel Tar, Richard Borcsik, Boldi Kemény.
  • 中文(简体): Tingting Yi, 斌 项, paul cheung, 建东 薛, Yiting Zhu, feiyun0112 feiyun0112, Justin Liu, Yizhi Gu, Joel Yang, 刘瑞恒 刘瑞恒, Edi Wang, Junzhe Liu, Dave Young, 张锐, Fan Su, 昊宇 周, Pluwen, Tony Xia, Yu Zhang, XIANG ZUO, 少民 谈, 彦佐 刘, Zhiqiang Li, 志乐 龚, 福永 叶, G.Y. Z, Hao Hu, meng shao, Horie Yuan, Xiangrui Kong, 王文杰, Liam Kennedy, 赵畅畅, Charles Lee, 松阳 樊, anson zhang, Young Bige, Shi Liu, Wang Debang, Jarvis Jiang, Lin ai, Jessica Zhang, Licheng Ren, , 驰 雷, sun qing, xiong Fu, Lynne Dong, zhao yu, 吉姆 舒, 红东 黄, 剑秋 陶, 游 尤, Hanlin Yang, bh wu, Bravo Yeung, Michael Zhang, Hanyu ZHANG, Y F, WangCG duoduobear, 越 郑, ziqiang sun, 正元 刘, Jiang LI, 擎 钟, peng wei, 涛 徐, 逍遥 许, 瑜 周, WL, 伟 全, rsy iridescent, Simon Chan, 海龙 黄, 仁松 陈, Jieting Xu, panda small, 翼 张, Chen Yang, Wang Weixuan, Ludi Fang, 舜杰 杨, 建 周, cuibty wong, 立飞 李, 雨齐 刘, 涛 罗, 九鼎 谭, LI ZHAO.
  • 中文(繁体): 謝政廷, Yi-Jyun Pan, Winnie Lin, LikKee 沥祺 Richie, Martin Lau, salagadoola _, 牧村 蔡, Jeremy, 小克, 煾 雪.
  • 印度尼西亚语: Jakka Prihatna, Septian Adi, Arif Fahmi, Laurensius Dede Suhardiman, Bakhtiar Amaludin, Heston Sinuraya, Riwut Libinuko, Hendra Widjaja, Rachmat Wahidi, Franky So, Bervianto Leo Pratama, Eriawan Kusumawardhono, Rifani Arsyad, Afnizar Nur Ghifari, Pradipta Hendri, Christian Elbrianno, Azhe Kun.
  • 意大利语: Alessandro Alpi, Bruni Luca, Luigi Bruno, Andrea Dottor, Riccardo Cappello, Moreno Bruschi, Aldo Donetti, andrea falco, Emanuele Meazzo, Michael Longo, Marco Dal Pino.
  • 日语: EbXpJ6bp -, nh, Kyohei Uchida, Takayuki Fuwa, Yoshihisa Ozaki, Hasefumi, TENMYO Masakazu, Michihito Kumamoto, Koichi Makino, Aya Tokura, Seiji Momoto, Yosuke Sano, Makoto Sakaguchi, Kyohei Moriyama, 裕子 知念, Rie Moriguchi, Fujio Kojima, 美穂 山本, taniokae, 太郎 西岡, Kazuya Ujihara, Hiroomi Kurosawa, Yasuaki Matsuda.
  • 韩语: Hongju, 우현 조, Jong Heun Shin, 형섭 이, Kyunghee Ko, Youngjae Kim, siin lee, Jae Yong Kum, Hoyeon Han, Kevin Lee, SeungJin Jeong, Hong Kwon.
  • 拉脱维亚语: Kaspars Bergs, Andris Vilde.
  • 立陶宛语: Andrius Svylas, Augustas Grikšas, Tautvydas Derzinskas, Karolis Kundrotas, Martynas J..
  • 挪威语: Andreas Rødland, Cookius Monsterius, Dag H. Baardsen, Ole Kristian Losvik, Stephan Eriksen, Agnethe Seim Olsen.
  • 波兰语: Warchlak, Wojciech Maj, Marcin Weksznejder, Rafał Całka, Tomasz Świstak, Tomasz Wiśniewski, Marek Biedrzycki, Szymon Seliga, Michal Szulc, Jakub Żmidziński, Bartek PL, Igor 05, Rafał Wolak, Tomasz Chojnacki, Piotr Grędowski, Czech Kaczmarek, Artur Pelczar, Marcin Floryan, Paweł Modrzejewski, Jakub Jedryszek, Michał Stojke, Artur Zdanowski.
  • 葡萄牙语(巴西): Marcondes Alexandre, Alessandro Trovato, Marcelo Fernandes, Roberto Fonseca, Albert Tanure, Judson Santiago, Junior Galvão - MVP, Ray Carneiro, Lucas Miranda, Rodrigo Crespi, Thiago Dupin Ugeda, Renan Miguel, Weslei A. de T. Marinho, Rafael Lima Teixeira, Eduardo Moura, Gerardo Magela Machado da Silva, Bruno Talanski, Bruno Sonnino, Loiane Groner, Marcos Albuquerque, Jucinei Pereira dos Santos, Emmanuel Gomes Brandão, Fábio Corrêa, Flávio Albuquerque Camilo, Pablo Garcia, Alessandro Fragnani, Andrei Bosco, Daniel Luna, José Rafael de Santana, Douglas Ivatiuk Martim, Giuliano Reginatto, Marcos Dias, Alan William, Lucas Nunes, Gabriel Schade, Lucas Santos, arthurdenner ., Mauricio Lima, Igor Felix, Gabriel Barbosa, Fabio Lux, Guilherme Pais, Victor Cavalcante, Letticia Nicoli, Becky Marques, Fernando Val, Milton Camara, Saymon Damásio, Felipe Scuissiatto, Rodrigo Vieira, Djonathas Cardoso, André Gama, Gustavo Bezerra, Cynthia Zanoni, Marcelo Guerra, Jhonathan Soares, Rafael Laranja, Swellington Soares.
  • 葡萄牙语(葡萄牙): Ana Rebelo, Nuno Carapito, Pedro Daniel, Pedro Teixeira, João Carvalho, Diogo Barros, José Rodrigues, Sandro Pereira, Vitor Barbosa, Tiago Antunes, Daniel Correia.
  • 罗马尼亚语: Mihai Marinescu, Stefan Gabos, Dragos Marinescu, Alexandru Staicu.
  • 俄语: Andrey Veselov, Дмитрий Кирьянов, netf0rger, michael v, Иван Лещенко, nata kazakova, Анатолий Калужин, Валерий Батурин, Эдуард Тихонов.
  • 塞尔维亚语: Milos Zivkovic, Radovan Skendzic.
  • 西班牙语: Andy Gonzalez, Ricardo Estrada Rdez, Carlos Mendible, Alvaro Enrique Ruano, Engel Aguilar, José María Aguilar, David Fernández Aldana, Ricardo Rubio, Thierry DEMAN, Gabriel Perez, julian3xl, Adolfo Jayme, Ing. Sergio Uziel Tovar Lemus, Mario Mendieta, Jorge Serrano Pérez.
  • 瑞典语: Johan Spånberg, Notetur Nomen.
  • 泰米尔语: Kondasamy Jayaraman, Merbin J Anselm, Jeyanthinath Muthuram, Mani M, Boopesh Kumar, Vignesh Rajendran, Jaganathan B, Nithun Harikrishnan, Purusothaman Ramanujam, கருணாகரன் சமயன், Krishna Pravin, Jeffin R P, Sakthi Raj, Vetri ., Ranjith kumar.
  • 土耳其语: mehmetcan Gün, Meryem Aytek, Fıratcan Sucu, Anıl Mısırlıoğlu, Mehmet Yönügül, Ahmetcan Aksu, Ömer Sert, Sinan Açar, Misir Jafarov, Umut Can Alparslan, Yakup Ad, Hüseyin Fahri Uzun, Murat Pala, S. Ferit Arslan, Mesut Pişkin, Okan Çetin, Bruh Moment, Muhammed Emin TİFTİKÇİ, Burak Göksel.
  • 乌克兰语: Dmytro Kutianskyi, Yaroslav, Max Harasym, Arthur Murauskas, Sviatoslav Ivaskiv, George Molchanyuk, Did Kokos, Alexander Varchenko, Вадим Шашков, Евгений Коростылёв.
  • 越南语: Khôi Phạm, Van-Tien Hoang, Việt Anh Nguyễn, Belikhun, Spepirus Shouru, Vuong Bui, Chủ Tất, Poon Nguyễn.