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
140
テキストエディタを知る / 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
1.3k
Kanazawa.rb LT大会用/kzlt コマンドの説明 2024/01版
muryoimpl
0
2.9k
kzltコマンドの新たなソリューションについて
muryoimpl
0
2.9k
俺とTODOアプリ~Linearの変~
muryoimpl
0
2.3k
POSIX文字クラスでの躓き
muryoimpl
0
2.3k
/kzlt コマンドとは
muryoimpl
0
940
meetup.kzrb.org の更新を考える 事前激闘編
muryoimpl
0
1.5k
meetup.kzrb.org の更新を 考える ゆるふわ編
muryoimpl
0
1.5k
最近のデスク周りの diff / kzrb meetup#108-2
muryoimpl
0
31
Other Decks in Programming
See All in Programming
脱Riverpod?fqueryで考える、TanStack Queryライクなアーキテクチャの可能性
ostk0069
0
490
The Evolution of Enterprise Java with Jakarta EE 11 and Beyond
ivargrimstad
0
240
PipeCDのプラグイン化で目指すところ
warashi
1
300
Model Pollution
hschwentner
1
160
商品比較サービス「マイベスト」における パーソナライズレコメンドの第一歩
ucchiii43
0
170
Claude Code + Container Use と Cursor で作る ローカル並列開発環境のススメ / ccc local dev
kaelaela
12
7k
“いい感じ“な定量評価を求めて - Four Keysとアウトカムの間の探求 -
nealle
2
12k
Quand Symfony, ApiPlatform, OpenAI et LangChain s'allient pour exploiter vos PDF : de la théorie à la production…
ahmedbhs123
0
210
PHP 8.4の新機能「プロパティフック」から学ぶオブジェクト指向設計とリスコフの置換原則
kentaroutakeda
2
1k
Python型ヒント完全ガイド 初心者でも分かる、現代的で実践的な使い方
mickey_kubo
1
240
『自分のデータだけ見せたい!』を叶える──Laravel × Casbin で複雑権限をスッキリ解きほぐす 25 分
akitotsukahara
2
660
MDN Web Docs に日本語翻訳でコントリビュートしたくなる
ohmori_yusuke
1
130
Featured
See All Featured
For a Future-Friendly Web
brad_frost
179
9.8k
Intergalactic Javascript Robots from Outer Space
tanoku
271
27k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
16k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
44
2.4k
Embracing the Ebb and Flow
colly
86
4.8k
Rebuilding a faster, lazier Slack
samanthasiow
83
9.1k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
34
3.1k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
126
53k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
161
15k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
8
700
Visualization
eitanlees
146
16k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
29
9.6k
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 をよ…
未完