Upgrade to PRO for Only $50/Year—Limited-Time Offer! 🔥
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
カスタマイズしたMastodonを本家に追従するときのコツ
Search
abcang
August 19, 2017
Programming
0
1.4k
カスタマイズしたMastodonを本家に追従するときのコツ
2017/08/19 Mastodon Developers Kaigi #0 LT
abcang
August 19, 2017
Tweet
Share
More Decks by abcang
See All by abcang
Pawoo(Mastodon)が動く仕組み
abcang
0
1.7k
Other Decks in Programming
See All in Programming
非同期処理の迷宮を抜ける: 初学者がつまづく構造的な原因
pd1xx
1
500
[堅牢.py #1] テストを書かない研究者に送る、最初にテストを書く実験コード入門 / Let's start your ML project by writing tests
shunk031
11
6.8k
【CA.ai #3】Google ADKを活用したAI Agent開発と運用知見
harappa80
0
250
AIコードレビューがチームの"文脈"を 読めるようになるまで
marutaku
0
300
How Software Deployment tools have changed in the past 20 years
geshan
0
27k
TypeScript 5.9 で使えるようになった import defer でパフォーマンス最適化を実現する
bicstone
1
980
ZOZOにおけるAI活用の現在 ~モバイルアプリ開発でのAI活用状況と事例~
zozotech
PRO
8
4k
TypeScriptで設計する 堅牢さとUXを両立した非同期ワークフローの実現
moeka__c
6
2.9k
Integrating WordPress and Symfony
alexandresalome
0
120
複数人でのCLI/Infrastructure as Codeの暮らしを良くする
shmokmt
5
2.1k
エディターってAIで操作できるんだぜ
kis9a
0
640
なあ兄弟、 余白の意味を考えてから UI実装してくれ!
ktcryomm
10
11k
Featured
See All Featured
Understanding Cognitive Biases in Performance Measurement
bluesmoon
31
2.7k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
659
61k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
960
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
49
3.2k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
Navigating Team Friction
lara
191
16k
Rails Girls Zürich Keynote
gr2m
95
14k
Code Reviewing Like a Champion
maltzj
527
40k
For a Future-Friendly Web
brad_frost
180
10k
GitHub's CSS Performance
jonrohan
1032
470k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.5k
How STYLIGHT went responsive
nonsquared
100
5.9k
Transcript
カスタマイズしたMastodonを本 家に追従するときのコツ Mastodon Developers Kaigi #0
自己紹介 • abcang(@abcang1015) ◦ 「あべ」とか「あべちゃん」と呼ばれている • Mastodonのcollaborator • ピクシブ株式会社 17新卒
エンジニア ◦ Pawooの開発を担当
19万ユーザーを突破しました!
Pawooには独自機能がたくさん • pixivアカウント連携 • 自動消滅トゥート • 固定トゥート • メディアタイムライン •
pixivの画像展開 • 音楽アップロード(Pawoo Music) • 共有プレイリスト機能(Pawoo Music) • などなど
GitHubで本家と比較してみると なかなかの変更量…
Mastodon本家の追従は楽じゃない $ git merge v1.5.1 … $ git status |
grep "both modified" | wc -l 65 $ git status | grep "both modified" | grep "app/javascript" | wc -l 28 コンフリクト多い!! 半分近くがJavaScript!! 1.3系から1.4系のアップデート のときは100くらいあった
本家の追従の流れ 1. 本家のコードをマージする 2. GemfileやGemfile.lockのコンフリクトを解決 3. Rails周りのコンフリクトを解決 4. package.jsonやyarn.lockのコンフリクトを解決 5.
JavaScriptのコンフリクトを解決 6. 残りを気合で修正して動くようにする
GemfileやGemfile.lockのコンフリクトを解決 • Gemfileは通常通り手動で直す • Gemfile.lockは一旦本家のを適用 ◦ git checkout --theirs Gemfile.lock
• bundle installを実行 ◦ 本家のGemfile.lockをベースにして、独自で追加したgemをインストール
Rails周りのコンフリクトを解決 • modelやcontrollerはコンフリクト箇所が少ない ◦ メソッドが増減すると起こりやすい • viewはコンフリクト箇所が多いのでよく見て直す ◦ pixiv連携周りで起こりやすい •
一通り直したらテストが通るかチェック • Rails周りはコンフリクト箇所がまだ少ないので楽
package.jsonやyarn.lockのコンフリクトを解決 • Gemfileのときと同じ感じで • package.jsonを手動で直す • yarn.lockは一旦本家のを適用 ◦ git checkout
--theirs yarn.lock • yarn installを実行
JavaScriptのコンフリクトを解決 • componentやcontainerにコンフリクトが多い ◦ ReactのDOM構造が変わるとdiffがうまくとれなくなる ▪ その結果大きいdiffを眺めてコンフリクトを解決することに ◦ 固定トゥートやpixivの画像展開機能は コンポーネントに変更を加えているのでコンフリクトしやすい
• actionやreducerではコンフリクトが少ない ◦ リファクタリングとかあるときぐらい
残りを気合で修正して動くようにする • コンフリクトを解決してもwebpackのコンパイルに失敗すること はよくある ◦ ライブラリのバージョンが上がって使い方が変わった(react-router) ◦ 大きく仕様が変わった(メディアタイムラインのマルチカラム対応) • JavaScriptのlintに通るように修正
◦ ルールが追加されててtestに通らなくなってることが多い • などなど
カスタマイズしつつ本家に追従しやすくする • カスタマイズ部分を可能な限り別ファイルに分ける ◦ 本家に存在するファイルを直接変更するとコンフリクトしやすい ◦ Rubyならモジュールとして切り出してincludeして使うなど ◦ Reactならコンポーネントに切り出してimportして使うなど •
いっその事カスタマイズした部分を本家に送る ◦ コンフリクトしなくなる!! ◦ 他のインスタンスでも使われるので多くの人が恩恵を受けれる ◦ Pawooでは管理画面の改善を本家に送った
楽しいMastodon開発ライフを!