首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

RSLint:使用Rust开发的JS Linter,可以解析错误代码

Riccardo D’Ambrosio最近发布了RSLint,一个完全用Rust开发的JavaScript linter。RSLint力求尽可能快、可定制和易于使用。RSLint仍处于开发的早期阶段,主要特色是与Visual Studio Code的集成。

RSLint的作者是这样描述他的动机的:

这是一个成熟的JavaScript linter,只是用Rust从头开始开发。我觉得现有的linter功能太有限,速度太慢,于是决定尝试自己开发一个,并带有一些自己的想法: 速度:文件加载、文件检查和规则运行都是并行的; rustc风格且友好的错误信息(包括标签、注释); 错误恢复:不管多离谱的源代码可以检查; …… 更强大的指令。

与其他linter一样,RSLint努力帮助开发人员实施良好的实践,并标记编程错误、bug、风格错误和可疑的代码。linter通常在代码编辑器中用于在编辑时提供实时反馈。使用了大量lint规则的大型代码库的用户可以从更快的实时反馈中获得开发速度方面的好处。

类似地,当lint规则提示错误时,特别是当规则很复杂或引用了其他几个语法实体时,友好的解释性错误消息可以帮助开发人员增长经验。

D’Ambrosio强调了RSLint的错误恢复能力,据称已知的linter不具备这个能力:

错误恢复是指解析器能够接受不正确的源代码,并且仍然能够解析出基本正确的AST(抽象语法树)。大多数linter根本不会这么做,例如,espree和swc_ecmascript(分别是ESLintdeno_lint的解析器)不会尝试进行错误恢复。当解析器遇到错误时,它们返回一个Err结果并停止解析,不生成AST……这意味着linter不可能检查错误的代码,如果能在IDE中实现这个功能,将是很惊人的。

RSLint可以解析这样的代码:

if true {
  /* */
} else {
  /* */
}

然后检查它:

error[SyntaxError]: Expected token `L_PAREN` but instead found `TRUE_KW`
  ┌─ tests\main.js:1:4
  │
1 │ if true {
  │    ^^^^ Unexpected
error[SyntaxError]: Expected token `R_PAREN` but instead found `L_CURLY`
  ┌─ tests\main.js:1:9
  │
1 │ if true {
  │         ^ Unexpected
error[no-constant-condition]: Unexpected constant condition
  ┌─ tests\main.js:1:4
  │  
1 │   if true {
  │      ^^^^ this condition is always truthy...
2 │     /* */
3 │   } else {
  │ ┌────────'
4 │ │   /* */
5 │ │ }
  │ └─' ...which makes this unreachable

D’Ambrosio回顾了该项目的初期想法:

但是请注意,rslint_parser仍处于早期开发阶段,并且错误恢复有时会有很多bug,但是在将来会变得更好。

RSLint速度的提升不仅是因为使用Rust开发(编译成机器码),也因为它使用了并行执行和特定的数据结构(不是传统的AST)。RSLint使用了为Rust分析器项目开发的rowan库。rowan生成的语法树是不可变的,而不是克隆成本很高的可变AST。

RSLint提供了一些指令,在检查代码时可以忽略一些文件,或者在某些情况下(rsLint-ignore)忽略特定的lint规则。RSLint目前实现了大约25条规则(例如,no-async-promise-executorno-await-in-loop或者no-dupe-keys),未来还将计划实现更多规则。开发人员可以编写自定义规则。不过,文档中提到,自定义规则必须用Rust宏来编写——这可能给JavaScript社区贡献内容造成了障碍。

RSLint是用其他语言开发可编译为原生代码的JavaScript工具这一新兴趋势的一部分。InfoQ之前曾报道过用Go语言开发的JavaScript打包器esbuild。swc是一个基于Rust的JavaScript/TypeScript编译器。缩短JavaScript工具的反馈周期、利用开发者机器强大的多核功能以及对原始性能的追求推动了这一趋势。

然而,使用compile-to-native编程语言来编写代码并不是实现高吞吐量的唯一方法。通过减少自动化任务的作用范围,也可以提升工具的速度。在去年的一些基准测试中,JavaScript/TypeScript编译器Sucrase击败了基于Rust的swc编译器。然而,Sucrase只针对开发构建,并做了一些限制性的假设(例如,不支持Node 6或Internet Explorer)。

JavaScript社区的一些成员在Reddit上表达了对RSLint的乐观态度。一个用户提到:

这太棒了!虽然还处于早期阶段,但它很出色,我们期待看到这个项目更多的进展!

另一篇文章列举了要让社区采用需要满足的一些特性:

看起来不错。我希望能加快代码检查的速度。为了能够在工作中使用,它要非常成熟而且功能完善,并在一定程度上保证项目的维护。

RSLint目前正处于开发的早期阶段。RSLint路线图包括基准测试、作用域分析、自动修复、JSX和TypeScript支持、JavaScript插件,等等。已知的问题文档可以在网上找到。

RSLint采用了MIT开源许可。开发者可以通过该项目的GitHub存储库参与贡献或拉取请求。

原文链接

RSLint, a New, Fast JavaScript Linter Written in Rust

  • 发表于:
  • 本文为 InfoQ 中文站特供稿件
  • 首发地址https://www.infoq.cn/article/y8vNSq2PLELORGEH3Q1g
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券