helm-agを今年いろいろ変更したのでそれについてまとめていこうと思います.
親ディレクトリの検索(1月 9日)
あるディレクトリ以下を検索するとき, 一つ上のディレクトリで検索したいと思うことがよくあります. その実現です. helm-ag
, helm-do-ag
ともに C-l
で一つ上のディレクトリに移動して検索できます. 一つ上のディレクトリ以下に膨大なファイルがある場合は危険ですのでご注意ください(~/work/
から ~/
へ移動など). 一応リポジトリのトップらしきディレクトリ(.git
等がある)より上に行こうとすると警告は出ます.
grepの ignoreリストを追加するフラグの追加(1月 14日)
grep-find-ignored-files
及びgrep-find-ignored-directories
を検索対象外にする. helm-ag-use-grep-ignore-list
を non-nilにすることで有効になる. デフォルト無効. 個人的には微妙な機能.
helm-do-agの C-u
つきの挙動を helm-do-grepと同じにする(1月 20日)
C-u
をつけると, ファイルパターンを追加で指定できるようになった. しかし helm-do-grep
が削除されてしまった今, 微妙である. helm-do-ag
は helm-do-grep
みたいなものを作ってくれと言われて作りましたけど, 個人的には面倒なので helm-ag
派です.
fuzzy matchの対応(1月 27日)
helmが fuzzy match(個人的にあまりこれを fuzzy matchと呼びたくないが)に対応したということでその対応. デフォルト無効. helm-ag-fuzzy-match
を non-nilすることで有効になる. この手のよくある fuzzy matchは英語圏以外の人では利用が難しいと思う. 学習方法にもよるんだろうけど, foobarbazを fbbととっさに打つのは難しい.
編集機能の追加(2月 16日)
helm-ag
を公開した直後から要望されていた検索した行を編集, 反映させる機能. 個人的にいらないし, 作り方わからねーってことで放置していたが, helm-swoopで実現されており, そのコード見ればなんとかなるだろってことでようやく今年に実装を開始. ほとんどコードは helm-swoopだけど, メンテのために必要最低限の機能だけ取り込む. 実装してみて, 使ってみたところ便利だった. 思いこみはよくないなぁと考えさせられた作業だった.
プロジェクトルートからの検索機能(3月 19日)
簡易 projectile. projectileを使っていないけど, プロジェクトルートから検索したいことがたまにあるなぁということで追加. helm-ag
版が helm-ag-project-root
で, helm-do-ag
版が helm-do-ag-project-root
です.
正規表現周りの改善(3月 21日)
- https://github.com/syohex/emacs-helm-ag/pull/83
- https://github.com/syohex/emacs-helm-ag/pull/84
- https://github.com/syohex/emacs-helm-ag/pull/97
ag(the silver searcher)は PCREを受け取るので, 結果をハイライトするときに直接それを使うとうまくいかないという問題があった(Emacs Lispと PCREの正規表現が完全に一致しないため). そのため簡易な変換を行い, ハイライトをうまく行うように修正. がちなものは作れなかったのでグルーピングや OR検索等に限られる.
編集バッファでの next-error
, previous-error
の対応(3月 30日)
M-x grep
や M-x compile
同様に next-error, previous-errorでその行に飛べるように対応. M-x compile
由来なんだろうけど, 名前が一致しなさすぎる.
現在開いているバッファに対して, 検索を行う機能(4月 29日)
helm-ag-buffers
, helm-do-ag-buffers
の実装. 要望されて作ったがいるのか ?
現在開いているファイルのみに helm-do-agを適用(6月 17日)
helm-do-ag-this-file
コマンドの追加. 微妙に使っている.
複数パターン検索の改善(6月 30日)
helm-do-ag
で使われる helmの別プロセスとのやりとりの機構を使うと入力がそのままプロセスに投げられてしまう. これでは通常の helmと挙動が異なる. 例えば foo bar
と入力した場合 foo bar
を含む行でなく, foo
と bar
を順不同に含む行にマッチして欲しい. これを実現するための修正. foo bar
が来たら, (?=.*foo.*)(?=.*bar.*)
のように変換しています. このあたりを実現するのに正規表現技術入門が大変役に立ちました(理論的な部分は私の頭では理解が困難でしたが... 勉強しないといけませんね).
ちなみにこの機能は PCRE互換の検索ツール(ag, ack等)しか使えません. Go製のツール(the platinum searcher, sift)では無理です. Goの正規表現は遅くなりづらい利点はあるけど, その分表現力を犠牲にしているので, 検索ツールにはあまり向かないのではないかと個人的に思っています.
プロジェクトルートにある .agignore
を利用するフラグの追加(6月 30日)
agは通常ホームディレクトリかカレントディレクトリにある ignoreファイルしかみない. そのためプロジェクトルートに置いていてもそれ以下のディレクトリで検索を行ったらそれが利用されない. なのでそのようなとき, helm-ag-use-agignore
を non-nilにすると, コマンドラインオプションを使い, プロジェクトルートの ignoreファイルを指定する. agは gitignoreは見にいってくれるので基本不要と思う.
helm-do-agで直接コマンドラインオプションを受け付けるようにする(9月 14日).
今までは prefixキーでオプションを指定する必要があったが, めんどいということで, 入力を解析し, ハイフンで始まるものはコマンドラインオプションとしてプロセスに渡すように修正.
検索パターンにコロンが含まれると正しくファイルにジャンプできない問題の修正(10月 28日)
よくいままで気付かなかったものだ. 以外とコロンを検索する機会は少ない ?
否定パターンの入力の改善(11月 28日)
!pattern
と入力すると pattern
を含まない行にマッチする機能の追加. 先ほどの変換同様 ^(?!.*pattern).+$"
と変換している. PCRE検索ツール限定
おわりに
いろいろ変更したものだ. この大半は自分の要望ではなく issueとして挙げられたものですが, もっと NOというべきだったように思えます. 実装しても良かったと言える機能もいくつかありましたが, 同程度に全く不要だったのではないかと思う機能もありました. メンテナンスしていくためにも NOというべきだったのではと反省しています. しかし異国の人に NOというのはなかなか難しいです. 自分の英語力で相手を納得させる必要があります. 大量の英語で畳み込まれそうなときも反発するだけの英語力が必要です. 来年というか今後は NOと言えるために, 英語力を高めていきたいと思います.