Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Building markdown editor using Rust’s parser
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
HiroyukiYagihashi
November 27, 2021
Technology
2.6k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Building markdown editor using Rust’s parser
HiroyukiYagihashi
November 27, 2021
More Decks by HiroyukiYagihashi
See All by HiroyukiYagihashi
2024年度SecHack365 アシスタントを囲む会
yagipy
0
90
LLMの活用方法と課題
yagipy
0
300
What is Soft Memory Limit?
yagipy
1
710
簡易的な推薦機能を実装する
yagipy
0
160
GitHub oneliner command
yagipy
0
110
Other Decks in Technology
See All in Technology
AWSシリコン最前線 〜AI時代のチップ選択を読み解く〜
htokoyo
2
460
FDE という解 ― 暗黙知と明示知をつなぐ、伴走型エンジニアリング ―
otanet
0
130
エンジニアリング戦略の作り方 / Crafting Engineering Strategy
iwashi86
20
6.6k
RAG を使わないという選択肢
tatsutaka
1
190
非エンジニアがClaudeと挑んだ「1ヶ月間プロダクト30本ノック」
askokc
0
330
AIソロプレナー時代に2ヶ月で20人増員した事業創造会社の開発組織の話
miyatakoji
0
600
AGENTS.mdとSkillsで始めるAIエージェント活用
sonoda_mj
3
200
AmazonRoute 53ではじめてのドメイン取得!HTTPS化までの道のりを整理してみた
usanchuu
3
130
AI-DLCを活用した高品質・安全なAI駆動開発実践 / AI Driven Development with AI-DLC
yoshidashingo
0
170
攻撃者視点で考えるDetection Engineering
cryptopeg
1
1.2k
中期計画、2回作ってみた ~業務委託と正社員、両方の視点から~
demaecan
1
680
チームで進めるAI駆動アジャイル×ウォーターフォール
kumaiu
0
150
Featured
See All Featured
Design in an AI World
tapps
1
240
How GitHub (no longer) Works
holman
316
150k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.7k
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Designing Experiences People Love
moore
143
24k
KATA
mclloyd
PRO
35
15k
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
180
Bioeconomy Workshop: Dr. Julius Ecuru, Opportunities for a Bioeconomy in West Africa
akademiya2063
PRO
1
140
Six Lessons from altMBA
skipperchong
29
4.3k
Rebuilding a faster, lazier Slack
samanthasiow
85
9.5k
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
62
54k
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
420
Transcript
Building markdown editor using Rust’s parser @yagipy JS Conf JP
2021
自己紹介 @yagipy(Hiroyuki Yagihashi) - 所属: からくり株式会社/エンジニア - TypeScript/Next.jsでフロントエンドや、 Go/Node.jsで APIサーバー、AWSでインフラ構築、Figmaでデザイン作成、
Java/KotlinでAndroid等 - エンジニア募集中です - Twitter: @yagipy_ - GitHub: @yagipy - Blog: https://blog.yagipy.me
本セッションのゴール - wasmのユースケースの一部を理解できるようになる - Rustのコードからwasm pkgを生成できるようになる - wasm pkgをReactで使用できるようになる -
マークダウンエディタが構築できるようになる
本セッションで話すこと - 作ったもの - アーキテクチャ - アーキテクチャのモチベーション - フロントエンド複雑化の流れ -
問題点 - 解決策 - 実装の紹介 - Rustのライブラリをwasm pkg化する - wasm pkgをdependenciesに追加する - wasm pkgをロードするReact Hookを定義する - 定義したReact Hookを呼び出す - まとめ
作ったもの
https://editor.yagipy.me - 3種類のプレビュー形式に対応 - デフォルト - マインドマップ - スライド -
3種類のレイアウトに対応 - 2カラム(textarea,preview) - textareaのみ - Previewのみ - 本セッションでは、デフォルト/スライドで使用しているRustコード(マー クダウンパーサー)をReactで使用するまでのアーキテクチャを紹介します
アーキテクチャ
RustコードがReactアプリで使用できるまで Reactアプリ wasm pkg Rustコード wasm-pack import マークダウンパー サー tsの型定義
Jsのラッパー wasm
アーキテクチャのモチベーション
前提: フロントエンド大規模化の流れ - ロジックがフロントエンドに寄ってきている - 主なメリット: 無駄な通信の削減、サーバーリソースの削減 - よりユーザーの近くで計算した方が良い -
エッジコンピューティングやフォグコンピューティングの流れ - サーバーに戻そう、という動きもあるにはあるが ...(React Server Components等)
問題点 - サーバーに書いていた処理をフロントエンド用に書き直す必要がある - 今までサーバーサイドはデータストアの役割に加えて、共通ロジックの置き場所として働い ていたがそうではなくなってきている
解決策 - 色々ある - blitz, Kotlin Multiplatform, wasm, etc.. -
様々な言語の資産を活用したい場合はwasmが選択肢に入る - 今回は、実験としてRustのコードをwasmにしてWeb上で使用するという実 装を行った
実装の紹介
1. Rustのコードをwasm pkg化する 2. wasm pkgをdependenciesに追加する 3. wasm pkgをロードするReact Hookを定義する
4. 定義したReact Hookを呼び出す RustコードをReactアプリで使用するまでの手順
Rustのコードをwasm pkg化する - wasm-packを使用 - wasm_bindgen + package.json等を出力(npm publishする場合にスムーズに対応でき る)
- wasm_bindgen: #[wasm_bindgen]アトリビュートを付けた関数の wasmとJavaScript のラッパーとTypeScriptの型定義を生成する - https://developer.mozilla.org/ja/docs/WebAssembly/Rust_to_wasm#buildi ng_the_package use pulldown_cmark::{html, Options, Parser}; use wasm_bindgen::prelude::*; #[wasm_bindgen] pub fn pulldown_cmark(source_text: &str) -> String { // ~~~ 省略 ~~~ html_output }
wasm pkgをdependenciesに追加する - package.jsonのdependenciesに追加 - 直接/pkgのパスを指定する形でも可能 { "dependencies": { "markdown-parser":
"file:./markdown-parser/pkg" } }
wasm pkgをロードするReact Hookを定義する - wasmを含んだJavaScriptは動的に読み込む必要があるので、その読み込み を待ってrerenderする import { pulldown_cmark }
from 'markdown-parser' export interface IPullDownCmark { pulldown_cmark: typeof pulldown_cmark } export const usePullDownCmark = () => { const [state, setState] = useState<IPullDownCmark | null>(null) useEffect(() => { (async () => { const wasmContainer = await import('markdown-parser') setState(wasmContainer) })() }, []) return state }
定義したReact Hookを呼び出す - 作成したHookを呼ぶ - wasm_bindgenした関数が呼べる interface IProps { text:
string } export const DefaultPreview = ({ text }: IProps): ReactElement => { const instance = usePullDownCmark() return ( <div dangerouslySetInnerHTML={{ __html: instance?.pulldown_cmark(text) ?? '', }} /> ) }
まとめ
まとめ - wasm-packを使用することで、簡単にRustで書いたコードをWeb上で使用 できた - その他のwasmがサポートされている言語のコードも、wasmを介することで Web上で使用できるようになるため、既存の言語資産をWeb上で使用できる
Thank you for listening!