Slide 1

Slide 1 text

1 Biome is for JavaScripters @unvalley_ We are JavaScripters

Slide 2

Slide 2 text

About me - unvalley - A core contributor of Biome - TypeScript / Rust / Scala @unvalley_ unvalley 2

Slide 3

Slide 3 text

Biome - One toolchain for your web project - パフォーマンスに優れたRust製のWebツールチェーン - Analyzer / Linter / Formatterを提供(CLIとLSPで利用可能) - 採用事例が増えている Vercel (v0.dev)・Sentry (javascript-sdk)・ant-design, etc - Prettierと約97%の互換性(対象はJS, TS, JSX のフォーマット) - 181のLintルールを実装(ESLint, typescript-eslintなどからの移植や固有のもの) 3 Rome Biome

Slide 4

Slide 4 text

技術的な哲学 - エラーに対して、可能な限り修正提案・ヒントを示す - エラーメッセージを具体的にする - 専門用語の利用を減らす - コマンドやフラグの命名には冗長性をもたせる - 包括的な用語を利用する(差別的な用語を使わない) など他 https://biomejs.dev/internals/philosophy/ 4

Slide 5

Slide 5 text

Biomeを試す 5 - npm, yarn, pnpm, deno, bunで利用できます - Homebrewでもインストール可能:brew install biome - 業務で使ってるプロジェクトやOSSなどで試してみてください - Docs : https://biomejs.dev - Playground : https://biomejs.dev/playground npx @biomejs/biome check --apply . // format and lint with npx

Slide 6

Slide 6 text

最近のアップデート - 🌎:ドキュメントの翻訳(󰏦・󰎩・󰐨) - 🤝:スポンサーの獲得(時雨堂・KANAME・個人) - 🎆:Prettier Challenge の達成 - ⚙:v1.4.1のリリース - 🌟:5.4k スター - 🎨:ウェブサイトのリブランディング 6

Slide 7

Slide 7 text

日本コミュニティの貢献 7 日本コミュニティはBiomeの普及を信じてくれている。 過去数週間で彼らはステップアップし、我々はコードと寄付による多くの貢 献を受けた。ありがとう!

Slide 8

Slide 8 text

Prettier Challenge : Write a pretty printer in Rust 8 Vjeux(Co creator of Prettier)・Guillermo Rauch(Vercel CEO)・ WASIX・napi-rs によるBountyプログラム。

Slide 9

Slide 9 text

Prettier Challengeで得られたもの - Bounty - 新規コントリビュータ - 多くのコントリビュータがPrettier Challengeに参加した - @faultyserver, @TaKO8Ki がメンバーになった - Formatterのオプションに対する方向性 - https://biomejs.dev/formatter/option-philosophy/ - Prettierとは異なるフォーマットの判断(Divergence) - https://biomejs.dev/formatter/differences-with-prettier/ 9

Slide 10

Slide 10 text

Biomeの開発 10

Slide 11

Slide 11 text

Rust Part 11 - CSTによるError ResilientなParser実装 - RustによるAnalyzer / Linter / Formatterの実装 - CLI / VS Code Extension - WASMによるWeb Playground 他いろいろ

Slide 12

Slide 12 text

Web Part 12 - 対応言語(JavaScript / TypeScript / JSX / JSON / CSS)の仕様 - 対応言語の既存Lint実装 - (ESLint / typescript-eslint, eslint-plugin-jsx-a11y etc) - 対応言語の既存Formatter実装 (Prettier) 他いろいろ

Slide 13

Slide 13 text

Lint Rule実装の雰囲気:noSvgWithoutTitle 13

Slide 14

Slide 14 text

自分の最初の貢献(2022-11-03) Rust初心者だったけど、Formatterの修正タスクをやってみた ここから関わり始めた 14

Slide 15

Slide 15 text

開発のためのドキュメント 15 - CONTRIBUTING.md : https://github.com/biomejs/biome/blob/main/CONTRIBUTING.md - 開発に関する情報のハブ - @ematipicoによるParserとFormatterの解説動画のリンクなどもあります - Analyzer and Linter : https://docs.rs/biome_analyze/latest/biome_analyze/ - Parser : https://docs.rs/biome_parser/latest/biome_parser/ - JS Formatter: https://docs.rs/biome_js_formatter/latest/biome_js_formatter/

Slide 16

Slide 16 text

We seek contributors:参加方法はいろいろ 16 - コードコントリビューション(機能追加・バグ修正等)をする - ウェブサイトのデザインアイデアを投げる・実装する - GitHub DiscussionやDiscordでアイデアを投げる・議論する・解決する - 他の利用者の質問に回答する - スポンサーになる Good First Issueがなくても、タスクは作れます(特にLintルール)。 興味があれば、気軽にDiscordやGitHub Discussionなどで、お声がけください。 自分ももっとBiomeの内部でも他のOSSでも、色々と幅を広げていきたい。