$30 off During Our Annual Pro Sale. View Details »
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
150
テキストエディタを知る / 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
Rubyで鍛える仕組み化プロヂュース力
muryoimpl
0
77
人魚とたわむれる
muryoimpl
0
26
Kanzawa.rbのLT大会を支える技術の裏側を変更する Ruby on Rails + Litestream 編
muryoimpl
0
1.3k
Kanazawa.rb LT大会用/kzlt コマンドの説明 2024/01版
muryoimpl
0
3k
kzltコマンドの新たなソリューションについて
muryoimpl
0
2.9k
俺とTODOアプリ~Linearの変~
muryoimpl
0
2.6k
POSIX文字クラスでの躓き
muryoimpl
0
2.3k
/kzlt コマンドとは
muryoimpl
0
960
meetup.kzrb.org の更新を考える 事前激闘編
muryoimpl
0
1.6k
Other Decks in Programming
See All in Programming
AIコーディングエージェント(skywork)
kondai24
0
150
CSC305 Lecture 17
javiergs
PRO
0
340
JETLS.jl ─ A New Language Server for Julia
abap34
1
270
【CA.ai #3】Google ADKを活用したAI Agent開発と運用知見
harappa80
0
290
30分でDoctrineの仕組みと使い方を完全にマスターする / phpconkagawa 2025 Doctrine
ttskch
3
800
なあ兄弟、 余白の意味を考えてから UI実装してくれ!
ktcryomm
11
11k
UIデザインに役立つ 2025年の最新CSS / The Latest CSS for UI Design 2025
clockmaker
18
7.3k
20 years of Symfony, what's next?
fabpot
2
350
Cap'n Webについて
yusukebe
0
120
まだ間に合う!Claude Code元年をふりかえる
nogu66
3
540
ソフトウェア設計の課題・原則・実践技法
masuda220
PRO
26
22k
令和最新版Android Studioで化石デバイス向けアプリを作る
arkw
0
380
Featured
See All Featured
Building Applications with DynamoDB
mza
96
6.8k
How Fast Is Fast Enough? [PerfNow 2025]
tammyeverts
3
390
KATA
mclloyd
PRO
32
15k
Build The Right Thing And Hit Your Dates
maggiecrowley
38
3k
GitHub's CSS Performance
jonrohan
1032
470k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
10
720
A Modern Web Designer's Workflow
chriscoyier
698
190k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
9.8k
Done Done
chrislema
186
16k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
Scaling GitHub
holman
464
140k
[SF Ruby Conf 2025] Rails X
palkan
0
500
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 をよ…
未完