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
テキストエディタを知る / Getting to Know a Text Editor
Search
muryoimpl
December 19, 2020
Programming
0
120
テキストエディタを知る / Getting to Know a Text Editor
Kanazawa.rb#100 100回記念 & 年末 LT 大会 の二次会で話したスライド。
muryoimpl
December 19, 2020
Tweet
Share
More Decks by muryoimpl
See All by muryoimpl
Kanzawa.rbのLT大会を支える技術の裏側を変更する Ruby on Rails + Litestream 編
muryoimpl
0
250
Kanazawa.rb LT大会用/kzlt コマンドの説明 2024/01版
muryoimpl
0
2.5k
kzltコマンドの新たなソリューションについて
muryoimpl
0
2.4k
俺とTODOアプリ~Linearの変~
muryoimpl
0
2k
POSIX文字クラスでの躓き
muryoimpl
0
2k
/kzlt コマンドとは
muryoimpl
0
830
meetup.kzrb.org の更新を考える 事前激闘編
muryoimpl
0
1.3k
meetup.kzrb.org の更新を 考える ゆるふわ編
muryoimpl
0
1.3k
最近のデスク周りの diff / kzrb meetup#108-2
muryoimpl
0
21
Other Decks in Programming
See All in Programming
Honoのおもしろいミドルウェアをみてみよう
yusukebe
1
210
メンテが命: PHPフレームワークのコンテナ化とアップグレード戦略
shunta27
0
120
クリーンアーキテクチャから見る依存の向きの大切さ
shimabox
2
370
ペアーズでの、Langfuseを中心とした評価ドリブンなリリースサイクルのご紹介
fukubaka0825
2
320
Domain-Driven Transformation
hschwentner
2
1.9k
Software Architecture
hschwentner
6
2.1k
Rubyで始める関数型ドメインモデリング
shogo_tksk
0
110
AWS Organizations で実現する、 マルチ AWS アカウントのルートユーザー管理からの脱却
atpons
0
150
Amazon Bedrock Multi Agentsを試してきた
tm2
1
290
Grafana Cloudとソラカメ
devoc
0
170
2024年のWebフロントエンドのふりかえりと2025年
sakito
3
250
負債になりにくいCSSをデザイナとつくるには?
fsubal
10
2.4k
Featured
See All Featured
Become a Pro
speakerdeck
PRO
26
5.1k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
193
16k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
53k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
29
1k
The Cost Of JavaScript in 2023
addyosmani
47
7.3k
How GitHub (no longer) Works
holman
314
140k
4 Signs Your Business is Dying
shpigford
182
22k
Scaling GitHub
holman
459
140k
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
356
29k
The Cult of Friendly URLs
andyhume
78
6.2k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
33
2.1k
Navigating Team Friction
lara
183
15k
Transcript
テキストエディタを 知る 2020-12-19 (土) 13:00 〜 kanazawa.rb meetup#100 100回記念 &
年末 LT 大会 muryoimpl
何か新しいことを 学びたい なんか飽き ちゃって…
でも実用的じゃないと続か ない 簡単すぎて もなぁ… なんか飽き ちゃう… 身近だけど ほどよく謎 で… イメージしや
すい何かな いか…
テキストエディタを つくってみよう 簡単じゃあ ない! 仕事で毎日 使うじゃん イメージしや すい… 飽きるかも しれんが…
コミットログ書ける程度のものを ターゲットにしてみよう 普通のコミットログ 書くのにそんな高度 な編集機能はいら んだろう(マジ? ここを キャンプ地とし よう
でもどうやって 作るんだ? ナニモ ワカラナイ
どうやってテキストエディタを作るんだ? • イベントループで待ち受けて、キー入力を受け取ってなにかするくらいはわかるけ ど…基礎知識が足りない • テキストエディタは C 言語で書かれているものが多いが、私は C 言語に明るくない
• 既存のエディタのソースは参考になるんだろうが、私は C 言語に明る(ry • Ruby で書かれた Textbringer や Go で書かれた micro があるが、それぞれ何の ためにこの変更をやっているのか?まではコミットログからは詳細にわからない… 基礎知識が足りない困った
どうやってテキストエディタを作るんだ? • Textbringer 作者の shugo さんは、toruby07の発表 で参考として、 『The Craft of
Text Editing』https://www.finseth.com/craft/ を挙げているがいき なりはちょっとむずかしい感じだった • 簡易的なエディタをつくろう、というような連載記事 (2, 3回くらいのもの) は見つかる んだけど、それほど説明が詳しいわけでもないし、それだとすぐに完結してしまう
よさそうなサイトを発見!!
Build Your Own Text Editor • URL: https://viewsourcecode.org/snaptoken/kilo/ • 元々
http://antirez.com/news/108 で公開されていたものらしい • kilo という、単一の C 言語のファイル 約1000行 で構成されたテキストエディタを作 る過程が、184 step にも渡って解説されている • ソースコード: https://github.com/antirez/kilo • 実は有志によって解説部分が完全ではないものの日本語化されている ◦ https://github.com/algebroid/learn-kilo • C 言語の文法には説明はないが、利用しようとするものの意味にはちゃんと言及が ある
やってみている感想 なるほど…
やってみている感想 (まだまだ全然終わらない) • 記憶に残るように、英語で読み、写経して、解説の概要をコミットログに残しながら 進めているので時間がかかっている。が、続いている。 • 現在 50 step 目あたり。Ctrl-Q
で終了できる、エスケープシーケンスを駆使してウイ ンドウサイズを取得する、キー入力でカーソルを上下左右に動かせる、まだ vim で いうノーマルモードのみ、という状態。 • エスケープシーケンスってコンソールに色つけるだけじゃないんだぞ!っていうのを 思い知らされている。 • 遠回りしている感はあるが、それぞれのやっていることの意味は解説されていて理 解できるので、やっていることに納得感はある。(重要)
やってみている感想 (まだまだ全然終わらない) • Makefile があるので、保存時にタブをスペースに変換している処理が入っていると いきなりつまづきます。 • step ごとに make
して動かせる、変化を目で確認できるので、なかなか楽しい。 • 50 step 目現在で、C 言語初心者がつまづきそうなポインタの使い方はされていな いので、C 言語の入門書読んだ程度の人であれば少なくとも 50 step 目までは到 達できます。 • いつになったら自作テキストエディタをつくるというスタート地点に立てるのか今のと ころ未定なところが危険。
やってみている感想 (まだまだ全然終わらない) 正月休み使っても完走に至らない見込みなので、次回のもくもくもこれをやっている可能 性は否定できません… オレはようやくのぼりはじめたばかりだからな このはてしない kilo の step をよ…
未完