2012年12月6日木曜日

sublime text 2 のちょっと便利な機能の使い方。-  Sublime Text 2 Advent Calendar 2012 の 7日目

はじめまして、千葉のいすみ市という田舎で、波乗りエンジニアしてます。サーフィンしてるだけです。宮本と申します。(@yahsan2)

普段自分用ブログメモなのですが、人のために?書きたいと思います。すこし読みにくいかもですが、そのへんご容赦下さい(ヽ'ω`)

 

Sublime Text 2 Advent Calendar 2012 の 7日目(http://www.adventar.org/calendars/20)で、書かせていだきます。

とはいって、sublime text歴2ヶ月くらいなので、僕が使っていて便利だなーと思っているかつ、他の記事にあまり乗ってないかなーってものををざっくばらんに書きます。また、macユーザーなのでwindowsの方は適宜読み替えて下さい。

 

目次 

・projectについて:画面をすっきり、コード管理も楽になる!?

・snippetについて:大量の自分のsnippetを管理の仕方を工夫する!?

・sidebarについて:マウスを使わないでファイル管理する!?

・矩形(複数)選択について:カーソルを好きな場所に増やしまくれる!?

・key bindingについて

・最後に

 

・projectについて

多分他のeditorにもあると思いますが、projectごとにファイルを保存する機能がsublime text 2にもあります。

プロジェクトで開くには、finderでフォルダをdocのアイコンにドッラグするか、terminalから

$subl . 

 をコマンドを打ったりすればプロジェクトで開かれます。

また、コマンドパレットから、Project: Add Folderでも大丈夫ですし、僕は以下のkeybindを設定しています。

{ "keys": ["super+ctrl+n"], "command": "prompt_add_folder"},

 

更にこの状態で、メニューの Save Project as を選択するか、

みんな大好きコマンドパレットでpro saveとかタイプして、Project: Save asを選択すると、プロジェクトとして保存ができます。

ちなみに、saveされるファイルは、プロジェクトフォルダ外でも内でも大丈夫なので、僕は一箇所のフォルダにまとめて保存しています。

 

プロジェクトとして登録すれば、メニューのプロジェクトから最近のものが開けたり、ctrl + cmd + p でプロジェクトを開いたり、移動したりできます。

このプロジェクトでもホットセーブがされていているので、以前開いたファイルの内容はもちろん、tabとかもそのまま同じ位置でに残っていたりするので、

受注でたくさんのサイトを同時並行して作っている僕にとって、切り替えがスムーズでかなり便利です。

過去のコードも見たい時も同じ箇所だったりするので、ctrl + cmd + pでそのコードをすぐ見つかることが多いです。

 

 

・Snippetについて

How to create な記事はたくさん他にあるので、管理の仕方について書きたいと思います。

 

僕はコードを以上3回書いたなーと思うと、すぐにsnippetを登録します。

メニューの tool > new Snippets でも良いですが、僕は以下のkey bindをあててどんどん追加してます!

{ "keys": ["super+alt+n"], "command": "new_snippet"},

 

 

snippetむちゃくちゃ便利ですね。

ただ、どんどん登録するのですぐにバッティングしたり、出力もっと違うようにしたいと思うことがたくさんあります。

そこで、先程書いたProjectを使います。

/Users/yahsan2/Library/Application Support/Sublime Text 2/Packages/User

このフォルダをproject登録しておけば、編集したばかりのものはtabを消してなければ残っているし、サイドバーなどですぐに探し出せます。

このproject + snippetコンボはなかなかです。

 

 

・sidebarについて

projectで開くと,sidebarが出せます。もちろんメニューで出せますが、キーバインドが便利です。

{ "keys": ["super+ctrl+shift+`"], "command": "toggle_side_bar" },

{ "keys": ["ctrl+super+`"], "command": "focus_side_bar" },

僕は上記の様に変更していますが(USキーボードでctrl+super+1のノリで移動できるから)、デフォルトでは ["super+b", "super+k"]となっていてます。

cmd + bと打ってもsidebarが開かなくて嵌っていましたが、これはcmd +b のあとに cmd+kを打つという意味です。

 

focus_side_barでsidebarに移動したあとクリックすればファイルは開けますが、f2でファイル名の変更もできます。

また、f2で「sample.html」→「./pages/sample.html 」とか相対pathをつけてやると移動もできます。

これも最初見つけるの苦労したので、参考になればと思います。

 

 

 

・矩形(複数)選択について

矩形(くけい)選択って便利です。大好きです。sublime text 2でももちろん出来ます。

ただ、その前にcmd+dを使った同じ単語を選択するやつ(なんていうのだろうか?)が便利です。

{ "keys": ["super+d"], "command": "find_under_expand" },

{ "keys": ["super+alt+d"], "command": "find_all_under" },

上は選択した同じ単語一つづつ選択追加で、下は一気に選択追加して、削除や編集ができます。


でも矩形選択もやっぱり便利です。

ctrl + shift+↑又は↓で矩形選択の入力カーソルが増えます。

ctrl + a で先頭にいって、ctrl + shift+↓でカーソル増やして、alt + →とか移動してhtml編集とかはよく使います。

 

さらに矩形選択はこのやり方だけでなく

alt + cmd を押したままマウスドラッグで、そこら一帯を矩形選択できますし、

finderとかでcmdを押しながら選択中ファイルを増やすように、cmd押しながらクリックしていくと、カーソルをどんどん増やせます。

特に後者は、案外規則で並んでないけど同時編集したいって時とかものすごい便利です。

 

また、矩形選択はesc脱出することができます。 

 

・key binding

これはおまけですが、僕がkey bindingが好きなので、大体の操作にあててます。

このとき必要になるコマンド名は、st2デフォルトの機能であれば以下のdefault.sublime-commandsやプラグインであれば、

そのプラグインの.sublime-commandsファイル名を見れば見つけることが出来ます。

https://github.com/cj/sublime/blob/master/Default/Default.sublime-commands

ちなみに、もちろんキーバインド追加しまくれるように、このUser Keymapのファイルもキーバインドしています^^

{ "keys": ["super+alt+,"], "command": "open_file", "args":

  {

    "file": "${packages}/User/Default (OSX).sublime-keymap",

    "platform": "OSX"

  }

},

 

・最後に

sublime text 2まだ初心者ですが(プログラマとしてもなんですが)、かなり良い感じですね!使ってて楽しいです!

他にもプラグインを使用しての細かい便利ハックが結構あるのですが、時間ができたらまとめたいです。

 

ただいくつか、これできないかなーと思っていることもあります。

・sidebarにフォーカスした状態で、キーボードからファイル及びフォルダの削除

・""とか''""の内側を""を含まないで選択(expand_selectionは""含んでしまう)

・vintageモードの際、矩形選択から通常に戻る時、矩形選択のノーマルモードではなく、カーソル一つのinsertモードに戻りたい。

・Indent Using Spaceを常にオンにしたい。

 

もし知っている方いたらtwitterとかで教えていただけたら、とても嬉しいです。

他にも、こんなかんじやつ大好きなので、持っているかたあるかた教えて欲しいです。

是非こちらまで、@yahsan2

 

明日は jugyoさんです。よろしくお願いしますー!