Tcl - Obsługa błędów

Obsługa błędów w Tcl jest zapewniana przy pomocy error i catchpolecenia. Poniżej przedstawiono składnię każdego z tych poleceń.

Składnia błędu

error message info code

W powyższej składni polecenia błędu komunikat jest komunikatem błędu, informacja jest ustawiana w zmiennej globalnej errorInfo, a kod jest ustawiany w zmiennej globalnej errorCode.

Catch Składnia

catch script resultVarName

W powyższej składni polecenia catch skrypt jest kodem do wykonania, a resultVarName jest zmienną przechowującą błąd lub wynik. Polecenie catch zwraca 0, jeśli nie ma błędu, i 1, jeśli wystąpił błąd.

Poniżej przedstawiono przykład prostej obsługi błędów -

#!/usr/bin/tclsh

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 = [Div 10 0]"} errmsg]} {
   puts "ErrorMsg: $errmsg"
   puts "ErrorCode: $errorCode"
   puts "ErrorInfo:\n$errorInfo\n"
}

if {[catch {puts "Result = [Div 10 2]"} errmsg]} {
   puts "ErrorMsg: $errmsg"
   puts "ErrorCode: $errorCode"
   puts "ErrorInfo:\n$errorInfo\n"
}

Wykonanie powyższego kodu daje następujący wynik -

ErrorMsg: Error generated by error
ErrorCode: 401
ErrorInfo:
Info String for error
   (procedure "Div" line 1)
   invoked from within
"Div 10 0"

Result = 5

Jak widać w powyższym przykładzie, możemy tworzyć własne niestandardowe komunikaty o błędach. Podobnie można wyłapać błąd generowany przez Tcl. Przykład pokazano poniżej -

#!/usr/bin/tclsh

catch {set file [open myNonexistingfile.txt]} result
puts "ErrorMsg: $result"
puts "ErrorCode: $errorCode"
puts "ErrorInfo:\n$errorInfo\n"

Wykonanie powyższego kodu daje następujący wynik -

ErrorMsg: couldn't open "myNonexistingfile.txt": no such file or directory
ErrorCode: POSIX ENOENT {no such file or directory}
ErrorInfo:
couldn't open "myNonexistingfile.txt": no such file or directory
   while executing
"open myNonexistingfile.txt"