Slide 1

Slide 1 text

@unvalley_ Biome is for JavaScripters 1

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

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

Slide 8

Slide 8 text

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

Slide 9

Slide 9 text

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

Slide 10

Slide 10 text

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

Slide 11

Slide 11 text

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

Slide 12

Slide 12 text

Biomeの開発 12

Slide 13

Slide 13 text

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

Slide 14

Slide 14 text

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

Slide 15

Slide 15 text

Lint Rule実装の雰囲気:noSvgWithoutTitle 15

Slide 16

Slide 16 text

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

Slide 17

Slide 17 text

開発のためのドキュメント 17 - 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 18

Slide 18 text

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