2017-08-29 14 views

答えて

1

グローバル変数errorInfoを見ると、必要な情報を含むスタックトレースが表示されます。また、errMsgの後にcatchコールに余分な可変引数を追加すると、その情報にエラー情報のトレースと他のもの(コンピュータが読み取り可能な例外コードなど)が含まれる辞書が書き込まれます。


[EDIT]:Tclの8.6では、例外オプション辞書が呼び出されている内容の説明が含まれている要素-errorstackを持っています。ここではこのことを示し、対話型セッションです:

% proc foo {x} {error $x} 
% proc bar c {catch {puts a;foo $c} a b;return $b} 
% bar d 
a 
-code 1 -level 0 -errorstack {INNER {returnImm d {}} CALL {foo d} CALL {bar d}} -errorcode NONE -errorinfo {d 
    while executing 
"error $x" 
    (procedure "foo" line 1) 
    invoked from within 
"foo $c"} -errorline 1 

エラー・スタックは、様々な事柄のための要素のペアを持っていますが、重要なものは、各ペアの2番目の要素はなかった引数のリストですCALLタイプのもの、あります実際に電話をかけるために使用されます。これを使って名前を得ることは可能かもしれません。 (INNERタイプは、Tclバイトコードエンジンの実行状態を参照しています。他のタイプがあるかどうかはわかりません)

+0

'errMsg'の後に余分な変数を追加しようとしました。 '-errorinfo'キーの下にプロシージャ名をキャッチしますが、エラーメッセージ文字列の一部です。つまり、文字列を解析して名前を取得する必要があります。私はそれを得るためのよりクリーンな方法があると思った。 –

+1

@ Mr.SrJenea _Perhaps_あります。 8.6のエラースタック情報が役立つかもしれません。またはそうでないかもしれません;私はリストのどこに見えるかを決めるのにそれを解析する最善の方法が何であるか全く分かりません。 –

+0

私の要件はバージョン8.5に制限されています。私は複数の 'catch'ブロックを持つか、' regexp'を使ってプロシージャ名を抽出するかのいずれかになります。ありがとう –

関連する問題