JavaScript/TypeScriptの高速フォーマッター「Rome Formatter」リリース。Rust製でPrettierより約10倍高速と

2022年4月18日

JavaScriptのツールチェインを統一的に提供することを目指した「Rome Tools, Inc.」(以下、Rome Tools)は、JavaScriptおよびTypeScriptのコードの書式を高速に整えるフォーマッター「Rome Formatter」をリリースしました。

Rome Toolsは、フォーマッターや構文チェッカー、トランスパイラ、バンドラーなどの多数のツールを組み合わせて開発環境を構築することが求められる現在のJavaScript開発環境において、これらの機能をすべて統合した1つのツールを提供し、JavaScriptの開発環境を統一してしまおうという野心的な「Rome」プロジェクトを推進しています。

参考:JavaScriptツールチェインの統一を目指す「Rome」開発チームが起業、「Rome Tools, Inc.」を立ち上げ

開発はオープンソースで行われており、今回リリースされたのは、このRomeから最初のツールとして登場したソフトウェアです。

単体で利用可能なRome Formatter

Romeプロジェクトは前述の通り、さまざまなJavaScriptツールの統一的な提供を目指していますが、Romeプロジェクトを構成するツールは単独でも利用可能になります。

今回リリースされたRome Formatterも、コマンドラインから単独で利用できるほか、Visual Studio Codeの拡張機能としても利用可能です。

Rome Formatterの特徴は、高速性、エラーへの耐性、既存のフォーマッタとして普及しているPrettierとの互換性の3つが挙げられます。

Rust製で高速実行、Prettierと比較して9~12倍高速

高速性については、Rust言語を採用することによる効果に加えて、開発初期段階からツールの高速性を意識した開発を進めているとしています。これらの要素により、既存のフォーマッターであるPrettierと比較して9倍から12倍前後高速であるとしています。

下記はRomeの開発チームが、ESLint、Webpack、TypeScriptのソースコードをPrettierとRome Formatterでそれぞれフォーマッティングした場合の速度を比較したグラフです。

fig

エラーのある行以降もフォーマッティング継続

エラー耐性については、従来のフォーマッターではコードに構文エラーなどがある場合、それ以降のフォーマットが正しく行われないことが多いのに対し、Rome Formatterではエラーの行以降も極力正常なフォーマットが行われるようにパーサを開発したとのことです。下記は「Announcing Rome Formatter」からの引用です。

We put a lot of work into building an error tolerant JavaScript/TypeScript parser that could quickly recover from errors, and then extending our formatter to work on this broken code.

私たちはエラーから迅速に回復できるエラー許容型のJavaScript/TypeScriptパーサーを構築し、壊れたコードにも対応できるようフォーマッターを拡張することに、多くの労力を費やしました。

そしてRome Formatterは既存のフォーマッターとしてPrettierが広く使われていることを認識した上で、Prettierのフォーマットルールを可能な限り取り入れたとしています。

ただしルールの完全互換は保証しておらず、今後フォーマットの違いをドキュメント化する予定だとしています。

Rome Formatterは現在のところJavaScriptとTypeScriptのフォーマットにのみ対応していますが、今後はHTML、CSS、JSONなどを含むWeb開発におけるさまざまな言語へも対応するべく拡張されるとともに、Rome Formatterに続く新たなツールの登場も予定されているとのことです。

あわせて読みたい

JavaScript プログラミング言語




タグクラウド

クラウド
AWS / Azure / Google Cloud
クラウドネイティブ / サーバレス
クラウドのシェア / クラウドの障害

コンテナ型仮想化

プログラミング言語
JavaScript / Java / .NET
WebAssembly / Web標準
開発ツール / テスト・品質

アジャイル開発 / スクラム / DevOps

データベース / 機械学習・AI
RDB / NoSQL

ネットワーク / セキュリティ
HTTP / QUIC

OS / Windows / Linux / 仮想化
サーバ / ストレージ / ハードウェア

ITエンジニアの給与・年収 / 働き方

殿堂入り / おもしろ / 編集後記

全てのタグを見る

Blogger in Chief

photo of jniino

Junichi Niino(jniino)
IT系の雑誌編集者、オンラインメディア発行人を経て独立。2009年にPublickeyを開始しました。
詳しいプロフィール

Publickeyの新着情報をチェックしませんか?
Twitterで : @Publickey
Facebookで : Publickeyのページ
RSSリーダーで : Feed

最新記事10本