mirror of
https://github.com/python/cpython.git
synced 2025-07-07 19:35:27 +00:00
gh-107915: Handle errors in C API functions PyErr_Set*() and PyErr_Format() (GH-107918)
Such C API functions as PyErr_SetString(), PyErr_Format(), PyErr_SetFromErrnoWithFilename() and many others no longer crash or ignore errors if it failed to format the error message or decode the filename. Instead, they keep a corresponding error.
This commit is contained in:
parent
79db9d9a0e
commit
633ea217a8
5 changed files with 218 additions and 9 deletions
|
@ -292,8 +292,10 @@ _PyErr_SetString(PyThreadState *tstate, PyObject *exception,
|
|||
const char *string)
|
||||
{
|
||||
PyObject *value = PyUnicode_FromString(string);
|
||||
_PyErr_SetObject(tstate, exception, value);
|
||||
Py_XDECREF(value);
|
||||
if (value != NULL) {
|
||||
_PyErr_SetObject(tstate, exception, value);
|
||||
Py_DECREF(value);
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -891,7 +893,13 @@ PyErr_SetFromErrnoWithFilenameObjects(PyObject *exc, PyObject *filenameObject, P
|
|||
PyObject *
|
||||
PyErr_SetFromErrnoWithFilename(PyObject *exc, const char *filename)
|
||||
{
|
||||
PyObject *name = filename ? PyUnicode_DecodeFSDefault(filename) : NULL;
|
||||
PyObject *name = NULL;
|
||||
if (filename) {
|
||||
name = PyUnicode_DecodeFSDefault(filename);
|
||||
if (name == NULL) {
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
PyObject *result = PyErr_SetFromErrnoWithFilenameObjects(exc, name, NULL);
|
||||
Py_XDECREF(name);
|
||||
return result;
|
||||
|
@ -988,7 +996,13 @@ PyObject *PyErr_SetExcFromWindowsErrWithFilename(
|
|||
int ierr,
|
||||
const char *filename)
|
||||
{
|
||||
PyObject *name = filename ? PyUnicode_DecodeFSDefault(filename) : NULL;
|
||||
PyObject *name = NULL;
|
||||
if (filename) {
|
||||
name = PyUnicode_DecodeFSDefault(filename);
|
||||
if (name == NULL) {
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
PyObject *ret = PyErr_SetExcFromWindowsErrWithFilenameObjects(exc,
|
||||
ierr,
|
||||
name,
|
||||
|
@ -1012,7 +1026,13 @@ PyObject *PyErr_SetFromWindowsErrWithFilename(
|
|||
int ierr,
|
||||
const char *filename)
|
||||
{
|
||||
PyObject *name = filename ? PyUnicode_DecodeFSDefault(filename) : NULL;
|
||||
PyObject *name = NULL;
|
||||
if (filename) {
|
||||
name = PyUnicode_DecodeFSDefault(filename);
|
||||
if (name == NULL) {
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
PyObject *result = PyErr_SetExcFromWindowsErrWithFilenameObjects(
|
||||
PyExc_OSError,
|
||||
ierr, name, NULL);
|
||||
|
@ -1137,9 +1157,10 @@ _PyErr_FormatV(PyThreadState *tstate, PyObject *exception,
|
|||
_PyErr_Clear(tstate);
|
||||
|
||||
string = PyUnicode_FromFormatV(format, vargs);
|
||||
|
||||
_PyErr_SetObject(tstate, exception, string);
|
||||
Py_XDECREF(string);
|
||||
if (string != NULL) {
|
||||
_PyErr_SetObject(tstate, exception, string);
|
||||
Py_DECREF(string);
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue