vim + tmuxでVSCodeっぽい開発環境を作る

vim + tmuxでVSCodeっぽい開発環境を作る

vim + tmuxでVSCodeっぽい開発環境を作る

MicrosoftのVisual Studio Code(以下VSCode)には期待していて何度かエディタの乗り換えにトライしてるんだけど、今回もあえなく失敗してしまった。でもその度に改善アイデアを得ては自分の環境に取り入れている。定期的に色んなエディタを試して良いとこ取りをするのは、結構いいかもしれない。

自分は基本的にvimとtmuxを併用してターミナルで作業をしている。本稿ではVSCodeの特徴を軸に自分のvimとtmuxの設定をシェアしたい。説明はtmuxとvimの基本を知っていることを前提とする。以下概要:

  • VSCodeっぽい画面分割
  • VSCodeっぽいファイラ
  • VSCodeっぽいエラー表示
  • (VSCodeっぽくない) プロジェクトごとにtmuxタブを開く

VSCodeでは画面下にターミナルを表示できるのが便利だと思ったので真似した。tmuxで上下7:3で分割している。上段でvimを起動して、下段でコンパイルなどをする。下段は更に3つに垂直分割する事が多い。この画面分割をコマンド一発で出来るように以下のようなシェルスクリプトにしている:

<span id="5331" class="qg ot io qc b gz qh qi m qj qk">#!/bin/bash<br></br>tmux split-window -v -p 30<br></br>tmux split-window -h -p 66<br></br>tmux split-window -h -p 50</span>

VSCodeでは画面下のターミナルをトグル(表示/非表示)出来る。邪魔な時は非表示に出来るのが便利。tmuxではズーム機能で同じことができる。上段にフォーカスがあたっている時に -z を入力すると、上段のウインドウが最大化する。つまり下段が非表示になる。この機能はすごく便利で、下段でやるとシェルが最大化するのでログをじっくり眺めたい時などによくやる。

-z</code> を入力すると、上段のウインドウが最大化する。つまり下段が非表示になる。この機能はすごく便利で、下段でやるとシェルが最大化するのでログをじっくり眺めたい時などによくやる。</p><p id="0009" class="pw-post-body-paragraph np nq io nr b ns nt nu nv nw nx ny nz go oa ob oc gr od oe of gu og oh oi oj hp bk">一方、vim側の画面分割は以下のようにキーをマップしている:</p><pre class="pp pq pr ps pt qb qc qd qe aj qf bk"><span id="499f" class="qg ot io qc b gz qh qi m qj qk">" Split window<br></br>nmap ss :split<Return><C-w>w<br></br>nmap sv :vsplit<Return><C-w>w<br></br>" Move window<br></br>nmap <Space> <C-w>w<br></br>map s<left> <C-w>h<br></br>map s<up> <C-w>k<br></br>map s<down> <C-w>j<br></br>map s<right> <C-w>l<br></br>map sh <C-w>h<br></br>map sk <C-w>k<br></br>map sj <C-w>j<br></br>map sl <C-w>l<br></br>" Resize window<br></br>nmap <C-w><left> <C-w><<br></br>nmap <C-w><right> <C-w>><br></br>nmap <C-w><up> <C-w>+<br></br>nmap <C-w><down> <C-w>-</span>

一方、vim側の画面分割は以下のようにキーをマップしている:

ss で水平分割、 sv で垂直分割。 s でウインドウの移動など。vimのウインドウ分割機能はとても優秀で、縦に横に無限に分割できる。他のエディタになかなか移行できない理由の一つ。

ファイルツリーは個人的に要らないので表示していない。画面をめいっぱい編集画面として使いたいから。vimfilerを適宜立ち上げて使っている。以下のように sfキーで任意のウインドウで起動できる。

vimfiler

VSCodeではMaterial Icon Themeでファイルアイコンをいい感じに表示できるのがかっこいい。上記の通り、vimでも vim-devicons を使えばファイラにアイコンを表示できる。

vimfilerの設定内容は以下のとおり:

