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
型を書かないRuby開発への挑戦
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Shia
March 02, 2026
Technology
0
39
型を書かないRuby開発への挑戦
「型を書かなくても十分有用な型情報を得られる」を目標に開発中の LSP「type-guessr」について話します。
完全さを諦めることでいい感じの体験を目指します。
Shia
March 02, 2026
Tweet
Share
More Decks by Shia
See All by Shia
ひとつの開発環境
riseshia
0
64
Conquering Massive Traffic Spikes in Ruby Applications with Pitchfork
riseshia
0
290
スパイクアクセス対策としての pitchfork 導入
riseshia
0
810
NewEngineering 2024 - 繋がっていくサービスを支える開発環境作り
riseshia
0
1.6k
Hotspot on Coverage
riseshia
0
260
差分ベースで効率的にテストを実行してみる
riseshia
1
770
Cookpad internship 2020 summer - web
riseshia
0
7.7k
マイクロサービス化を支える継続的切り替え術
riseshia
0
700
Cleaning up a huge ruby application
riseshia
3
12k
Other Decks in Technology
See All in Technology
Introduction to Sansan, inc / Sansan Global Development Center, Inc.
sansan33
PRO
0
3k
パネルディスカッション資料 (at Tableau Now! - 2026-02-26)
yoshitakaarakawa
0
840
Databricksアシスタントが自分で考えて動く時代に! エージェントモード体験もくもく会
taka_aki
0
250
2026-02-25 Tokyo dbt meetup プロダクトと融合したCI/CD で実現する、堅牢なデータパイプラインの作り方
y_ken
0
150
NW構成図の自動描画は何が難しいのか?/netdevnight3
corestate55
2
510
組織のSREを推進するためのPlatform EngineeringとEKS / Platform Engineering and EKS to drive SRE in your organization
chmikata
0
160
失敗できる意思決定とソフトウェアとの正しい歩き方_-_変化と向き合う選択肢/ Designing for Reversible Decisions
soudai
PRO
8
1.4k
Exadata Fleet Update
oracle4engineer
PRO
0
1.3k
Introduction to Sansan Meishi Maker Development Engineer
sansan33
PRO
0
360
ローカルでLLMを使ってみよう
kosmosebi
0
210
Snowflakeデータ基盤で挑むAI活用 〜4年間のDataOpsの基礎をもとに〜
kaz3284
1
300
ソフトウェアアーキテクトのための意思決定術: Create Decision Readiness—The Real Skill Behind Architectural Decision
snoozer05
PRO
27
7.8k
Featured
See All Featured
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.3k
Agile that works and the tools we love
rasmusluckow
331
21k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Odyssey Design
rkendrick25
PRO
2
530
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.1k
Jamie Indigo - Trashchat’s Guide to Black Boxes: Technical SEO Tactics for LLMs
techseoconnect
PRO
0
78
Paper Plane
katiecoart
PRO
0
47k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
SEO in 2025: How to Prepare for the Future of Search
ipullrank
3
3.3k
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
130
Transcript
福岡Rubyist会議05 Shia@STORES 型を書かないRuby開発への挑戦
SIM SANGYONG (@shia) - STORES株式会社 - GitHub: @riseshia - X:
@riseshia 自己紹介 2
質問です 3 Rubyで型を書きたいですか?
お気持ち 4 型を書きたくない!!
正確なお気持ち 5 Ruby では型を書きたくない!!
そしてただのワガママ 6 Ruby では型を書きたくない!! でも型情報はちょっとほしい
Ruby 型マップ 7 型宣言依存度 Steep / Sorbet Ruby LSP Guessed
type typeprof solargraph 提供される情報の品質
Ruby 型マップ 8 型宣言依存度 Steep / Sorbet Ruby LSP Guessed
type typeprof solargraph 型宣言が前提。方向が違う 提供される情報の品質
Ruby 型マップ 9 型宣言依存度 Steep / Sorbet Ruby LSP Guessed
type typeprof solargraph 丁寧な推論 大規模アプリだと少々重い gem は rbs 書いてね 提供される情報の品質
Ruby 型マップ 10 型宣言依存度 Ruby LSP Guessed type typeprof solargraph
欲しいアプローチは近いが Hash/Array が情報不足 あと ruby-lsp と機能重複... Steep / Sorbet 提供される情報の品質
Ruby 型マップ 11 型宣言依存度 Ruby LSP Guessed type typeprof solargraph
変数名ベースの単純推測のみ 提供される情報の品質 Steep / Sorbet
Ruby 型マップ 12 型宣言依存度 Ruby LSP Guessed type typeprof solargraph
この辺の何かがほしい 提供される情報の品質 Steep / Sorbet
推論の精度を落とし 自分が書く型の必要性を減らす・速度を得る 欲しいもの 13
- 推論された型が複雑なら untyped に - A or B or C
or D… -> untyped でいいでしょう! - Hash / Array に Structural Typing サポート - ヒューリスティックに依存する どうやって? 14
Structural Typing - Hash 15
Structural Typing - Array 16
Duck Typing を信じる 17 通常の Duck Typing: 「これらのメソッドに応答できるなら、OK」 🦆 quack
できるなら → アヒル type-guessr: 「これらのメソッドが呼ばれたなら、このクラスのはず」 🦆 quack が呼ばれた → きっとアヒル
Duck Typing を信じる 18
Duck Typing を信じる 19
Duck Typing を信じる 20
対象: LOC 100k 以上の Rails プロジェクト三つ 変数に送ったメソッド一覧から、変数(レシーバ)の型がわかる比率 => 10~20% Duck
Typing を信じる - そんな〜うまくいくんですか? 21
Duck Typing を信じる in type-guessr 22
- ruby-lsp の UX にそのまま溶け込める - 適切に実装すれば hover, autocompletion, 定義ジャンプが「型
がわかれば」自動で効く - ruby-lsp-rails, ruby-lsp-mongoid 等が ruby-lsp に登録する DSL 由来のメソッド一覧をそのまま活用できる - Duck typing ヒューリスティックではめっちゃ大事 設計 - Impl as ruby-lsp add on 23
設計 - How to infer - Duck typing によるクラス推定を頑張る -
自明なものを頑張る(e.g. Hoge.new) - あとは型情報を使って伝播していく - 型推論の結果が一定以上複雑になったら精度を落とす 24
- 十分小さいアプリでは価値が出にくい (メソッド名の一意性に依存) - ActiveRecord とかが大変扱いづらい... - 速度が遅い問題 - ruby-lsp
のインデッシングを待つ必要がある - 推論が重い - Diagnostic 出しづらい問題 - ヒューリスティックを混ぜたことでどう出すべきかという悩み Limitation 25
今色々いじりまくっており unstable ですが どうぞお試しください (そしてフィードバックがあると喜びます) bundle add type-gusser -g=’development’ https://github.com/riseshia/type-guessr
最後に 26