2011-09-04 16:22:46 +04:00
|
|
|
irb関連おまけコマンドとライブラリ
|
2001-04-30 22:17:38 +04:00
|
|
|
$Release Version: 0.7.1 $
|
|
|
|
$Revision$
|
|
|
|
by Keiju ISHITSUKA(Nihon Rational Co.,Ltd.)
|
|
|
|
|
2001-05-08 03:52:57 +04:00
|
|
|
=begin
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
:コマンド:
|
2001-04-30 22:17:38 +04:00
|
|
|
* rtags -- ruby tags command
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
:関数ライブラリ:
|
2001-04-30 22:17:38 +04:00
|
|
|
* xmp -- irb version of gotoken xmp-function
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
:クラスライブラリ:
|
2001-04-30 22:17:38 +04:00
|
|
|
* frame.rb -- frame tracer
|
|
|
|
* completion.rb -- irb completor
|
|
|
|
|
|
|
|
= rtags
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
rtagsはemacs及びvi用の, TAGファイルをつくるコマンドです.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
== 使い方
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
rtags [-vi] file....
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
カレントディレクトリにemacs用のTAGSファイルができます. -viオプションを
|
|
|
|
つけた時にはvi用のtagsファイルを作成します.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
emacsの場合, 通常のetags.elがそのまま使えます. 検索可能なのは,
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
* クラス
|
|
|
|
* メソッド
|
|
|
|
* 特異メソッド
|
2001-04-30 22:17:38 +04:00
|
|
|
* alias
|
2011-09-04 16:22:46 +04:00
|
|
|
* attrで宣言されたアクセサ(パラメータがシンボルか文字列リテラルに限る)
|
|
|
|
* attr_XXXで宣言されたアクセサ(パラメータがシンボルか文字列リテラルに限る)
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
です.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
Cなどで使っているのと違うのは, コンプリーションに関する部分で,
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
関数名は,
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
関数名(
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
クラスは,
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
::クラス名::....::クラス名
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
メソッドは,
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
::クラス名::....::クラス名#メソッド名
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
特異メソッド(クラスメソッド)は
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
::クラス名::....::クラス名.メソッド名
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
でコンプリーションを行なうところです.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
= xmp.rb
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
ごとけんxmpの上位互換バージョンです. ただ, 非常に重いのでごとけんxmpで
|
|
|
|
は対応できない時に, 使用すると良いでしょう.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
== 使い方
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
=== 関数として使う.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
require "irb/xmp"
|
|
|
|
xmp <<END
|
|
|
|
foo = 1
|
|
|
|
foo
|
|
|
|
END
|
|
|
|
---
|
|
|
|
foo = 1
|
|
|
|
==>1
|
|
|
|
foo
|
|
|
|
==>1
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
=== XMPインスタンスを用いる.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
この場合は, XMPがコンテキスト情報を持つので, 変数の値などを保持してい
|
|
|
|
ます.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
require "irb/xmp"
|
|
|
|
xmp = XMP.new
|
|
|
|
xmp.puts <<END
|
|
|
|
foo = 1
|
|
|
|
foo
|
|
|
|
END
|
|
|
|
xmp.puts <<END
|
|
|
|
foo
|
|
|
|
END
|
|
|
|
===
|
|
|
|
foo = 1
|
|
|
|
==>1
|
|
|
|
foo
|
|
|
|
==>1
|
|
|
|
foo
|
|
|
|
==>1
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
== コンテキストに関して
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
XMPメソッド群のコンテキストは, 呼び出す前のコンテキストで評価されます.
|
|
|
|
明示的にコンテキストを指定するとそのコンテキストで評価します.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
例:
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
xmp "foo", an_binding
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
:注:
|
|
|
|
マルチスレッドには対応していません.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
= frame.rb
|
2011-09-04 16:22:46 +04:00
|
|
|
現在実行中のフレーム情報を取り扱うためのクラスです.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
* IRB::Frame.top(n = 0)
|
2011-09-04 16:22:46 +04:00
|
|
|
上からn番目のコンテキストを取り出します. nは0が最上位になります.
|
2001-04-30 22:17:38 +04:00
|
|
|
* IRB::Frame.bottom(n = 0)
|
2011-09-04 16:22:46 +04:00
|
|
|
下からn番目のコンテキストを取り出します. nは0が最下位になります.
|
2001-04-30 22:17:38 +04:00
|
|
|
* IRB::Frame.sender
|
2011-09-04 16:22:46 +04:00
|
|
|
センダになっているオブジェクトを取り出します. センダとは, そのメソッ
|
|
|
|
ドを呼び出した側のselfのことです.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
:注:
|
|
|
|
set_trace_funcを用いてRubyの実行をトレースしています. マルチスレッドに
|
|
|
|
は対応していません.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
= completion.rb
|
2011-09-04 16:22:46 +04:00
|
|
|
irbのcompletion機能を提供するものです.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
== 使い方
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
% irb -r irb/completion
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
とするか, ~/.irbrc 中に
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
require "irb/completion"
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
を入れてください. irb実行中に require "irb/completion" してもよいです.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
irb実行中に (TAB) を押すとコンプレーションします.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
トップレベルで(TAB)を押すとすべての構文要素, クラス, メソッドの候補がで
|
|
|
|
ます. 候補が唯一ならば完全に補完します.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
irb(main):001:0> in
|
|
|
|
in inspect instance_eval
|
|
|
|
include install_alias_method instance_of?
|
|
|
|
initialize install_aliases instance_variables
|
|
|
|
irb(main):001:0> inspect
|
|
|
|
"main"
|
|
|
|
irb(main):002:0> foo = Object.new
|
|
|
|
#<Object:0x4027146c>
|
|
|
|
|
2011-09-04 16:22:46 +04:00
|
|
|
((|変数名.|))の後に(TAB)を押すと, そのオブジェクトのメソッド一覧がでま
|
|
|
|
す.
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
irb(main):003:0> foo.
|
|
|
|
foo.== foo.frozen? foo.protected_methods
|
|
|
|
foo.=== foo.hash foo.public_methods
|
|
|
|
foo.=~ foo.id foo.respond_to?
|
|
|
|
foo.__id__ foo.inspect foo.send
|
|
|
|
foo.__send__ foo.instance_eval foo.singleton_methods
|
|
|
|
foo.class foo.instance_of? foo.taint
|
|
|
|
foo.clone foo.instance_variables foo.tainted?
|
|
|
|
foo.display foo.is_a? foo.to_a
|
|
|
|
foo.dup foo.kind_of? foo.to_s
|
|
|
|
foo.eql? foo.method foo.type
|
|
|
|
foo.equal? foo.methods foo.untaint
|
|
|
|
foo.extend foo.nil?
|
|
|
|
foo.freeze foo.private_methods
|
|
|
|
|
2001-05-08 03:52:57 +04:00
|
|
|
=end
|
2001-04-30 22:17:38 +04:00
|
|
|
|
|
|
|
% Begin Emacs Environment
|
|
|
|
% Local Variables:
|
|
|
|
% mode: text
|
|
|
|
% comment-column: 0
|
|
|
|
% comment-start: "%"
|
|
|
|
% comment-end: "\n"
|
|
|
|
% End:
|
|
|
|
%
|
|
|
|
|