Python のソースを読むのにタグジャンプ機能を利用する
vi(vim) で Python のソースを読むのに ctags を使ってみました。調べていると、別途、ptags.py と言うものもあり、それを用いてもタグファイルを作成してくれるようです。
basic Tip #1188: Use ptags.py to generate tags file for python によると、Python 2.3 以上で使用できます。ptags.py は python-tools パッケージに含まれています。
yum を使って python-tools と ctags をインストールします。
$ sudo yum install python-tools ctags ~~~ snip ~~~ Running Transaction Installing : python-tools [1/2] Installing : ctags
以下のように ptags.py の引数にファイル名を指定すると tags ファイルが作成されます。おそらく ptags.py は ctags が Python に対応していなかった過去の名残りかな?と思います。現在は ctags でもタグファイルを作成することができます。
$ /usr/lib/python2.5/Tools/scripts/ptags.py *.py
又は、
$ ctags *.py
ptags.py と ctags で作成した tags ファイルを比較してみました。ctags の tags ファイルの方がサイズが大きいです。
$ ls -l tags* -rw-rw-r-- 1 xxx xxx 33543 2008-09-03 18:31 tags.ctags -rw-rw-r-- 1 xxx xxx 18708 2008-09-03 18:32 tags.ptags $ head tags.ptags tags.ctags ==> tags.ptags <== CacheProgressCallback output.py /^class CacheProgressCallback:/ CheckFailedSignal yum-updatesd.py /^ def CheckFailedSignal(/ CheckNow yum-updatesd.py /^ def CheckNow(/ CheckUpdateCommand yumcommands.py /^class CheckUpdateCommand(/ CleanCommand yumcommands.py /^class CleanCommand(/ CliError cli.py /^class CliError(/ DbusUpdateEmitter yum-updatesd.py /^class DbusUpdateEmitter(/ DepListCommand yumcommands.py /^class DepListCommand(/ DepSolveProgressCallBack output.py /^class DepSolveProgressCallBack:/ EmailUpdateEmitter yum-updatesd.py /^class EmailUpdateEmitter(/ ==> tags.ctags <== !_TAG_FILE_FORMAT 2 /extended format; --format=1 will not append ;" to lines/ !_TAG_FILE_SORTED 1 /0=unsorted, 1=sorted, 2=foldcase/ !_TAG_PROGRAM_AUTHOR Darren Hiebert /[email protected]/ !_TAG_PROGRAM_NAME Exuberant Ctags // !_TAG_PROGRAM_URL http://ctags.sourceforge.net /official site/ !_TAG_PROGRAM_VERSION 5.6 // CacheProgressCallback output.py /^class CacheProgressCallback:$/;" c CheckFailedSignal yum-updatesd.py /^ def CheckFailedSignal(self, message):$/;" m class:YumDbusInterface CheckNow yum-updatesd.py /^ def CheckNow(self):$/;" m class:YumDbusListener CheckUpdateCommand yumcommands.py /^class CheckUpdateCommand(YumCommand):$/;" c
どちらが良いとか、何が違うとかがよく分からないので、取り合えず ctags を使用することにします(^ ^;;
カレントディレクトリ配下(サブディレクトリも含む)の 全ての .py ファイルからタグファイルを作成する $ find . -type f -name "*.py" -exec ctags -a {} \; 上記に加えて、特定ライブラリも対象に含めてタグファイルを作成する $ find . /usr/lib/python2.5/site-packages/rpm* -type f -name "*.py" -exec ctags -a {} \;
vi(vim) エディタ上での基本操作は以下の通りです。詳細は Tip #94: Questions & Answers about using tags with Vim からリンクを辿ればありそうです。まぁ、ぼちぼちと(- -#
:ta tag タグを検索する Ctrl-] カーソル下のタグを検索する(ヒットすればジャンプ) Ctrl-T タグジャンプする前の位置へ戻る
さらに taglist.vim : Source code browser (supports C/C++, java, perl, python, tcl, sql, php, etc) に taglist.vim というプラグインがあります。せっかくなのでこれもインストールして使ってみます。
インストール方法: 1. taglist_45.zip をダウンロード 2. vim の環境設定 $ vi ~/.vimrc filetype on を追加 $ cd ~/.vim $ unzip /tmp/taglist_45.zip plugin/taglist.vim - プラグインの本体 doc/taglist.txt - ドキュメント(ヘルプ)ファイル 3. 基本操作 :TlistToggle 左側にタグリストメニューが表示され F1 でヘルプが見れます
以下のようなイメージです。
リファレンス:
Vim Taglist Plugin 本家サイト