Ruby デバッガです。Ruby スクリプトのソースコードデバッグに使用します。
また、Emacs を使用したインタフェース rubydb3x.el が https://github.com/ruby/elisp にあるので、活用してください。
$ ruby -rdebug foo.rb
または、Emacs から
M-x load-library rubydb3x.el M-x rubydb
以下は、デバッガで使用できるコマンド名とその用法の一覧です。各コマンド名には省略形があります。
ここに挙げたもの以外を入力した場合、その入力を ruby の式として評価します。
ブレークポイントを設定します。引数を省略した場合設定したブレークポイントを表示します。
設定するブレークポイントの書式は プログラムファイル名:位置 かクラス名:メソッド名 です。位置 はファイル中の行番号もしくはメソッド名で指定します。ファイル名: を省略した場合は現在実行中のファイルを指定したものと見倣されます。
このコマンドの省略形は b です。
例外が発生した時にデバッガを停止させるキャッチポイントを設定します。引数を省略した場合設定したキャッチポイントを表示します。
発生した例外が <an Exception> のサブクラスであればデバッガが停止します。デフォルトのキャッチポイントは StandardErrorに設定されています。
<an Exception>として off を指定すると例外発生時に停止しなくなります。
このコマンドの省略形は cat です。
式 <expression> の値が変化したときに停止するウォッチポイントを設定します。
このコマンドの省略形は wat です。
指定したブレークポイントを取り除きます。引数を省略した場合すべてのブレークポイントを取り除きます。
このコマンドの省略形は del です。
処理が停止するごとに <expression> を評価するディスプレイ式を設定します。引数を省略した場合すべてのディスプレイ式を表示します。
このコマンドの省略形は disp です。
指定したディスプレイ式を取り除きます。引数を省略した場合すべてのディスプレイ式を取り除きます。
このコマンドの省略形は undisp です。
スクリプトが終了するまで、もしくは次のブレークポイントに到達するまで処理を続行します。
このコマンドの省略形は c です。
一行ずつ処理を実行します。引数を指定した場合、指定した行数分、処理を続行します。メソッドの中に入ります。
このコマンドの省略形は s です。
一行ずつ処理を実行します。引数を指定した場合、指定した行数分、処理を続行します。step [nnn]との違いは、メソッド呼び出しのところでそのメソッドの中に入らないことです。
このコマンドの省略形は n です。
フレームのスタックと、現在のフレーム位置を表示します。
このコマンドの省略形は w または f です。
スクリプトを表示します。引数が `-' ならば前の行を表示します。 nn-mm の形式では指定した範囲の行のスクリプトを表示します。
このコマンドの省略形は l です。
上位のフレームに上がります。
下位のフレームに下がります。
外側のフレームに上がるまで処理を続行します。
このコマンドの省略形は fin です。
トレースモードの設定を変更します。トレースモードをonにすると、以後の実行においてメソッドの呼び出し関係が表示されます。引数を省略した場合現在のモードを表示します。all を指定した場合、全てのスレッドに対してモードの設定を変更します。
このコマンドの省略形は tr です。
スクリプトを中断し、デバッガを終了します。
このコマンドの省略形は q です。
それぞれ、グローバル変数、ローカル変数、オブジェクト<object>のインスタンス変数、<object>の定数を表示します。
このコマンドの省略形は v です。
それぞれ、オブジェクト<object>のインスタンスメソッドクラスメソッド または モジュールメソッドを表示します。
このコマンドの省略形は m です。
スレッドの一覧を表示します。
このコマンドの省略形は th です。
現在のスレッドを表示します。
実行するスレッドを <nnn> に切替えます。
スレッド <nnn> を停止します。
スレッド <nnn> を再開します。
ruby の式 <expression> の結果を見やすく表示します。
ruby の式 <expression> の結果を表示します。
プログラムを最初からやり直します。
このコマンドの省略形は r です。
デバッグコマンドの一覧を表示します。
このコマンドの省略形は h です。
このライブラリは $SAFE が 0 より大きい場合には使用できません。
DEBUGGER__ | ライブラリの内部で使用します。 |