種類
- 特異メソッド (187)
- インスタンスメソッド (99)
- ライブラリ (33)
- 定数 (11)
- 文書 (5)
ライブラリ
- debug (11)
-
irb
/ ext / tracer (33) -
irb
/ extend-command (11) - tracer (242)
クラス
-
IRB
:: Context (33) - Tracer (253)
モジュール
-
IRB
:: ContextExtender (11)
キーワード
-
NEWS for Ruby 2
. 7 . 0 (5) - Single (11)
-
add
_ filter (33) -
display
_ c _ call (11) -
display
_ c _ call= (11) -
display
_ c _ call? (11) -
display
_ process _ id (11) -
display
_ process _ id= (11) -
display
_ process _ id? (11) -
display
_ thread _ id (11) -
display
_ thread _ id= (11) -
display
_ thread _ id? (11) -
get
_ line (11) -
get
_ thread _ no (11) -
install
_ extend _ commands (11) - irb (11)
-
irb
/ ext / tracer (11) - off (11)
- on (11)
-
set
_ get _ line _ procs (33) - stdout (11)
-
trace
_ func (22) -
use
_ tracer (11) -
use
_ tracer= (11) -
use
_ tracer? (11)
検索結果
先頭5件
-
tracer (38084.0)
-
実行トレース出力をとる機能を提供します。
...nel.#require する方法です。
hoge.rb の実行をすべてトレース出力します。
ruby -rtracer hoge.rb
もうひとつはソースからrequireする方法です。
require 'tracer'
とした後
Tracer.on
によりトレース出力を有効にします。
Tracer.off...... Tracer.on を呼び出すと、そのブロック内のみ
トレースを出力します。
=== サンプルコード
# 例: 式の評価の中でHogeクラスのメソッドが呼び出される時、トレースする。
# ruby 1.8 では警告がでますが、動作します。
requir......e 'tracer'
class Hoge
def Hoge.fuga(i)
"fuga #{i}"
end
end
Tracer.add_filter {|event, file, line, id, binding, klass|
event =~ /line/ and klass.to_s =~ /hoge/i
}
Tracer.on
for i in 0..3
puts Hoge.fuga(i) if i % 3 == 0
end
Tracer.off
=== SEE ALSO
Kernel.#set... -
IRB
:: Context # use _ tracer=(val) (29141.0) -
irb への入力を評価する時に tracer が有効にするかどうかを val で 指定します。
...
irb への入力を評価する時に tracer が有効にするかどうかを val で
指定します。
.irbrc ファイル中で IRB.conf[:USE_TRACER] を設定する事でも同様の事が行
えます。
@param val tracer を有効にする場合に true を指定します。
@see tracer,......IRB::Context#use_tracer... -
IRB
:: Context # use _ tracer -> bool (29130.0) -
irb への入力を評価する時に tracer が有効かどうかを返します。
...
irb への入力を評価する時に tracer が有効かどうかを返します。
@see tracer, IRB::Context#use_tracer=... -
IRB
:: Context # use _ tracer? -> bool (29130.0) -
irb への入力を評価する時に tracer が有効かどうかを返します。
...
irb への入力を評価する時に tracer が有効かどうかを返します。
@see tracer, IRB::Context#use_tracer=... -
IRB
:: ContextExtender . install _ extend _ commands -> object (26106.0) -
定義済みの拡張を読み込みます。
...みます。
IRB::Context で以下のメソッドが利用できるようになります。
* eval_history=
* use_tracer=
* math_mode=
* use_loader=
* save_history=
irb/extend-command が require された時にライブラリ内部で自動的
に実行されます。
@see IRB::ContextExt... -
Tracer
# get _ line(file , line) -> String (23300.0) -
@todo
...@todo
@param file
@param line... -
Tracer
. set _ get _ line _ procs(filename) {|line| . . . . } (23218.0) -
あるファイルについて利用する、行番号からソースのその行の内容を返す 手続きを指定します。何も指定しなければデフォルトの動作が利用されます。 指定する手続きは行番号を唯一の引数として呼び出されます。
...@param filename ソースファイルの場所を文字列で指定します。
@param proc 通常、文字列を返す手続きオブジェクトを指定します。
# 例 dummy.rb の3行目から6 行目のトレース出力に !! をつける
require 'tracer'
Tracer.set_get_line_procs(......'./dummy.rb'){|line|
str = "\n"
str = "!!\n" if line >= 3 and line <= 6
str
}
Tracer.on
require 'dummy'
dm = Dummy.new
puts dm.number
=begin
# dummy.rb
class Dummy
def initialize
@number = 135
end
attr :number
end
=end... -
Tracer
. add _ filter {|event , file , line , id , binding , klass| . . . . } (23206.0) -
トレース出力するかどうかを決定するフィルタを追加します。 何もフィルタを与えない場合はすべての行についてトレース情報が出力されます。 与えられた手続き(ブロックまたはProcオブジェクト)が真を返せば トレースは出力されます。
...して event, file, line, id, binding, klass の
6 つをとります。
Kernel.#set_trace_func で指定するものとほぼ同じです。
=== フィルタ手続きのパラメータ
: event
イベントを表す文字列。
以下の種類がある。カッコ内は tracer の出力での......表記。
//emlist{
* line (-) ある行を実行
* call (>) メソッド呼び出し
* return (<) メソッドからのリターン
* class (C) クラスコンテキストに入った
* end (E) クラスコンテキストから出た
* raise 例外が発生した
* c-cal......ッドからreturn
//}
: file
現在処理しているファイルの名前
: line
現在処理している行番号
: id
最後に呼び出されたメソッドのメソッド名(のシンボル)
そのようなメソッドがなければ0になる。
: binding
現在のコンテキ... -
Tracer
:: Single -> Tracer (23201.0) -
@todo
@todo -
Tracer
. set _ get _ line _ procs(filename , proc) (23118.0) -
あるファイルについて利用する、行番号からソースのその行の内容を返す 手続きを指定します。何も指定しなければデフォルトの動作が利用されます。 指定する手続きは行番号を唯一の引数として呼び出されます。
...@param filename ソースファイルの場所を文字列で指定します。
@param proc 通常、文字列を返す手続きオブジェクトを指定します。
# 例 dummy.rb の3行目から6 行目のトレース出力に !! をつける
require 'tracer'
Tracer.set_get_line_procs(......'./dummy.rb'){|line|
str = "\n"
str = "!!\n" if line >= 3 and line <= 6
str
}
Tracer.on
require 'dummy'
dm = Dummy.new
puts dm.number
=begin
# dummy.rb
class Dummy
def initialize
@number = 135
end
attr :number
end
=end...