Prettierとの違い
Prettierとの間にいくつかの相違点が存在します。
Prettierは有効なJavaScript識別子である一部のオブジェクトプロパティの引用符を外しません
Section titled Prettierは有効なJavaScript識別子である一部のオブジェクトプロパティの引用符を外しませんPrettierとBiomeは、有効なJavaScript識別子であるオブジェクトおよびクラスプロパティの引用符を外します。 Prettierは、特にES5において有効な識別子のみ引用符を外します。
ES2015が広まっている現在のエコシステムにおいて、これは古い制限です。 そのため、私たちはES2015以降の全ての有効なJavaScript識別子の引用符を外すことにしました。
プロジェクトが使用するECMAScriptバージョンを設定するための設定を導入することは可能な解決策かもしれません。 そのバージョンに基づいて引用符を外す動作を調整できます。 ECMAScriptのバージョンをES5に設定することで、Prettierの挙動に一致させることができます。
入力
差分
Prettierは計算プロパティでの代入で一貫性のない挙動を示します
Section titled Prettierは計算プロパティでの代入で一貫性のない挙動を示しますPrettierとBiomeは、特に条件文などで代入式を括弧で囲みます。 これにより、Biomeは比較式であるべきコードを識別できます。
Prettierは、オブジェクトの計算プロパティでの代入では括弧を追加する一方で、クラスの計算プロパティではそれを行いません。以下の例で示されます:
入力
差分
一貫性を保つために、私たちはPrettierのフォーマットに合わせることなく括弧を省略することにしました。 代替案としては、オブジェクトまたはクラスの計算プロパティでの代入を常に括弧で囲むことができます。
Prettierは必要ない場合でもアロー関数の型パラメータに末尾のカンマを追加します
Section titled Prettierは必要ない場合でもアロー関数の型パラメータに末尾のカンマを追加します特定のケースでは、JSX要素と区別するために、アロー関数の型パラメータリストに末尾のカンマが必要となります。 型パラメータにデフォルト値が提供されている場合、末尾のカンマは必要ありません。 ここでは、必要な場合にのみ末尾のカンマを追加するというPrettierの元々の意図を尊重するために、現在のフォーマットの差分を受け入れました。
入力
差分
Prettier は、括弧で囲まれた non-null アサーションを含むオプショナルチェーンに対して一貫性のない動作をします
Section titled Prettier は、括弧で囲まれた non-null アサーションを含むオプショナルチェーンに対して一貫性のない動作をしますTypeScript では、non-nullアサーション演算子 !
を使用して、値がnullでないことをアサートできます。
オプショナルチェーンに適用される場合、アサーションは括弧の存在に関係なくチェーン全体に適用されます。つまり、(a.?.b)!
と a.?.b!
は同じ結果になるはずです。
Prettierは、先のコード例をどちらも適切にフォーマットされているとみなします。つまり、括弧の有無は維持され、コードを正規化しようとしません。
さらに、Prettierは、括弧がnon-nullアサーション演算子を囲んでいる場合でもかっこを削除しません。代わりに、演算子を括弧の外に移動します。
入力
差分
Prettierは無効な構文をフォーマットします
Section titled Prettierは無効な構文をフォーマットしますJavaScriptおよびTypeScriptのためにPrettierで利用されているBabelパーサの解析は厳密なものではなく、いくつかの構文エラーを無視 することがあります。 Biomeのパーサは、Prettierのパーサよりも厳密に構文を解析します。 たとえば、以下の構文エラーを正確に識別します:
- 関数には重複する修飾子を持つことはできません
- プロパティの修飾子を無効な順序で指定することはできません
- 関数宣言では関数の処理を定義することができません
- 抽象クラス以外で抽象プロパティを持つことはできません
- オプショナルチェーンに代入することはできません
- インターフェースの型パラメータに
const
修飾子を設定することはできません - トップレベルの
return
Prettierでは、これらのエラーを構文エラーとして扱わず、適切なノードでASTが “正しく” 構築されます。 そして、これらのノードを通常通り扱い、フォーマットします。
Biomeでは、構文エラーはBogus
ノードとして扱います。Bogus
ノードは、有効なノード、無効なノード、生の文字などを含みます。
フォーマット時、Biomeはbogusノードを事実上のプレーンテキストとして扱い、そのまま出力します。これは、フォーマットを試みることでコードの意図を変更してしまう恐れがあるためです。
Prettierのパーサは、クラスプロパティの修飾子に対してブール値のフィールドを使用します。これは、各種類の修飾子が1つしか存在できないことを意味します。(アクセス修飾子は単一の文字列として格納されます)。 フォーマットの時には、ブール値のリストを見て、どの修飾子を再び出力するかを決定します。一方、Biomeは修飾子のリストを保持し、重複を含めて解析が可能になります(これが重複修飾子や順序に関する解析エラーを報告できる理由です)。 不正な修飾子を含むbogusノードをフォーマットする際は、修飾子のリストはそのまま維持され、不正なテキストをそのまま出力します。
Biomeでは、この問題に対処するいくつかの方法があります。 その1つとしては、フォーマット時にBogusなノードを解釈し、有効なノードを構築する方法があります。 有効なノードが構築できれば通常通りそのノードをフォーマットし、そうでない場合は現在のように不正なテキストをそのまま出力します。 しかし、これを実装するのは少し大変で、フォーマッタに意味のないロジックを導入することになります。
別の方法としては、意味論的なエラー(重複修飾子、抽象クラス以外での抽象プロパティの使用)を受け入れる “syntactically-valid bogus node(文法的に不正確なノード)” をパーサに導入する方法もあります。
これにより、通常通りノードを構築しつつ(Prettierの挙動と一致させつつ)、新しい種類のbogusノードに構文解析の情報を含めて格納します。
フォーマット時には、特定のbogusノードでは内部ノードをフォーマットしようと試み、エラーが発生した場合はフォールバックします(既存の format_or_verbatim
ユーティリティがこれを行っています)。
これにより、パーサとフォーマッタのロジックを分離しつつ、無効な状態を半有効とみなすような複雑なロジックをパーサに実装することが可能になります。
クラスプロパティの重複する修飾子
Section titled クラスプロパティの重複する修飾子入力
差分
差分
インターフェイスの型パラメータに対する誤った修飾子
Section titled インターフェイスの型パラメータに対する誤った修飾子入力
差分
トップレベルのreturn
Section titled トップレベルのreturn誤った self-increment と self-decrement
Section titled 誤った self-increment と self-decrement入力
抽象クラスでないクラスでの abstract
修飾子の使用
Section titled 抽象クラスでないクラスでの abstract 修飾子の使用入力
差分