dwww Home | Manual pages | Find package

try(3tcl)                    Tcl Built-In Commands                   try(3tcl)

______________________________________________________________________________

NAME
       try - Trap and process errors and exceptions

SYNOPSIS
       try body ?handler...? ?finally script?
______________________________________________________________________________

DESCRIPTION
       This  command  executes the script body and, depending on what the out-
       come of that script is (normal exit, error, or some  other  exceptional
       result), runs a handler script to deal with the case. Once that has all
       happened, if the finally clause is present, the script it includes will
       be  run  and  the  result  of  the  handler  (or the body if no handler
       matched) is allowed to continue to propagate.  Note  that  the  finally
       clause  is processed even if an error occurs and irrespective of which,
       if any, handler is used.

       The handler clauses are each expressed as several words, and must  have
       one of the following forms:

       on code variableList script
              This clause matches if the evaluation of body completed with the
              exception code code. The code may be expressed as an integer  or
              one of the following literal words: ok, error, return, break, or
              continue. Those literals correspond to the integers 0 through  4
              respectively.

       trap pattern variableList script
              This clause matches if the evaluation of body resulted in an er-
              ror and the prefix of the -errorcode from the interpreter's sta-
              tus  dictionary  is  equal  to the pattern. The number of prefix
              words taken from the -errorcode is equal to the  list-length  of
              pattern,  and  inter-word spaces are normalized in both the -er-
              rorcode and pattern before comparison.

       The variableList word in each handler is always interpreted as  a  list
       of  variable  names.  If the first word of the list is present and non-
       empty, it names a variable into which the result of the  evaluation  of
       body  (from  the main try) will be placed; this will contain the human-
       readable form of any errors. If the second word of the list is  present
       and non-empty, it names a variable into which the options dictionary of
       the interpreter at the moment of completion of execution of  body  will
       be placed.

       The script word of each handler is also always interpreted the same: as
       a Tcl script to evaluate if the clause is matched. If script is a  lit-
       eral “-” and the handler is not the last one, the script of the follow-
       ing handler is invoked instead (just like with the switch command).

       Note that handler clauses are matched against in order,  and  that  the
       first  matching one is always selected. At most one handler clause will
       selected. As a consequence, an on error will mask any  subsequent  trap
       in the try. Also note that on error is equivalent to trap {}.

       If  an  exception (i.e. any non-ok result) occurs during the evaluation
       of either the handler or the finally clause, the  original  exception's
       status  dictionary  will be added to the new exception's status dictio-
       nary under the -during key.

EXAMPLES
       Ensure that a file is closed no matter what:

              set f [open /some/file/name a]
              try {
                  puts $f "some message"
                  # ...
              } finally {
                  close $f
              }

       Handle different reasons for a file to not be openable for reading:

              try {
                  set f [open /some/file/name w]
              } trap {POSIX EISDIR} {} {
                  puts "failed to open /some/file/name: it's a directory"
              } trap {POSIX ENOENT} {} {
                  puts "failed to open /some/file/name: it doesn't exist"
              }

SEE ALSO
       catch(3tcl), error(3tcl), return(3tcl), throw(3tcl)

KEYWORDS
       cleanup, error, exception, final, resource management

Tcl                                   8.6                            try(3tcl)

Generated by dwww version 1.14 on Thu Jan 23 00:19:22 CET 2025.