putsコマンドがstdoutに送信するものをログファイルに複製するTclコードを探しています。はい、いくつかのカスタム関数へのプットへのすべての呼び出しを変更する可能性があります。でも、なるべく透明にしたいと思います。私はこのトライアルコードを持っていますが、実際にはうまく機能しません:
set pass_log_output "0"
rename puts _puts
proc puts { args } {
global pass_log_output
if {[info exists pass_log_output]} {
# There can be several cases:
# -nonewline parameter, stdout specified or not
set stdout_dest [ lsearch $args stdout ]
set nonewline [ lsearch $args -nonewline ]
if { $stdout_dest != -1 } {
log_low_level "" [lindex $args [expr $stdout_dest + 1]] ""
} elseif { $nonewline != -1 && [ llength $args ] > 1} {
log_low_level "" [lindex $args [expr $nonewline + 1]] ""
} else {
log_low_level "" [lindex $args 0] ""
}
}
if { [ catch { eval _puts $args } err ] } {
return -code error $err
}
}
log_low_level関数は、渡された文字列をファイルに格納するだけです。これまでのところ、このエラーが発生しています。
Tcl Interpreter Error: too many nested evaluations (infinite loop?)