<span id="879d" class="qg ot io qc b gz qh qi m qj qk">nmap sf :VimFilerBufferDir<Return><br></br>nmap sF :VimFilerExplorer -find<Return><br></br>nmap sb :Unite buffer<Return><br></br>let g:vimfiler_as_default_explorer = 1<br></br>let g:vimfiler_safe_mode_by_default = 0<br></br>let g:vimfiler_enable_auto_cd = 0<br></br>let g:vimfiler_tree_leaf_icon = ''<br></br>let g:vimfiler_tree_opened_icon = '▾'<br></br>let g:vimfiler_tree_closed_icon = '▸'<br></br>let g:vimfiler_marked_file_icon = '✓'</span>

gr で開いているディレクトリを起点としてファイルの中身を検索できる。かなり多用してる。

VSCodeではLintエラーとかを、ファイルを保存しなくても非同期的にチェックしてくれる。いちいち待たされないのが良い。これはvimではAleを使って実現する。

で次のエラーにジャンプできる。キーマップは以下のとおり:

<span id="c151" class="qg ot io qc b gz qh qi m qj qk">nmap <silent> <C-k> <Plug>(ale_previous_wrap)<br></br>nmap <silent> <C-j> <Plug>(ale_next_wrap)</span>

エラー一覧を表示したい時は :lopen で。

自分はInkdropというMarkdownエディタを作っていて、サーバサイドからデスクトップやモバイルアプリまで同時に複数のプロジェクトを開いて開発することが多い。自分はプロジェクトごとにtmuxでタブを開いて、それに名前を付けて管理している。こんな感じ:

-, でタブ(ウインドウ)の名前を変更できる。面倒だけどこまめに変更してやると迷わなくて済む。

-,</code> でタブ(ウインドウ)の名前を変更できる。面倒だけどこまめに変更してやると迷わなくて済む。</p><p id="85df" class="pw-post-body-paragraph np nq io nr b ns nt nu nv nw nx ny nz go oa ob oc gr od oe of gu og oh oi oj hp bk">VSCodeだとプロジェクトごとにウインドウを開くことになるので、どれがどのプロジェクトか分からなくなる。仮想デスクトップは嫌いなので解決にならない。この辺が今後改善されると嬉しい。</p><p id="889b" class="pw-post-body-paragraph np nq io nr b ns nt nu nv nw nx ny nz go oa ob oc gr od oe of gu og oh oi oj hp bk"><code class="cx ql qm qn qc b"><prefix>-o</code> でウインドウのカレントディレクトリを開くように設定している。これでFinderで作業したい時にすぐ開ける。</p><pre class="pp pq pr ps pt qb qc qd qe aj qf bk"><span id="243b" class="qg ot io qc b gz qh qi m qj qk"># Open current directory<br></br>bind o run-shell "open #{pane_current_path}"</span>

VSCodeだとプロジェクトごとにウインドウを開くことになるので、どれがどのプロジェクトか分からなくなる。仮想デスクトップは嫌いなので解決にならない。この辺が今後改善されると嬉しい。

-o でウインドウのカレントディレクトリを開くように設定している。これでFinderで作業したい時にすぐ開ける。

開発環境は見直すたびに新しい発見があって面白い。キリが無いのでこの辺で。

https://www.inkdrop.app/

Read more

貫禄を捨てて愛嬌で生き延びろ!40代オッサンの生存戦略

貫禄を捨てて愛嬌で生き延びろ!40代オッサンの生存戦略

