| \chapter{Exception Handling \label{exceptionHandling}} |
| |
| The functions described in this chapter will let you handle and raise Python |
| exceptions. It is important to understand some of the basics of |
| Python exception handling. It works somewhat like the |
| \UNIX{} \cdata{errno} variable: there is a global indicator (per |
| thread) of the last error that occurred. Most functions don't clear |
| this on success, but will set it to indicate the cause of the error on |
| failure. Most functions also return an error indicator, usually |
| \NULL{} if they are supposed to return a pointer, or \code{-1} if they |
| return an integer (exception: the \cfunction{PyArg_*()} functions |
| return \code{1} for success and \code{0} for failure). |
| |
| When a function must fail because some function it called failed, it |
| generally doesn't set the error indicator; the function it called |
| already set it. It is responsible for either handling the error and |
| clearing the exception or returning after cleaning up any resources it |
| holds (such as object references or memory allocations); it should |
| \emph{not} continue normally if it is not prepared to handle the |
| error. If returning due to an error, it is important to indicate to |
| the caller that an error has been set. If the error is not handled or |
| carefully propagated, additional calls into the Python/C API may not |
| behave as intended and may fail in mysterious ways. |
| |
| The error indicator consists of three Python objects corresponding to |
| \withsubitem{(in module sys)}{ |
| \ttindex{exc_type}\ttindex{exc_value}\ttindex{exc_traceback}} |
| the Python variables \code{sys.exc_type}, \code{sys.exc_value} and |
| \code{sys.exc_traceback}. API functions exist to interact with the |
| error indicator in various ways. There is a separate error indicator |
| for each thread. |
| |
| % XXX Order of these should be more thoughtful. |
| % Either alphabetical or some kind of structure. |
| |
| \begin{cfuncdesc}{void}{PyErr_Print}{} |
| Print a standard traceback to \code{sys.stderr} and clear the error |
| indicator. Call this function only when the error indicator is |
| set. (Otherwise it will cause a fatal error!) |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_Occurred}{} |
| Test whether the error indicator is set. If set, return the |
| exception \emph{type} (the first argument to the last call to one of |
| the \cfunction{PyErr_Set*()} functions or to |
| \cfunction{PyErr_Restore()}). If not set, return \NULL. You do |
| not own a reference to the return value, so you do not need to |
| \cfunction{Py_DECREF()} it. \note{Do not compare the return value |
| to a specific exception; use \cfunction{PyErr_ExceptionMatches()} |
| instead, shown below. (The comparison could easily fail since the |
| exception may be an instance instead of a class, in the case of a |
| class exception, or it may the a subclass of the expected |
| exception.)} |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{int}{PyErr_ExceptionMatches}{PyObject *exc} |
| Equivalent to \samp{PyErr_GivenExceptionMatches(PyErr_Occurred(), |
| \var{exc})}. This should only be called when an exception is |
| actually set; a memory access violation will occur if no exception |
| has been raised. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{int}{PyErr_GivenExceptionMatches}{PyObject *given, PyObject *exc} |
| Return true if the \var{given} exception matches the exception in |
| \var{exc}. If \var{exc} is a class object, this also returns true |
| when \var{given} is an instance of a subclass. If \var{exc} is a |
| tuple, all exceptions in the tuple (and recursively in subtuples) |
| are searched for a match. If \var{given} is \NULL, a memory access |
| violation will occur. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_NormalizeException}{PyObject**exc, PyObject**val, PyObject**tb} |
| Under certain circumstances, the values returned by |
| \cfunction{PyErr_Fetch()} below can be ``unnormalized'', meaning |
| that \code{*\var{exc}} is a class object but \code{*\var{val}} is |
| not an instance of the same class. This function can be used to |
| instantiate the class in that case. If the values are already |
| normalized, nothing happens. The delayed normalization is |
| implemented to improve performance. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_Clear}{} |
| Clear the error indicator. If the error indicator is not set, there |
| is no effect. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_Fetch}{PyObject **ptype, PyObject **pvalue, |
| PyObject **ptraceback} |
| Retrieve the error indicator into three variables whose addresses |
| are passed. If the error indicator is not set, set all three |
| variables to \NULL. If it is set, it will be cleared and you own a |
| reference to each object retrieved. The value and traceback object |
| may be \NULL{} even when the type object is not. \note{This |
| function is normally only used by code that needs to handle |
| exceptions or by code that needs to save and restore the error |
| indicator temporarily.} |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_Restore}{PyObject *type, PyObject *value, |
| PyObject *traceback} |
| Set the error indicator from the three objects. If the error |
| indicator is already set, it is cleared first. If the objects are |
| \NULL, the error indicator is cleared. Do not pass a \NULL{} type |
| and non-\NULL{} value or traceback. The exception type should be a |
| class. Do not pass an invalid exception type or value. |
| (Violating these rules will cause subtle problems later.) This call |
| takes away a reference to each object: you must own a reference to |
| each object before the call and after the call you no longer own |
| these references. (If you don't understand this, don't use this |
| function. I warned you.) \note{This function is normally only used |
| by code that needs to save and restore the error indicator |
| temporarily; use \cfunction{PyErr_Fetch()} to save the current |
| exception state.} |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_SetString}{PyObject *type, char *message} |
| This is the most common way to set the error indicator. The first |
| argument specifies the exception type; it is normally one of the |
| standard exceptions, e.g. \cdata{PyExc_RuntimeError}. You need not |
| increment its reference count. The second argument is an error |
| message; it is converted to a string object. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_SetObject}{PyObject *type, PyObject *value} |
| This function is similar to \cfunction{PyErr_SetString()} but lets |
| you specify an arbitrary Python object for the ``value'' of the |
| exception. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_Format}{PyObject *exception, |
| const char *format, \moreargs} |
| This function sets the error indicator and returns \NULL. |
| \var{exception} should be a Python exception (class, not |
| an instance). \var{format} should be a string, containing format |
| codes, similar to \cfunction{printf()}. The \code{width.precision} |
| before a format code is parsed, but the width part is ignored. |
| |
| \begin{tableii}{c|l}{character}{Character}{Meaning} |
| \lineii{c}{Character, as an \ctype{int} parameter} |
| \lineii{d}{Number in decimal, as an \ctype{int} parameter} |
| \lineii{x}{Number in hexadecimal, as an \ctype{int} parameter} |
| \lineii{s}{A string, as a \ctype{char *} parameter} |
| \lineii{p}{A hex pointer, as a \ctype{void *} parameter} |
| \end{tableii} |
| |
| An unrecognized format character causes all the rest of the format |
| string to be copied as-is to the result string, and any extra |
| arguments discarded. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_SetNone}{PyObject *type} |
| This is a shorthand for \samp{PyErr_SetObject(\var{type}, |
| Py_None)}. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{int}{PyErr_BadArgument}{} |
| This is a shorthand for \samp{PyErr_SetString(PyExc_TypeError, |
| \var{message})}, where \var{message} indicates that a built-in |
| operation was invoked with an illegal argument. It is mostly for |
| internal use. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_NoMemory}{} |
| This is a shorthand for \samp{PyErr_SetNone(PyExc_MemoryError)}; it |
| returns \NULL{} so an object allocation function can write |
| \samp{return PyErr_NoMemory();} when it runs out of memory. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_SetFromErrno}{PyObject *type} |
| This is a convenience function to raise an exception when a C |
| library function has returned an error and set the C variable |
| \cdata{errno}. It constructs a tuple object whose first item is the |
| integer \cdata{errno} value and whose second item is the |
| corresponding error message (gotten from |
| \cfunction{strerror()}\ttindex{strerror()}), and then calls |
| \samp{PyErr_SetObject(\var{type}, \var{object})}. On \UNIX, when |
| the \cdata{errno} value is \constant{EINTR}, indicating an |
| interrupted system call, this calls |
| \cfunction{PyErr_CheckSignals()}, and if that set the error |
| indicator, leaves it set to that. The function always returns |
| \NULL, so a wrapper function around a system call can write |
| \samp{return PyErr_SetFromErrno(\var{type});} when the system call |
| returns an error. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_SetFromErrnoWithFilename}{PyObject *type, |
| char *filename} |
| Similar to \cfunction{PyErr_SetFromErrno()}, with the additional |
| behavior that if \var{filename} is not \NULL, it is passed to the |
| constructor of \var{type} as a third parameter. In the case of |
| exceptions such as \exception{IOError} and \exception{OSError}, this |
| is used to define the \member{filename} attribute of the exception |
| instance. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_SetFromWindowsErr}{int ierr} |
| This is a convenience function to raise \exception{WindowsError}. |
| If called with \var{ierr} of \cdata{0}, the error code returned by a |
| call to \cfunction{GetLastError()} is used instead. It calls the |
| Win32 function \cfunction{FormatMessage()} to retrieve the Windows |
| description of error code given by \var{ierr} or |
| \cfunction{GetLastError()}, then it constructs a tuple object whose |
| first item is the \var{ierr} value and whose second item is the |
| corresponding error message (gotten from |
| \cfunction{FormatMessage()}), and then calls |
| \samp{PyErr_SetObject(\var{PyExc_WindowsError}, \var{object})}. |
| This function always returns \NULL. |
| Availability: Windows. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_SetExcFromWindowsErr}{PyObject *type, |
| int ierr} |
| Similar to \cfunction{PyErr_SetFromWindowsErr()}, with an additional |
| parameter specifying the exception type to be raised. |
| Availability: Windows. |
| \versionadded{2.3} |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_SetFromWindowsErrWithFilename}{int ierr, |
| char *filename} |
| Similar to \cfunction{PyErr_SetFromWindowsErr()}, with the |
| additional behavior that if \var{filename} is not \NULL, it is |
| passed to the constructor of \exception{WindowsError} as a third |
| parameter. |
| Availability: Windows. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_SetExcFromWindowsErrWithFilename} |
| {PyObject *type, int ierr, char *filename} |
| Similar to \cfunction{PyErr_SetFromWindowsErrWithFilename()}, with |
| an additional parameter specifying the exception type to be raised. |
| Availability: Windows. |
| \versionadded{2.3} |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_BadInternalCall}{} |
| This is a shorthand for \samp{PyErr_SetString(PyExc_TypeError, |
| \var{message})}, where \var{message} indicates that an internal |
| operation (e.g. a Python/C API function) was invoked with an illegal |
| argument. It is mostly for internal use. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{int}{PyErr_Warn}{PyObject *category, char *message} |
| Issue a warning message. The \var{category} argument is a warning |
| category (see below) or \NULL; the \var{message} argument is a |
| message string. |
| |
| This function normally prints a warning message to \var{sys.stderr}; |
| however, it is also possible that the user has specified that |
| warnings are to be turned into errors, and in that case this will |
| raise an exception. It is also possible that the function raises an |
| exception because of a problem with the warning machinery (the |
| implementation imports the \module{warnings} module to do the heavy |
| lifting). The return value is \code{0} if no exception is raised, |
| or \code{-1} if an exception is raised. (It is not possible to |
| determine whether a warning message is actually printed, nor what |
| the reason is for the exception; this is intentional.) If an |
| exception is raised, the caller should do its normal exception |
| handling (for example, \cfunction{Py_DECREF()} owned references and |
| return an error value). |
| |
| Warning categories must be subclasses of \cdata{Warning}; the |
| default warning category is \cdata{RuntimeWarning}. The standard |
| Python warning categories are available as global variables whose |
| names are \samp{PyExc_} followed by the Python exception name. |
| These have the type \ctype{PyObject*}; they are all class objects. |
| Their names are \cdata{PyExc_Warning}, \cdata{PyExc_UserWarning}, |
| \cdata{PyExc_DeprecationWarning}, \cdata{PyExc_SyntaxWarning}, |
| \cdata{PyExc_RuntimeWarning}, and \cdata{PyExc_FutureWarning}. |
| \cdata{PyExc_Warning} is a subclass of \cdata{PyExc_Exception}; the |
| other warning categories are subclasses of \cdata{PyExc_Warning}. |
| |
| For information about warning control, see the documentation for the |
| \module{warnings} module and the \programopt{-W} option in the |
| command line documentation. There is no C API for warning control. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{int}{PyErr_WarnExplicit}{PyObject *category, char *message, |
| char *filename, int lineno, char *module, PyObject *registry} |
| Issue a warning message with explicit control over all warning |
| attributes. This is a straightforward wrapper around the Python |
| function \function{warnings.warn_explicit()}, see there for more |
| information. The \var{module} and \var{registry} arguments may be |
| set to \NULL{} to get the default effect described there. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{int}{PyErr_CheckSignals}{} |
| This function interacts with Python's signal handling. It checks |
| whether a signal has been sent to the processes and if so, invokes |
| the corresponding signal handler. If the |
| \module{signal}\refbimodindex{signal} module is supported, this can |
| invoke a signal handler written in Python. In all cases, the |
| default effect for \constant{SIGINT}\ttindex{SIGINT} is to raise the |
| \withsubitem{(built-in exception)}{\ttindex{KeyboardInterrupt}} |
| \exception{KeyboardInterrupt} exception. If an exception is raised |
| the error indicator is set and the function returns \code{1}; |
| otherwise the function returns \code{0}. The error indicator may or |
| may not be cleared if it was previously set. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_SetInterrupt}{} |
| This function is obsolete. It simulates the effect of a |
| \constant{SIGINT}\ttindex{SIGINT} signal arriving --- the next time |
| \cfunction{PyErr_CheckSignals()} is called, |
| \withsubitem{(built-in exception)}{\ttindex{KeyboardInterrupt}} |
| \exception{KeyboardInterrupt} will be raised. It may be called |
| without holding the interpreter lock. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{PyObject*}{PyErr_NewException}{char *name, |
| PyObject *base, |
| PyObject *dict} |
| This utility function creates and returns a new exception object. |
| The \var{name} argument must be the name of the new exception, a C |
| string of the form \code{module.class}. The \var{base} and |
| \var{dict} arguments are normally \NULL. This creates a class |
| object derived from the root for all exceptions, the built-in name |
| \exception{Exception} (accessible in C as \cdata{PyExc_Exception}). |
| The \member{__module__} attribute of the new class is set to the |
| first part (up to the last dot) of the \var{name} argument, and the |
| class name is set to the last part (after the last dot). The |
| \var{base} argument can be used to specify an alternate base class. |
| The \var{dict} argument can be used to specify a dictionary of class |
| variables and methods. |
| \end{cfuncdesc} |
| |
| \begin{cfuncdesc}{void}{PyErr_WriteUnraisable}{PyObject *obj} |
| This utility function prints a warning message to \code{sys.stderr} |
| when an exception has been set but it is impossible for the |
| interpreter to actually raise the exception. It is used, for |
| example, when an exception occurs in an \method{__del__()} method. |
| |
| The function is called with a single argument \var{obj} that |
| identifies the context in which the unraisable exception occurred. |
| The repr of \var{obj} will be printed in the warning message. |
| \end{cfuncdesc} |
| |
| \section{Standard Exceptions \label{standardExceptions}} |
| |
| All standard Python exceptions are available as global variables whose |
| names are \samp{PyExc_} followed by the Python exception name. These |
| have the type \ctype{PyObject*}; they are all class objects. For |
| completeness, here are all the variables: |
| |
| \begin{tableiii}{l|l|c}{cdata}{C Name}{Python Name}{Notes} |
| \lineiii{PyExc_Exception}{\exception{Exception}}{(1)} |
| \lineiii{PyExc_StandardError}{\exception{StandardError}}{(1)} |
| \lineiii{PyExc_ArithmeticError}{\exception{ArithmeticError}}{(1)} |
| \lineiii{PyExc_LookupError}{\exception{LookupError}}{(1)} |
| \lineiii{PyExc_AssertionError}{\exception{AssertionError}}{} |
| \lineiii{PyExc_AttributeError}{\exception{AttributeError}}{} |
| \lineiii{PyExc_EOFError}{\exception{EOFError}}{} |
| \lineiii{PyExc_EnvironmentError}{\exception{EnvironmentError}}{(1)} |
| \lineiii{PyExc_FloatingPointError}{\exception{FloatingPointError}}{} |
| \lineiii{PyExc_IOError}{\exception{IOError}}{} |
| \lineiii{PyExc_ImportError}{\exception{ImportError}}{} |
| \lineiii{PyExc_IndexError}{\exception{IndexError}}{} |
| \lineiii{PyExc_KeyError}{\exception{KeyError}}{} |
| \lineiii{PyExc_KeyboardInterrupt}{\exception{KeyboardInterrupt}}{} |
| \lineiii{PyExc_MemoryError}{\exception{MemoryError}}{} |
| \lineiii{PyExc_NameError}{\exception{NameError}}{} |
| \lineiii{PyExc_NotImplementedError}{\exception{NotImplementedError}}{} |
| \lineiii{PyExc_OSError}{\exception{OSError}}{} |
| \lineiii{PyExc_OverflowError}{\exception{OverflowError}}{} |
| \lineiii{PyExc_ReferenceError}{\exception{ReferenceError}}{(2)} |
| \lineiii{PyExc_RuntimeError}{\exception{RuntimeError}}{} |
| \lineiii{PyExc_SyntaxError}{\exception{SyntaxError}}{} |
| \lineiii{PyExc_SystemError}{\exception{SystemError}}{} |
| \lineiii{PyExc_SystemExit}{\exception{SystemExit}}{} |
| \lineiii{PyExc_TypeError}{\exception{TypeError}}{} |
| \lineiii{PyExc_ValueError}{\exception{ValueError}}{} |
| \lineiii{PyExc_WindowsError}{\exception{WindowsError}}{(3)} |
| \lineiii{PyExc_ZeroDivisionError}{\exception{ZeroDivisionError}}{} |
| \end{tableiii} |
| |
| \noindent |
| Notes: |
| \begin{description} |
| \item[(1)] |
| This is a base class for other standard exceptions. |
| |
| \item[(2)] |
| This is the same as \exception{weakref.ReferenceError}. |
| |
| \item[(3)] |
| Only defined on Windows; protect code that uses this by testing that |
| the preprocessor macro \code{MS_WINDOWS} is defined. |
| \end{description} |
| |
| |
| \section{Deprecation of String Exceptions} |
| |
| All exceptions built into Python or provided in the standard library |
| are derived from \exception{Exception}. |
| \withsubitem{(built-in exception)}{\ttindex{Exception}} |
| |
| String exceptions are still supported in the interpreter to allow |
| existing code to run unmodified, but this will also change in a future |
| release. |