DOC HOME SITE MAP MAN PAGES GNU INFO SEARCH PRINT BOOK
 

Tcl_Panic(3tcl)




Tcl_Panic(3)         Tcl Library Procedures          Tcl_Panic(3)

_________________________________________________________________


NAME

     Tcl_Panic,  Tcl_PanicVA,  Tcl_SetPanicProc  -  report  fatal
     error and abort


SYNOPSIS

     #include <tcl.h>

     void
     Tcl_Panic(format, arg, arg, ...)

     void
     Tcl_PanicVA(format, argList)

     void
     Tcl_SetPanicProc(panicProc)


ARGUMENTS

     const char* format (in)                A printf-style format
                                            string.

      arg (in)                              Arguments    matching
                                            the format string.

     va_list argList (in)                   An argument  list  of
                                            arguments    matching
                                            the  format   string.
                                            Must  have  been ini-
                                            tialized        using
                                            va_start, and cleared
                                            using va_end.

     Tcl_PanicProc *panicProc (in)          Procedure  to  report
                                            fatal  error  message
                                            and abort.

_________________________________________________________________


DESCRIPTION

     When the Tcl library detects that its internal  data  struc-
     tures are in an inconsistent state, or that its C procedures
     have been called in a manner inconsistent with  their  docu-
     mentation,  it calls Tcl_Panic to display a message describ-
     ing the error and abort the process.  The format argument is
     a format string describing how to format the remaining argu-
     ments arg into an error message, according to the same  for-
     matting  rules  used by the printf family of functions.  The
     same formatting rules are also used by the built-in Tcl com-
     mand format.

Tcl                     Last change: 8.4                        1

Tcl_Panic(3)         Tcl Library Procedures          Tcl_Panic(3)

     In a freshly loaded Tcl library, Tcl_Panic prints  the  for-
     matted  error message to the standard error file of the pro-
     cess,  and  then  calls  abort  to  terminate  the  process.
     Tcl_Panic does not return.

     Tcl_SetPanicProc may be  used  to  modify  the  behavior  of
     Tcl_Panic.   The  panicProc  argument  should match the type
     Tcl_PanicProc:

          typedef void Tcl_PanicProc(
                  const char *format,
                  arg, arg,...);

     After  Tcl_SetPanicProc  returns,  any   future   calls   to
     Tcl_Panic  will call panicProc, passing along the format and
     arg arguments.  To maintain consistency with the callers  of
     Tcl_Panic,  panicProc  must  not return; it must call abort.
     panicProc should avoid making calls into the Tcl library, or
     into  other  libraries  that may call the Tcl library, since
     the original call to Tcl_Panic indicates the Tcl library  is
     not in a state of reliable operation.

     The typical use of Tcl_SetPanicProc arranges for  the  error
     message  to  be displayed or reported in a manner more suit-
     able for the application or the platform.   As  an  example,
     the Windows implementation of wish calls Tcl_SetPanicProc to
     force all panic messages to be displayed in a system  dialog
     box,  rather  than  to be printed to the standard error file
     (usually not visible under Windows).

     Although the primary callers of Tcl_Panic are the procedures
     of  the  Tcl library, Tcl_Panic is a public function and may
     be called by any extension or  application  that  wishes  to
     abort  the  process  and  have a panic message displayed the
     same way that panic messages from Tcl will be displayed.

     Tcl_PanicVA is the same as Tcl_Panic except that instead  of
     taking  a  variable number of arguments it takes an argument
     list.


SEE ALSO

     abort(3), printf(3), exec(n), format(n)


KEYWORDS

     abort, fatal, error

Tcl                     Last change: 8.4                        2


Man(1) output converted with man2html