blob: 808e0def06b45c7ba9d08ebd2daa9b646a300552 [file] [log] [blame]
Guido van Rossuma3309961993-07-28 09:05:47 +00001#ifndef Py_ERRORS_H
2#define Py_ERRORS_H
3#ifdef __cplusplus
4extern "C" {
5#endif
6
Thomas Wouters477c8d52006-05-27 19:21:47 +00007/* Error objects */
8
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00009#ifndef Py_LIMITED_API
Collin Winter828f04a2007-08-31 00:04:24 +000010/* PyException_HEAD defines the initial segment of every exception class. */
Collin Winter231ff0e2007-08-31 00:59:38 +000011#define PyException_HEAD PyObject_HEAD PyObject *dict;\
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000012 PyObject *args; PyObject *traceback;\
Benjamin Petersond5a1c442012-05-14 22:09:31 -070013 PyObject *context; PyObject *cause;\
Benjamin Peterson1a1367b2012-08-08 17:22:50 -070014 char suppress_context;
Collin Winter828f04a2007-08-31 00:04:24 +000015
Thomas Wouters477c8d52006-05-27 19:21:47 +000016typedef struct {
Collin Winter828f04a2007-08-31 00:04:24 +000017 PyException_HEAD
Thomas Wouters477c8d52006-05-27 19:21:47 +000018} PyBaseExceptionObject;
19
20typedef struct {
Collin Winter828f04a2007-08-31 00:04:24 +000021 PyException_HEAD
Thomas Wouters477c8d52006-05-27 19:21:47 +000022 PyObject *msg;
23 PyObject *filename;
24 PyObject *lineno;
25 PyObject *offset;
26 PyObject *text;
27 PyObject *print_file_and_line;
28} PySyntaxErrorObject;
29
Thomas Wouters477c8d52006-05-27 19:21:47 +000030typedef struct {
Collin Winter828f04a2007-08-31 00:04:24 +000031 PyException_HEAD
Benjamin Peterson633b32a2012-04-12 21:50:35 -040032 PyObject *msg;
33 PyObject *name;
34 PyObject *path;
35} PyImportErrorObject;
36
37typedef struct {
38 PyException_HEAD
Thomas Wouters477c8d52006-05-27 19:21:47 +000039 PyObject *encoding;
40 PyObject *object;
Guido van Rossum7eaf8222007-06-18 17:58:50 +000041 Py_ssize_t start;
42 Py_ssize_t end;
Thomas Wouters477c8d52006-05-27 19:21:47 +000043 PyObject *reason;
44} PyUnicodeErrorObject;
Thomas Wouters477c8d52006-05-27 19:21:47 +000045
46typedef struct {
Collin Winter828f04a2007-08-31 00:04:24 +000047 PyException_HEAD
Thomas Wouters477c8d52006-05-27 19:21:47 +000048 PyObject *code;
49} PySystemExitObject;
50
51typedef struct {
Collin Winter828f04a2007-08-31 00:04:24 +000052 PyException_HEAD
Thomas Wouters477c8d52006-05-27 19:21:47 +000053 PyObject *myerrno;
54 PyObject *strerror;
55 PyObject *filename;
Larry Hastingsb0827312014-02-09 22:05:19 -080056 PyObject *filename2;
Thomas Wouters477c8d52006-05-27 19:21:47 +000057#ifdef MS_WINDOWS
Thomas Wouters477c8d52006-05-27 19:21:47 +000058 PyObject *winerror;
Thomas Wouters477c8d52006-05-27 19:21:47 +000059#endif
Antoine Pitrou6b4883d2011-10-12 02:54:14 +020060 Py_ssize_t written; /* only for BlockingIOError, -1 otherwise */
61} PyOSErrorObject;
62
Nick Coghlan1f7ce622012-01-13 21:43:40 +100063typedef struct {
64 PyException_HEAD
65 PyObject *value;
66} PyStopIterationObject;
67
Antoine Pitrou6b4883d2011-10-12 02:54:14 +020068/* Compatibility typedefs */
69typedef PyOSErrorObject PyEnvironmentErrorObject;
70#ifdef MS_WINDOWS
71typedef PyOSErrorObject PyWindowsErrorObject;
Martin v. Löwis4d0d4712010-12-03 20:14:31 +000072#endif
Antoine Pitrou6b4883d2011-10-12 02:54:14 +020073#endif /* !Py_LIMITED_API */
Guido van Rossumf70e43a1991-02-19 12:39:46 +000074
Guido van Rossum85a5fbb1990-10-14 12:07:46 +000075/* Error handling definitions */
76
Mark Hammond91a681d2002-08-12 07:21:58 +000077PyAPI_FUNC(void) PyErr_SetNone(PyObject *);
78PyAPI_FUNC(void) PyErr_SetObject(PyObject *, PyObject *);
Martin v. Löwis1c0689c2014-01-03 21:36:49 +010079#ifndef Py_LIMITED_API
Raymond Hettinger69492da2013-09-02 15:59:26 -070080PyAPI_FUNC(void) _PyErr_SetKeyError(PyObject *);
Mark Shannonae3087c2017-10-22 22:41:51 +010081_PyErr_StackItem *_PyErr_GetTopmostException(PyThreadState *tstate);
Martin v. Löwis1c0689c2014-01-03 21:36:49 +010082#endif
Victor Stinner257d38f2010-10-09 10:12:11 +000083PyAPI_FUNC(void) PyErr_SetString(
84 PyObject *exception,
85 const char *string /* decoded from utf-8 */
86 );
Mark Hammond91a681d2002-08-12 07:21:58 +000087PyAPI_FUNC(PyObject *) PyErr_Occurred(void);
88PyAPI_FUNC(void) PyErr_Clear(void);
89PyAPI_FUNC(void) PyErr_Fetch(PyObject **, PyObject **, PyObject **);
90PyAPI_FUNC(void) PyErr_Restore(PyObject *, PyObject *, PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +020091#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03030000
Martin v. Löwisaa2efcb2012-04-19 14:33:43 +020092PyAPI_FUNC(void) PyErr_GetExcInfo(PyObject **, PyObject **, PyObject **);
93PyAPI_FUNC(void) PyErr_SetExcInfo(PyObject *, PyObject *, PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +020094#endif
Brett Cannonb94767f2011-02-22 20:15:44 +000095
96#if defined(__clang__) || \
Alexey Izbysheve2ed5ad2018-11-02 19:32:26 +030097 (defined(__GNUC__) && \
98 ((__GNUC__ >= 3) || \
99 (__GNUC__ == 2) && (__GNUC_MINOR__ >= 5)))
Victor Stinnercfc88312018-08-01 16:41:25 +0200100# define _Py_NO_RETURN __attribute__((__noreturn__))
101#elif defined(_MSC_VER)
102# define _Py_NO_RETURN __declspec(noreturn)
Brett Cannonb94767f2011-02-22 20:15:44 +0000103#else
Victor Stinnercfc88312018-08-01 16:41:25 +0200104# define _Py_NO_RETURN
Brett Cannonb94767f2011-02-22 20:15:44 +0000105#endif
106
Nick Coghland6009512014-11-20 21:39:37 +1000107/* Defined in Python/pylifecycle.c */
Victor Stinnercfc88312018-08-01 16:41:25 +0200108PyAPI_FUNC(void) _Py_NO_RETURN Py_FatalError(const char *message);
Guido van Rossum85a5fbb1990-10-14 12:07:46 +0000109
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000110#if defined(Py_DEBUG) || defined(Py_LIMITED_API)
Raymond Hettinger5ba0cbe2005-08-06 18:31:24 +0000111#define _PyErr_OCCURRED() PyErr_Occurred()
112#else
Antoine Pitrou59c900d2013-10-07 20:38:51 +0200113#define _PyErr_OCCURRED() (PyThreadState_GET()->curexc_type)
Raymond Hettinger5ba0cbe2005-08-06 18:31:24 +0000114#endif
115
Barry Warsawc0dc92a1997-08-22 21:22:58 +0000116/* Error testing and normalization */
Mark Hammond91a681d2002-08-12 07:21:58 +0000117PyAPI_FUNC(int) PyErr_GivenExceptionMatches(PyObject *, PyObject *);
118PyAPI_FUNC(int) PyErr_ExceptionMatches(PyObject *);
119PyAPI_FUNC(void) PyErr_NormalizeException(PyObject**, PyObject**, PyObject**);
Barry Warsawc0dc92a1997-08-22 21:22:58 +0000120
Collin Winter828f04a2007-08-31 00:04:24 +0000121/* Traceback manipulation (PEP 3134) */
122PyAPI_FUNC(int) PyException_SetTraceback(PyObject *, PyObject *);
123PyAPI_FUNC(PyObject *) PyException_GetTraceback(PyObject *);
124
125/* Cause manipulation (PEP 3134) */
126PyAPI_FUNC(PyObject *) PyException_GetCause(PyObject *);
127PyAPI_FUNC(void) PyException_SetCause(PyObject *, PyObject *);
128
129/* Context manipulation (PEP 3134) */
130PyAPI_FUNC(PyObject *) PyException_GetContext(PyObject *);
131PyAPI_FUNC(void) PyException_SetContext(PyObject *, PyObject *);
Serhiy Storchakae2bd2a72014-10-08 22:31:52 +0300132#ifndef Py_LIMITED_API
133PyAPI_FUNC(void) _PyErr_ChainExceptions(PyObject *, PyObject *, PyObject *);
134#endif
Collin Winter828f04a2007-08-31 00:04:24 +0000135
Brett Cannonbf364092006-03-01 04:25:17 +0000136/* */
Barry Warsawc0dc92a1997-08-22 21:22:58 +0000137
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000138#define PyExceptionClass_Check(x) \
139 (PyType_Check((x)) && \
140 PyType_FastSubclass((PyTypeObject*)(x), Py_TPFLAGS_BASE_EXC_SUBCLASS))
Brett Cannonbf364092006-03-01 04:25:17 +0000141
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000142#define PyExceptionInstance_Check(x) \
143 PyType_FastSubclass((x)->ob_type, Py_TPFLAGS_BASE_EXC_SUBCLASS)
Brett Cannonbf364092006-03-01 04:25:17 +0000144
Serhiy Storchakaceeef102018-06-15 11:09:43 +0300145PyAPI_FUNC(const char *) PyExceptionClass_Name(PyObject *);
Christian Tismerea62ce72018-06-09 20:32:25 +0200146#ifndef Py_LIMITED_API
Serhiy Storchakaceeef102018-06-15 11:09:43 +0300147#define PyExceptionClass_Name(x) (((PyTypeObject*)(x))->tp_name)
Christian Tismerea62ce72018-06-09 20:32:25 +0200148#endif
Brett Cannonbf364092006-03-01 04:25:17 +0000149
Guido van Rossum45aecf42006-03-15 04:58:47 +0000150#define PyExceptionInstance_Class(x) ((PyObject*)((x)->ob_type))
Brett Cannonbf364092006-03-01 04:25:17 +0000151
Collin Winter828f04a2007-08-31 00:04:24 +0000152
Guido van Rossum3f5da241990-12-20 15:06:42 +0000153/* Predefined exceptions */
Guido van Rossum5c600e11990-10-14 20:00:25 +0000154
Brett Cannonbf364092006-03-01 04:25:17 +0000155PyAPI_DATA(PyObject *) PyExc_BaseException;
Mark Hammond91a681d2002-08-12 07:21:58 +0000156PyAPI_DATA(PyObject *) PyExc_Exception;
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200157#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03050000
Yury Selivanov75445082015-05-11 22:57:16 -0400158PyAPI_DATA(PyObject *) PyExc_StopAsyncIteration;
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200159#endif
Mark Hammond91a681d2002-08-12 07:21:58 +0000160PyAPI_DATA(PyObject *) PyExc_StopIteration;
Phillip J. Eby0d6615f2005-08-02 00:46:46 +0000161PyAPI_DATA(PyObject *) PyExc_GeneratorExit;
Mark Hammond91a681d2002-08-12 07:21:58 +0000162PyAPI_DATA(PyObject *) PyExc_ArithmeticError;
163PyAPI_DATA(PyObject *) PyExc_LookupError;
Barry Warsaw392d8271997-08-29 21:56:07 +0000164
Mark Hammond91a681d2002-08-12 07:21:58 +0000165PyAPI_DATA(PyObject *) PyExc_AssertionError;
166PyAPI_DATA(PyObject *) PyExc_AttributeError;
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200167PyAPI_DATA(PyObject *) PyExc_BufferError;
Mark Hammond91a681d2002-08-12 07:21:58 +0000168PyAPI_DATA(PyObject *) PyExc_EOFError;
169PyAPI_DATA(PyObject *) PyExc_FloatingPointError;
Mark Hammond91a681d2002-08-12 07:21:58 +0000170PyAPI_DATA(PyObject *) PyExc_OSError;
171PyAPI_DATA(PyObject *) PyExc_ImportError;
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200172#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03060000
Eric Snowc9432652016-09-07 15:42:32 -0700173PyAPI_DATA(PyObject *) PyExc_ModuleNotFoundError;
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200174#endif
Mark Hammond91a681d2002-08-12 07:21:58 +0000175PyAPI_DATA(PyObject *) PyExc_IndexError;
176PyAPI_DATA(PyObject *) PyExc_KeyError;
177PyAPI_DATA(PyObject *) PyExc_KeyboardInterrupt;
178PyAPI_DATA(PyObject *) PyExc_MemoryError;
179PyAPI_DATA(PyObject *) PyExc_NameError;
180PyAPI_DATA(PyObject *) PyExc_OverflowError;
181PyAPI_DATA(PyObject *) PyExc_RuntimeError;
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200182#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03050000
Yury Selivanovf488fb42015-07-03 01:04:23 -0400183PyAPI_DATA(PyObject *) PyExc_RecursionError;
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200184#endif
Mark Hammond91a681d2002-08-12 07:21:58 +0000185PyAPI_DATA(PyObject *) PyExc_NotImplementedError;
186PyAPI_DATA(PyObject *) PyExc_SyntaxError;
187PyAPI_DATA(PyObject *) PyExc_IndentationError;
188PyAPI_DATA(PyObject *) PyExc_TabError;
189PyAPI_DATA(PyObject *) PyExc_ReferenceError;
190PyAPI_DATA(PyObject *) PyExc_SystemError;
191PyAPI_DATA(PyObject *) PyExc_SystemExit;
192PyAPI_DATA(PyObject *) PyExc_TypeError;
193PyAPI_DATA(PyObject *) PyExc_UnboundLocalError;
194PyAPI_DATA(PyObject *) PyExc_UnicodeError;
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000195PyAPI_DATA(PyObject *) PyExc_UnicodeEncodeError;
196PyAPI_DATA(PyObject *) PyExc_UnicodeDecodeError;
197PyAPI_DATA(PyObject *) PyExc_UnicodeTranslateError;
Mark Hammond91a681d2002-08-12 07:21:58 +0000198PyAPI_DATA(PyObject *) PyExc_ValueError;
199PyAPI_DATA(PyObject *) PyExc_ZeroDivisionError;
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200200
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200201#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03030000
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200202PyAPI_DATA(PyObject *) PyExc_BlockingIOError;
203PyAPI_DATA(PyObject *) PyExc_BrokenPipeError;
204PyAPI_DATA(PyObject *) PyExc_ChildProcessError;
205PyAPI_DATA(PyObject *) PyExc_ConnectionError;
206PyAPI_DATA(PyObject *) PyExc_ConnectionAbortedError;
207PyAPI_DATA(PyObject *) PyExc_ConnectionRefusedError;
208PyAPI_DATA(PyObject *) PyExc_ConnectionResetError;
209PyAPI_DATA(PyObject *) PyExc_FileExistsError;
210PyAPI_DATA(PyObject *) PyExc_FileNotFoundError;
211PyAPI_DATA(PyObject *) PyExc_InterruptedError;
212PyAPI_DATA(PyObject *) PyExc_IsADirectoryError;
213PyAPI_DATA(PyObject *) PyExc_NotADirectoryError;
214PyAPI_DATA(PyObject *) PyExc_PermissionError;
215PyAPI_DATA(PyObject *) PyExc_ProcessLookupError;
216PyAPI_DATA(PyObject *) PyExc_TimeoutError;
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200217#endif
Antoine Pitrou6b4883d2011-10-12 02:54:14 +0200218
219
220/* Compatibility aliases */
221PyAPI_DATA(PyObject *) PyExc_EnvironmentError;
222PyAPI_DATA(PyObject *) PyExc_IOError;
Guido van Rossumdb0c9f72000-02-17 15:17:18 +0000223#ifdef MS_WINDOWS
Mark Hammond91a681d2002-08-12 07:21:58 +0000224PyAPI_DATA(PyObject *) PyExc_WindowsError;
Guido van Rossumdb0c9f72000-02-17 15:17:18 +0000225#endif
Guido van Rossum3e55cb61990-10-21 22:09:30 +0000226
Guido van Rossum3fc30372000-12-15 21:57:34 +0000227/* Predefined warning categories */
Mark Hammond91a681d2002-08-12 07:21:58 +0000228PyAPI_DATA(PyObject *) PyExc_Warning;
229PyAPI_DATA(PyObject *) PyExc_UserWarning;
230PyAPI_DATA(PyObject *) PyExc_DeprecationWarning;
231PyAPI_DATA(PyObject *) PyExc_PendingDeprecationWarning;
232PyAPI_DATA(PyObject *) PyExc_SyntaxWarning;
Mark Hammond91a681d2002-08-12 07:21:58 +0000233PyAPI_DATA(PyObject *) PyExc_RuntimeWarning;
Barry Warsaw9f007392002-08-14 15:51:29 +0000234PyAPI_DATA(PyObject *) PyExc_FutureWarning;
Thomas Wouters477c8d52006-05-27 19:21:47 +0000235PyAPI_DATA(PyObject *) PyExc_ImportWarning;
Thomas Wouters00ee7ba2006-08-21 19:07:27 +0000236PyAPI_DATA(PyObject *) PyExc_UnicodeWarning;
Guido van Rossum98297ee2007-11-06 21:34:58 +0000237PyAPI_DATA(PyObject *) PyExc_BytesWarning;
Georg Brandl08be72d2010-10-24 15:11:22 +0000238PyAPI_DATA(PyObject *) PyExc_ResourceWarning;
Guido van Rossum3fc30372000-12-15 21:57:34 +0000239
Barry Warsaw392d8271997-08-29 21:56:07 +0000240
Guido van Rossum5c600e11990-10-14 20:00:25 +0000241/* Convenience functions */
242
Mark Hammond91a681d2002-08-12 07:21:58 +0000243PyAPI_FUNC(int) PyErr_BadArgument(void);
244PyAPI_FUNC(PyObject *) PyErr_NoMemory(void);
245PyAPI_FUNC(PyObject *) PyErr_SetFromErrno(PyObject *);
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000246PyAPI_FUNC(PyObject *) PyErr_SetFromErrnoWithFilenameObject(
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000247 PyObject *, PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200248#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03040000
Larry Hastingsb0827312014-02-09 22:05:19 -0800249PyAPI_FUNC(PyObject *) PyErr_SetFromErrnoWithFilenameObjects(
250 PyObject *, PyObject *, PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200251#endif
Benjamin Peterson78565b22009-06-28 19:19:51 +0000252PyAPI_FUNC(PyObject *) PyErr_SetFromErrnoWithFilename(
Victor Stinner257d38f2010-10-09 10:12:11 +0000253 PyObject *exc,
254 const char *filename /* decoded from the filesystem encoding */
255 );
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000256#if defined(MS_WINDOWS) && !defined(Py_LIMITED_API)
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000257PyAPI_FUNC(PyObject *) PyErr_SetFromErrnoWithUnicodeFilename(
Serhiy Storchaka460bd0d2016-11-20 12:16:46 +0200258 PyObject *, const Py_UNICODE *) Py_DEPRECATED(3.3);
Hirokazu Yamamoto8223c242009-05-17 04:21:53 +0000259#endif /* MS_WINDOWS */
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000260
Victor Stinner1205f272010-09-11 00:54:47 +0000261PyAPI_FUNC(PyObject *) PyErr_Format(
262 PyObject *exception,
263 const char *format, /* ASCII-encoded string */
264 ...
265 );
Antoine Pitrou0676a402014-09-30 21:16:27 +0200266#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03050000
267PyAPI_FUNC(PyObject *) PyErr_FormatV(
268 PyObject *exception,
269 const char *format,
270 va_list vargs);
271#endif
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000272
Serhiy Storchaka467ab192016-10-21 17:09:17 +0300273#ifndef Py_LIMITED_API
274/* Like PyErr_Format(), but saves current exception as __context__ and
275 __cause__.
276 */
277PyAPI_FUNC(PyObject *) _PyErr_FormatFromCause(
278 PyObject *exception,
279 const char *format, /* ASCII-encoded string */
280 ...
281 );
282#endif
283
Guido van Rossumdb0c9f72000-02-17 15:17:18 +0000284#ifdef MS_WINDOWS
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000285PyAPI_FUNC(PyObject *) PyErr_SetFromWindowsErrWithFilename(
Victor Stinner555a24f2010-12-27 01:49:26 +0000286 int ierr,
Victor Stinnerb9cb21e2010-12-28 00:59:03 +0000287 const char *filename /* decoded from the filesystem encoding */
Victor Stinner555a24f2010-12-27 01:49:26 +0000288 );
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000289#ifndef Py_LIMITED_API
290/* XXX redeclare to use WSTRING */
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000291PyAPI_FUNC(PyObject *) PyErr_SetFromWindowsErrWithUnicodeFilename(
Serhiy Storchaka460bd0d2016-11-20 12:16:46 +0200292 int, const Py_UNICODE *) Py_DEPRECATED(3.3);
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000293#endif
Mark Hammond91a681d2002-08-12 07:21:58 +0000294PyAPI_FUNC(PyObject *) PyErr_SetFromWindowsErr(int);
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000295PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErrWithFilenameObject(
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000296 PyObject *,int, PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200297#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03040000
Larry Hastingsb0827312014-02-09 22:05:19 -0800298PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErrWithFilenameObjects(
299 PyObject *,int, PyObject *, PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200300#endif
Mark Hammond91a681d2002-08-12 07:21:58 +0000301PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErrWithFilename(
Victor Stinner555a24f2010-12-27 01:49:26 +0000302 PyObject *exc,
303 int ierr,
Victor Stinnerb9cb21e2010-12-28 00:59:03 +0000304 const char *filename /* decoded from the filesystem encoding */
Victor Stinner555a24f2010-12-27 01:49:26 +0000305 );
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000306#ifndef Py_LIMITED_API
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000307PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErrWithUnicodeFilename(
Serhiy Storchaka460bd0d2016-11-20 12:16:46 +0200308 PyObject *,int, const Py_UNICODE *) Py_DEPRECATED(3.3);
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000309#endif
Mark Hammond91a681d2002-08-12 07:21:58 +0000310PyAPI_FUNC(PyObject *) PyErr_SetExcFromWindowsErr(PyObject *, int);
Mark Hammondc2e85bd2002-10-03 05:10:39 +0000311#endif /* MS_WINDOWS */
Guido van Rossum3e55cb61990-10-21 22:09:30 +0000312
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200313#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03060000
Eric Snow46f97b82016-09-07 16:56:15 -0700314PyAPI_FUNC(PyObject *) PyErr_SetImportErrorSubclass(PyObject *, PyObject *,
315 PyObject *, PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200316#endif
317#if !defined(Py_LIMITED_API) || Py_LIMITED_API+0 >= 0x03030000
Brian Curtin09b86d12012-04-17 16:57:09 -0500318PyAPI_FUNC(PyObject *) PyErr_SetImportError(PyObject *, PyObject *,
319 PyObject *);
Serhiy Storchaka34d0ac82016-12-27 14:57:39 +0200320#endif
Brett Cannon79ec55e2012-04-12 20:24:54 -0400321
Fred Drake6d63adf2000-08-24 22:38:39 +0000322/* Export the old function so that the existing API remains available: */
Mark Hammond91a681d2002-08-12 07:21:58 +0000323PyAPI_FUNC(void) PyErr_BadInternalCall(void);
Neal Norwitzb382b842007-08-24 20:00:37 +0000324PyAPI_FUNC(void) _PyErr_BadInternalCall(const char *filename, int lineno);
Fred Drake6d63adf2000-08-24 22:38:39 +0000325/* Mask the old API with a call to the new API for code compiled under
326 Python 2.0: */
327#define PyErr_BadInternalCall() _PyErr_BadInternalCall(__FILE__, __LINE__)
Guido van Rossum25831651993-05-19 14:50:45 +0000328
Guido van Rossum2d2c3441997-09-16 21:50:37 +0000329/* Function to create a new exception */
Georg Brandl1e28a272009-12-28 08:41:01 +0000330PyAPI_FUNC(PyObject *) PyErr_NewException(
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000331 const char *name, PyObject *base, PyObject *dict);
Georg Brandl1e28a272009-12-28 08:41:01 +0000332PyAPI_FUNC(PyObject *) PyErr_NewExceptionWithDoc(
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000333 const char *name, const char *doc, PyObject *base, PyObject *dict);
Mark Hammond91a681d2002-08-12 07:21:58 +0000334PyAPI_FUNC(void) PyErr_WriteUnraisable(PyObject *);
Guido van Rossum2d2c3441997-09-16 21:50:37 +0000335
Nick Coghlan8b097b42013-11-13 23:49:21 +1000336/* In exceptions.c */
337#ifndef Py_LIMITED_API
338/* Helper that attempts to replace the current exception with one of the
339 * same type but with a prefix added to the exception text. The resulting
340 * exception description looks like:
341 *
342 * prefix (exc_type: original_exc_str)
343 *
344 * Only some exceptions can be safely replaced. If the function determines
345 * it isn't safe to perform the replacement, it will leave the original
346 * unmodified exception in place.
347 *
348 * Returns a borrowed reference to the new exception (if any), NULL if the
349 * existing exception was left in place.
350 */
351PyAPI_FUNC(PyObject *) _PyErr_TrySetFromCause(
352 const char *prefix_format, /* ASCII-encoded string */
353 ...
354 );
355#endif
356
357
Segev Finer7ff1e882017-05-25 14:00:18 +0300358/* In signalmodule.c */
Mark Hammond91a681d2002-08-12 07:21:58 +0000359PyAPI_FUNC(int) PyErr_CheckSignals(void);
360PyAPI_FUNC(void) PyErr_SetInterrupt(void);
Jeremy Hyltonad3d3f22001-02-28 17:47:12 +0000361
Christian Heimes5fb7c2a2007-12-24 08:52:31 +0000362/* In signalmodule.c */
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000363#ifndef Py_LIMITED_API
Christian Heimes5fb7c2a2007-12-24 08:52:31 +0000364int PySignal_SetWakeupFd(int fd);
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000365#endif
Christian Heimes5fb7c2a2007-12-24 08:52:31 +0000366
Jeremy Hyltonad3d3f22001-02-28 17:47:12 +0000367/* Support for adding program text to SyntaxErrors */
Victor Stinner555a24f2010-12-27 01:49:26 +0000368PyAPI_FUNC(void) PyErr_SyntaxLocation(
369 const char *filename, /* decoded from the filesystem encoding */
370 int lineno);
371PyAPI_FUNC(void) PyErr_SyntaxLocationEx(
372 const char *filename, /* decoded from the filesystem encoding */
373 int lineno,
374 int col_offset);
Martin v. Löwis1c0689c2014-01-03 21:36:49 +0100375#ifndef Py_LIMITED_API
Victor Stinner14e461d2013-08-26 22:28:21 +0200376PyAPI_FUNC(void) PyErr_SyntaxLocationObject(
377 PyObject *filename,
378 int lineno,
379 int col_offset);
Martin v. Löwis1c0689c2014-01-03 21:36:49 +0100380#endif
Victor Stinner555a24f2010-12-27 01:49:26 +0000381PyAPI_FUNC(PyObject *) PyErr_ProgramText(
382 const char *filename, /* decoded from the filesystem encoding */
383 int lineno);
Martin v. Löwis1c0689c2014-01-03 21:36:49 +0100384#ifndef Py_LIMITED_API
Victor Stinner14e461d2013-08-26 22:28:21 +0200385PyAPI_FUNC(PyObject *) PyErr_ProgramTextObject(
386 PyObject *filename,
387 int lineno);
Martin v. Löwis1c0689c2014-01-03 21:36:49 +0100388#endif
Tim Petersa437d452001-11-28 16:51:49 +0000389
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000390/* The following functions are used to create and modify unicode
391 exceptions from C */
Walter Dörwaldbf73db82002-11-21 20:08:33 +0000392
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000393/* create a UnicodeDecodeError object */
394PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_Create(
Victor Stinner555a24f2010-12-27 01:49:26 +0000395 const char *encoding, /* UTF-8 encoded string */
396 const char *object,
397 Py_ssize_t length,
398 Py_ssize_t start,
399 Py_ssize_t end,
400 const char *reason /* UTF-8 encoded string */
401 );
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000402
403/* create a UnicodeEncodeError object */
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000404#ifndef Py_LIMITED_API
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000405PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_Create(
Victor Stinner555a24f2010-12-27 01:49:26 +0000406 const char *encoding, /* UTF-8 encoded string */
407 const Py_UNICODE *object,
408 Py_ssize_t length,
409 Py_ssize_t start,
410 Py_ssize_t end,
411 const char *reason /* UTF-8 encoded string */
Serhiy Storchaka460bd0d2016-11-20 12:16:46 +0200412 ) Py_DEPRECATED(3.3);
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000413#endif
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000414
415/* create a UnicodeTranslateError object */
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000416#ifndef Py_LIMITED_API
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000417PyAPI_FUNC(PyObject *) PyUnicodeTranslateError_Create(
Victor Stinner555a24f2010-12-27 01:49:26 +0000418 const Py_UNICODE *object,
419 Py_ssize_t length,
420 Py_ssize_t start,
421 Py_ssize_t end,
422 const char *reason /* UTF-8 encoded string */
Serhiy Storchaka460bd0d2016-11-20 12:16:46 +0200423 ) Py_DEPRECATED(3.3);
Martin v. Löwisd63a3b82011-09-28 07:41:54 +0200424PyAPI_FUNC(PyObject *) _PyUnicodeTranslateError_Create(
425 PyObject *object,
426 Py_ssize_t start,
427 Py_ssize_t end,
428 const char *reason /* UTF-8 encoded string */
429 );
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000430#endif
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000431
432/* get the encoding attribute */
433PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_GetEncoding(PyObject *);
434PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_GetEncoding(PyObject *);
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000435
436/* get the object attribute */
437PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_GetObject(PyObject *);
438PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_GetObject(PyObject *);
439PyAPI_FUNC(PyObject *) PyUnicodeTranslateError_GetObject(PyObject *);
440
441/* get the value of the start attribute (the int * may not be NULL)
442 return 0 on success, -1 on failure */
Martin v. Löwis18e16552006-02-15 17:27:45 +0000443PyAPI_FUNC(int) PyUnicodeEncodeError_GetStart(PyObject *, Py_ssize_t *);
444PyAPI_FUNC(int) PyUnicodeDecodeError_GetStart(PyObject *, Py_ssize_t *);
445PyAPI_FUNC(int) PyUnicodeTranslateError_GetStart(PyObject *, Py_ssize_t *);
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000446
447/* assign a new value to the start attribute
448 return 0 on success, -1 on failure */
Martin v. Löwis18e16552006-02-15 17:27:45 +0000449PyAPI_FUNC(int) PyUnicodeEncodeError_SetStart(PyObject *, Py_ssize_t);
450PyAPI_FUNC(int) PyUnicodeDecodeError_SetStart(PyObject *, Py_ssize_t);
451PyAPI_FUNC(int) PyUnicodeTranslateError_SetStart(PyObject *, Py_ssize_t);
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000452
453/* get the value of the end attribute (the int *may not be NULL)
454 return 0 on success, -1 on failure */
Martin v. Löwis18e16552006-02-15 17:27:45 +0000455PyAPI_FUNC(int) PyUnicodeEncodeError_GetEnd(PyObject *, Py_ssize_t *);
456PyAPI_FUNC(int) PyUnicodeDecodeError_GetEnd(PyObject *, Py_ssize_t *);
457PyAPI_FUNC(int) PyUnicodeTranslateError_GetEnd(PyObject *, Py_ssize_t *);
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000458
459/* assign a new value to the end attribute
460 return 0 on success, -1 on failure */
Martin v. Löwis18e16552006-02-15 17:27:45 +0000461PyAPI_FUNC(int) PyUnicodeEncodeError_SetEnd(PyObject *, Py_ssize_t);
462PyAPI_FUNC(int) PyUnicodeDecodeError_SetEnd(PyObject *, Py_ssize_t);
463PyAPI_FUNC(int) PyUnicodeTranslateError_SetEnd(PyObject *, Py_ssize_t);
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000464
465/* get the value of the reason attribute */
466PyAPI_FUNC(PyObject *) PyUnicodeEncodeError_GetReason(PyObject *);
467PyAPI_FUNC(PyObject *) PyUnicodeDecodeError_GetReason(PyObject *);
468PyAPI_FUNC(PyObject *) PyUnicodeTranslateError_GetReason(PyObject *);
469
470/* assign a new value to the reason attribute
471 return 0 on success, -1 on failure */
472PyAPI_FUNC(int) PyUnicodeEncodeError_SetReason(
Victor Stinner555a24f2010-12-27 01:49:26 +0000473 PyObject *exc,
474 const char *reason /* UTF-8 encoded string */
475 );
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000476PyAPI_FUNC(int) PyUnicodeDecodeError_SetReason(
Victor Stinner555a24f2010-12-27 01:49:26 +0000477 PyObject *exc,
478 const char *reason /* UTF-8 encoded string */
479 );
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000480PyAPI_FUNC(int) PyUnicodeTranslateError_SetReason(
Victor Stinner555a24f2010-12-27 01:49:26 +0000481 PyObject *exc,
482 const char *reason /* UTF-8 encoded string */
483 );
Walter Dörwald3aeb6322002-09-02 13:14:32 +0000484
Marc-André Lemburge5006eb2001-07-31 13:24:44 +0000485/* These APIs aren't really part of the error implementation, but
486 often needed to format error messages; the native C lib APIs are
487 not available on all platforms, which is why we provide emulations
Tim Petersa437d452001-11-28 16:51:49 +0000488 for those platforms in Python/mysnprintf.c,
489 WARNING: The return value of snprintf varies across platforms; do
490 not rely on any particular behavior; eventually the C99 defn may
491 be reliable.
492*/
Marc-André Lemburge5006eb2001-07-31 13:24:44 +0000493#if defined(MS_WIN32) && !defined(HAVE_SNPRINTF)
494# define HAVE_SNPRINTF
495# define snprintf _snprintf
496# define vsnprintf _vsnprintf
497#endif
Marc-André Lemburg03d1b182001-07-31 18:05:33 +0000498
Marc-André Lemburgcecd9e02001-07-31 14:23:52 +0000499#include <stdarg.h>
Mark Hammond91a681d2002-08-12 07:21:58 +0000500PyAPI_FUNC(int) PyOS_snprintf(char *str, size_t size, const char *format, ...)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000501 Py_GCC_ATTRIBUTE((format(printf, 3, 4)));
Mark Hammond91a681d2002-08-12 07:21:58 +0000502PyAPI_FUNC(int) PyOS_vsnprintf(char *str, size_t size, const char *format, va_list va)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000503 Py_GCC_ATTRIBUTE((format(printf, 3, 0)));
Guido van Rossumb6775db1994-08-01 11:34:53 +0000504
Guido van Rossuma3309961993-07-28 09:05:47 +0000505#ifdef __cplusplus
506}
507#endif
508#endif /* !Py_ERRORS_H */