Orbits  1
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Macros Pages
pyerrors.h
Go to the documentation of this file.
1 #ifndef Py_ERRORS_H
2 #define Py_ERRORS_H
3 #ifdef __cplusplus
4 extern "C" {
5 #endif
6 
7 /* Error objects */
8 
9 typedef struct {
15 
16 typedef struct {
28 
29 #ifdef Py_USING_UNICODE
30 typedef struct {
32  PyObject *dict;
33  PyObject *args;
34  PyObject *message;
38  Py_ssize_t end;
39  PyObject *reason;
40 } PyUnicodeErrorObject;
41 #endif
42 
43 typedef struct {
50 
51 typedef struct {
60 
61 #ifdef MS_WINDOWS
62 typedef struct {
64  PyObject *dict;
65  PyObject *args;
66  PyObject *message;
67  PyObject *myerrno;
68  PyObject *strerror;
69  PyObject *filename;
70  PyObject *winerror;
71 } PyWindowsErrorObject;
72 #endif
73 
74 /* Error handling definitions */
75 
76 PyAPI_FUNC(void) PyErr_SetNone(PyObject *);
77 PyAPI_FUNC(void) PyErr_SetObject(PyObject *, PyObject *);
78 PyAPI_FUNC(void) PyErr_SetString(PyObject *, const char *);
79 PyAPI_FUNC(PyObject *) PyErr_Occurred(void);
80 PyAPI_FUNC(void) PyErr_Clear(void);
81 PyAPI_FUNC(void) PyErr_Fetch(PyObject **, PyObject **, PyObject **);
82 PyAPI_FUNC(void) PyErr_Restore(PyObject *, PyObject *, PyObject *);
83 
84 #ifdef Py_DEBUG
85 #define _PyErr_OCCURRED() PyErr_Occurred()
86 #else
87 #define _PyErr_OCCURRED() (_PyThreadState_Current->curexc_type)
88 #endif
89 
90 /* Error testing and normalization */
91 PyAPI_FUNC(int) PyErr_GivenExceptionMatches(PyObject *, PyObject *);
92 PyAPI_FUNC(int) PyErr_ExceptionMatches(PyObject *);
93 PyAPI_FUNC(void) PyErr_NormalizeException(PyObject**, PyObject**, PyObject**);
94 
95 /* */
96 
97 #define PyExceptionClass_Check(x) \
98  (PyClass_Check((x)) || (PyType_Check((x)) && \
99  PyType_FastSubclass((PyTypeObject*)(x), Py_TPFLAGS_BASE_EXC_SUBCLASS)))
100 
101 #define PyExceptionInstance_Check(x) \
102  (PyInstance_Check((x)) || \
103  PyType_FastSubclass((x)->ob_type, Py_TPFLAGS_BASE_EXC_SUBCLASS))
104 
105 #define PyExceptionClass_Name(x) \
106  (PyClass_Check((x)) \
107  ? PyString_AS_STRING(((PyClassObject*)(x))->cl_name) \
108  : (char *)(((PyTypeObject*)(x))->tp_name))
109 
110 #define PyExceptionInstance_Class(x) \
111  ((PyInstance_Check((x)) \
112  ? (PyObject*)((PyInstanceObject*)(x))->in_class \
113  : (PyObject*)((x)->ob_type)))
114 
115 
116 /* Predefined exceptions */
117 
118 PyAPI_DATA(PyObject *) PyExc_BaseException;
119 PyAPI_DATA(PyObject *) PyExc_Exception;
120 PyAPI_DATA(PyObject *) PyExc_StopIteration;
121 PyAPI_DATA(PyObject *) PyExc_GeneratorExit;
122 PyAPI_DATA(PyObject *) PyExc_StandardError;
123 PyAPI_DATA(PyObject *) PyExc_ArithmeticError;
124 PyAPI_DATA(PyObject *) PyExc_LookupError;
125 
126 PyAPI_DATA(PyObject *) PyExc_AssertionError;
127 PyAPI_DATA(PyObject *) PyExc_AttributeError;
128 PyAPI_DATA(PyObject *) PyExc_EOFError;
129 PyAPI_DATA(PyObject *) PyExc_FloatingPointError;
130 PyAPI_DATA(PyObject *) PyExc_EnvironmentError;
131 PyAPI_DATA(PyObject *) PyExc_IOError;
132 PyAPI_DATA(PyObject *) PyExc_OSError;
133 PyAPI_DATA(PyObject *) PyExc_ImportError;
134 PyAPI_DATA(PyObject *) PyExc_IndexError;
135 PyAPI_DATA(PyObject *) PyExc_KeyError;
136 PyAPI_DATA(PyObject *) PyExc_KeyboardInterrupt;
137 PyAPI_DATA(PyObject *) PyExc_MemoryError;
138 PyAPI_DATA(PyObject *) PyExc_NameError;
139 PyAPI_DATA(PyObject *) PyExc_OverflowError;
140 PyAPI_DATA(PyObject *) PyExc_RuntimeError;
141 PyAPI_DATA(PyObject *) PyExc_NotImplementedError;
142 PyAPI_DATA(PyObject *) PyExc_SyntaxError;
143 PyAPI_DATA(PyObject *) PyExc_IndentationError;
144 PyAPI_DATA(PyObject *) PyExc_TabError;
145 PyAPI_DATA(PyObject *) PyExc_ReferenceError;
146 PyAPI_DATA(PyObject *) PyExc_SystemError;
147 PyAPI_DATA(PyObject *) PyExc_SystemExit;
148 PyAPI_DATA(PyObject *) PyExc_TypeError;
149 PyAPI_DATA(PyObject *) PyExc_UnboundLocalError;
150 PyAPI_DATA(PyObject *) PyExc_UnicodeError;
151 PyAPI_DATA(PyObject *) PyExc_UnicodeEncodeError;
152 PyAPI_DATA(PyObject *) PyExc_UnicodeDecodeError;
153 PyAPI_DATA(PyObject *) PyExc_UnicodeTranslateError;
154 PyAPI_DATA(PyObject *) PyExc_ValueError;
155 PyAPI_DATA(PyObject *) PyExc_ZeroDivisionError;
156 #ifdef MS_WINDOWS
157 PyAPI_DATA(PyObject *) PyExc_WindowsError;
158 #endif
159 #ifdef __VMS
160 PyAPI_DATA(PyObject *) PyExc_VMSError;
161 #endif
162 
163 PyAPI_DATA(PyObject *) PyExc_BufferError;
164 
165 PyAPI_DATA(PyObject *) PyExc_MemoryErrorInst;
166 PyAPI_DATA(PyObject *) PyExc_RecursionErrorInst;
167 
168 /* Predefined warning categories */
169 PyAPI_DATA(PyObject *) PyExc_Warning;
170 PyAPI_DATA(PyObject *) PyExc_UserWarning;
171 PyAPI_DATA(PyObject *) PyExc_DeprecationWarning;
172 PyAPI_DATA(PyObject *) PyExc_PendingDeprecationWarning;
173 PyAPI_DATA(PyObject *) PyExc_SyntaxWarning;
174 PyAPI_DATA(PyObject *) PyExc_RuntimeWarning;
175 PyAPI_DATA(PyObject *) PyExc_FutureWarning;
176 PyAPI_DATA(PyObject *) PyExc_ImportWarning;
177 PyAPI_DATA(PyObject *) PyExc_UnicodeWarning;
178 PyAPI_DATA(PyObject *) PyExc_BytesWarning;
179 
180 
181 /* Convenience functions */
182 
183 PyAPI_FUNC(int) PyErr_BadArgument(void);
184 PyAPI_FUNC(PyObject *) PyErr_NoMemory(void);
185 PyAPI_FUNC(PyObject *) PyErr_SetFromErrno(PyObject *);
186 PyAPI_FUNC(PyObject *) PyErr_SetFromErrnoWithFilenameObject(
187  PyObject *, PyObject *);
188 PyAPI_FUNC(PyObject *) PyErr_SetFromErrnoWithFilename(
189  PyObject *, const char *);
190 #ifdef MS_WINDOWS
191 PyAPI_FUNC(PyObject *) PyErr_SetFromErrnoWithUnicodeFilename(
192  PyObject *, const Py_UNICODE *);
193 #endif /* MS_WINDOWS */
194 
195 PyAPI_FUNC(PyObject *) PyErr_Format(PyObject *, const char *, ...)
196  Py_GCC_ATTRIBUTE((format(printf, 2, 3)));
197 
198 #ifdef MS_WINDOWS
199 PyAPI_FUNC(PyObject *) PyErr_SetFromWindowsErrWithFilenameObject(
200  int, const char *);
201 PyAPI_FUNC(PyObject *) PyErr_SetFromWindowsErrWithFilename(
202  int, const char *);
203 PyAPI_FUNC(PyObject *) PyErr_SetFromWindowsErrWithUnicodeFilename(
204  int, const Py_UNICODE *);
205 PyAPI_FUNC(PyObject *) PyErr_SetFromWindowsErr(int);
206 PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErrWithFilenameObject(
207  PyObject *,int, PyObject *);
208 PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErrWithFilename(
209  PyObject *,int, const char *);
210 PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErrWithUnicodeFilename(
211  PyObject *,int, const Py_UNICODE *);
212 PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErr(PyObject *, int);
213 #endif /* MS_WINDOWS */
214 
215 /* Export the old function so that the existing API remains available: */
217 PyAPI_FUNC(void) _PyErr_BadInternalCall(char *filename, int lineno);
218 /* Mask the old API with a call to the new API for code compiled under
219  Python 2.0: */
220 #define PyErr_BadInternalCall() _PyErr_BadInternalCall(__FILE__, __LINE__)
221 
222 /* Function to create a new exception */
223 PyAPI_FUNC(PyObject *) PyErr_NewException(
224  char *name, PyObject *base, PyObject *dict);
225 PyAPI_FUNC(PyObject *) PyErr_NewExceptionWithDoc(
226  char *name, char *doc, PyObject *base, PyObject *dict);
227 PyAPI_FUNC(void) PyErr_WriteUnraisable(PyObject *);
228 
229 /* In sigcheck.c or signalmodule.c */
230 PyAPI_FUNC(int) PyErr_CheckSignals(void);
231 PyAPI_FUNC(void) PyErr_SetInterrupt(void);
232 
233 /* In signalmodule.c */
234 int PySignal_SetWakeupFd(int fd);
235 
236 /* Support for adding program text to SyntaxErrors */
237 PyAPI_FUNC(void) PyErr_SyntaxLocation(const char *, int);
238 PyAPI_FUNC(PyObject *) PyErr_ProgramText(const char *, int);
239 
240 #ifdef Py_USING_UNICODE
241 /* The following functions are used to create and modify unicode
242  exceptions from C */
243 
244 /* create a UnicodeDecodeError object */
245 PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_Create(
246  const char *, const char *, Py_ssize_t, Py_ssize_t, Py_ssize_t, const char *);
247 
248 /* create a UnicodeEncodeError object */
249 PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_Create(
250  const char *, const Py_UNICODE *, Py_ssize_t, Py_ssize_t, Py_ssize_t, const char *);
251 
252 /* create a UnicodeTranslateError object */
253 PyAPI_FUNC(PyObject *) PyUnicodeTranslateError_Create(
254  const Py_UNICODE *, Py_ssize_t, Py_ssize_t, Py_ssize_t, const char *);
255 
256 /* get the encoding attribute */
257 PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_GetEncoding(PyObject *);
258 PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_GetEncoding(PyObject *);
259 
260 /* get the object attribute */
261 PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_GetObject(PyObject *);
262 PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_GetObject(PyObject *);
263 PyAPI_FUNC(PyObject *) PyUnicodeTranslateError_GetObject(PyObject *);
264 
265 /* get the value of the start attribute (the int * may not be NULL)
266  return 0 on success, -1 on failure */
267 PyAPI_FUNC(int) PyUnicodeEncodeError_GetStart(PyObject *, Py_ssize_t *);
268 PyAPI_FUNC(int) PyUnicodeDecodeError_GetStart(PyObject *, Py_ssize_t *);
269 PyAPI_FUNC(int) PyUnicodeTranslateError_GetStart(PyObject *, Py_ssize_t *);
270 
271 /* assign a new value to the start attribute
272  return 0 on success, -1 on failure */
273 PyAPI_FUNC(int) PyUnicodeEncodeError_SetStart(PyObject *, Py_ssize_t);
274 PyAPI_FUNC(int) PyUnicodeDecodeError_SetStart(PyObject *, Py_ssize_t);
275 PyAPI_FUNC(int) PyUnicodeTranslateError_SetStart(PyObject *, Py_ssize_t);
276 
277 /* get the value of the end attribute (the int *may not be NULL)
278  return 0 on success, -1 on failure */
279 PyAPI_FUNC(int) PyUnicodeEncodeError_GetEnd(PyObject *, Py_ssize_t *);
280 PyAPI_FUNC(int) PyUnicodeDecodeError_GetEnd(PyObject *, Py_ssize_t *);
281 PyAPI_FUNC(int) PyUnicodeTranslateError_GetEnd(PyObject *, Py_ssize_t *);
282 
283 /* assign a new value to the end attribute
284  return 0 on success, -1 on failure */
285 PyAPI_FUNC(int) PyUnicodeEncodeError_SetEnd(PyObject *, Py_ssize_t);
286 PyAPI_FUNC(int) PyUnicodeDecodeError_SetEnd(PyObject *, Py_ssize_t);
287 PyAPI_FUNC(int) PyUnicodeTranslateError_SetEnd(PyObject *, Py_ssize_t);
288 
289 /* get the value of the reason attribute */
290 PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_GetReason(PyObject *);
291 PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_GetReason(PyObject *);
292 PyAPI_FUNC(PyObject *) PyUnicodeTranslateError_GetReason(PyObject *);
293 
294 /* assign a new value to the reason attribute
295  return 0 on success, -1 on failure */
296 PyAPI_FUNC(int) PyUnicodeEncodeError_SetReason(
297  PyObject *, const char *);
298 PyAPI_FUNC(int) PyUnicodeDecodeError_SetReason(
299  PyObject *, const char *);
300 PyAPI_FUNC(int) PyUnicodeTranslateError_SetReason(
301  PyObject *, const char *);
302 #endif
303 
304 
305 /* These APIs aren't really part of the error implementation, but
306  often needed to format error messages; the native C lib APIs are
307  not available on all platforms, which is why we provide emulations
308  for those platforms in Python/mysnprintf.c,
309  WARNING: The return value of snprintf varies across platforms; do
310  not rely on any particular behavior; eventually the C99 defn may
311  be reliable.
312 */
313 #if defined(MS_WIN32) && !defined(HAVE_SNPRINTF)
314 # define HAVE_SNPRINTF
315 # define snprintf _snprintf
316 # define vsnprintf _vsnprintf
317 #endif
318 
319 #include <stdarg.h>
320 PyAPI_FUNC(int) PyOS_snprintf(char *str, size_t size, const char *format, ...)
321  Py_GCC_ATTRIBUTE((format(printf, 3, 4)));
322 PyAPI_FUNC(int) PyOS_vsnprintf(char *str, size_t size, const char *format, va_list va)
323  Py_GCC_ATTRIBUTE((format(printf, 3, 0)));
324 
325 #ifdef __cplusplus
326 }
327 #endif
328 #endif /* !Py_ERRORS_H */

Copyright 2014 Google Inc. All rights reserved.