Я пытаюсь понять ошибки и исключения в Tcl. Я написал небольшой код следующим образом
proc Div3 {a b} {
return [Div2 $a $b]
}
proc Div2 {a b} {
return [Div $a $b]
}
proc Div {a b} {
if {$b == 0} {
error "Error generated by error" "Info String for error" 401
} else {
return [expr $a/$b]
}
}
if {[catch {puts "Result = [Div3 10 0]"} errmsg]} {
puts "ErrorMsg: $errmsg"
puts "ErrorCode: $errorCode"
puts "ErrorInfo:\n$errorInfo\n"
}
когда я запускаю это с помощью tclsh.exe
, вывод отладчика отображается следующим образом:
% tclsh error-file-1.tcl
ErrorMsg: Error generated by error
ErrorCode: 401
ErrorInfo:
Info String for error
(procedure "Div" line 1)
invoked from within
"Div $a $b"
(procedure "Div2" line 2)
invoked from within
"Div2 $a $b"
(procedure "Div3" line 2)
invoked from within
"Div3 10 0"
Однако, когда я запускаю то же самое, используя tclsh.exe
через Komodo IDE, я получаю вывод отладчика следующим образом
ErrorMsg: Error generated by error
ErrorCode: 401
ErrorInfo:
Info String for error
invoked from within
"DbgNub_uplevelCmd 1 $cmd"
invoked from within
"Div $a $b"
invoked from within
"DbgNub_uplevelCmd 1 $cmd"
invoked from within
"Div2 $a $b"
invoked from within
"DbgNub_uplevelCmd 1 $cmd"
invoked from within
"Div3 10 0"
invoked from within
"DbgNub_uplevelCmd 1 $cmd"
invoked from within
"DbgNub_Do 0 {1 17 {249 27}} {puts "Result = [DbgNub_Do 1 {1 17 {265 9}} {Div3 10 0}]"}"
Я могу понять вывод отладчика из tclsh.exe
, но не могу интерпретировать вывод отладчика из Komodo IDE.
особенно, я не могу понять DbgNub_Do 0 {1 17 {249 27}} {puts "Result = [DbgNub_Do 1 {1 17 {265 9}} {Div3 10 0}]"}
какие числа указаны в списках (т.е. {1 17 {249 27}}
) и DbgNub_uplevelCmd 1 $cmd
и DbgNub_Do
заранее спасибо
proc
своей собственной, чтобы добавить отладочную информацию, поэтому вы видите трассировку стека, которая включает ее. Кстати, запуск через tclsh напрямую не использует отладчик. - person Shawn   schedule 23.03.2020tclsh.exe
- person The_Learner   schedule 23.03.2020