どうもTAKUYAです。 つい先週(11月19日)に誕生日を迎え、41歳になりました。40代と言うのは若い頃には想像もしなかった年代で、どう生きれば良いのかというイメージがあまり具体的に湧かない、曖昧な年齢ではないでしょうか?自分の父親を想像するも、日中はいつも仕事でいなかったのであまり参考になりません。 自分は個人開発で生計を立てていて20代、30代で積み上げて来たものが上手く実を結んだおかげで今の生活があります。育児にも、いわゆるサラリーマンよりかは柔軟に参加できていて、子供との時間も沢山取れています。ママ友も出来ました(迷惑かけっぱなしですが)。 本記事では、そんなライフスタイルを送る自分が40代で大事にしたいことについて書きたいと思います。タイトルにもある通り、結論から言うとそれは「愛嬌」だと思います。以下、中年男性の愛嬌の重要性について説明します。 TL;DR * 「貫禄が出てきたね」と言われたら注意 * 笑顔を作れ。オッサンがムスッとしてたら普通に怖い * 謙虚に振る舞え。実績を積むと周りが萎縮する * ギャップ萌えを活用しろ 「貫禄が出てきたね」と言わ

By Takuya Matsuyama
過集中を避けるための働き方とルーティン(二児の父ver.)

過集中を避けるための働き方とルーティン(二児の父ver.)

どうもTAKUYAです。 先日書いた通り、最近個人開発を頑張りすぎて体を壊してしまいました。 その原因の一つが過集中癖です。自分はもともと何かに集中すると周りが見えなくなる傾向があり、それがたまに私生活にも影響を及ぼします。同じ失敗を繰り返さないためにも、ちょっと働き方を再設計したいと思います。 働き方に対して他人の指摘をアテにしない 自分のようなフリーランサーまたは自作サービスで生計を立てている人は、時間の使い方を自分で自由に決められます。その反面、どこまでも極端な働き方が出来てしまい、それを指摘したり止めてくれる人がいないという欠点もあります。自分には妻がいますが、全く違う業界なので自分の作業ペースがどのようなものか具体的に把握できません。 「疲れた!」と言えば「休んだら?」と言ってくれますが、働き方やペース配分などにまで口は出しません。なので、他人のストップサインはアテに出来ません。 (心理カウンセラーの可能性を別途検討中) 最近子供が生まれたので厳密なルーティン実行は出来ない 一日を時間単位・分単位で区切ってルーティンを組むのは気持ちがいいですよね。僕もそうしたい

By Takuya Matsuyama
なぜ体を壊してまで個人開発を頑張るのか?自尊心の欠如や過集中癖と向き合う

なぜ体を壊してまで個人開発を頑張るのか?自尊心の欠如や過集中癖と向き合う

どうもTAKUYAです。最近、個人開発を頑張りすぎて体調を崩してしまいました。アトピーが猛烈に悪化して、QoLが著しく下がってしまいました。まだ療養中ですが、毎日1万歩以上歩いて、徐々に回復しつつあります。 この過ちを繰り返さないためにも、自分は一体何が原因で頑張りすぎてしまうのか?という事について深堀りして考えてみたいと思います。また、個人開発におけるメンタルヘルスはあまり語られていないトピックだと思います。本記事が、同じように仕事を頑張りすぎてしまう人の助けになれば幸いです。 TL;DR * なんとなく続けていたソフト開発が自分を救った * 原体験が歪んだモチベーションを生んでしまった * 親が引くほどの過集中癖がある * 生得的な直せないバグと考えることにする * アプリの成功に関係なく、自分をあるがままに受け入れる * 挫折しないのは、なんだかんだで前向きだから * ユーザさんから「休め!」と叱咤された * 人生は長い。個人開発なんかで死ぬな 自己の原体験について振り返ってみる 個人開発だけで生活するようになって、かれこれ8年ぐらいが経ちます。こう

By Takuya Matsuyama
ユーザサポートの問い合わせを装った攻撃が怖すぎた

ユーザサポートの問い合わせを装った攻撃が怖すぎた

どうもTAKUYAです。個人開発をしていてアプリの知名度が上がってくると、作者個人(あるいはサイト管理人)を狙った攻撃というのをたまに受けます。つい先日も、怖すぎるメールを受け取ったのでシェアします。 件名: Cookie consent prevents platform access Hello, I cannot access use the store. The cookie consent notice keeps appearing and nothing happens once I approve or try to close it, so I’m unable to interact with the website. Please provide guidance on

By Takuya Matsuyama