Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 2be0373

Browse files
committed
Added some additional checks for sys.std?? is None, see #1440
1 parent 70021d7 commit 2be0373

7 files changed

Lines changed: 17 additions & 12 deletions

File tree

Modules/_ctypes/callbacks.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@ PrintError(char *msg, ...)
1717
va_start(marker, msg);
1818
vsnprintf(buf, sizeof(buf), msg, marker);
1919
va_end(marker);
20-
if (f)
20+
if (f != NULL && f != Py_None)
2121
PyFile_WriteString(buf, f);
2222
PyErr_Print();
2323
}

Modules/_cursesmodule.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2010,7 +2010,7 @@ PyCurses_setupterm(PyObject* self, PyObject *args, PyObject* keywds)
20102010

20112011
sys_stdout = PySys_GetObject("stdout");
20122012

2013-
if (sys_stdout == NULL) {
2013+
if (sys_stdout == NULL || sys_stdout == Py_None) {
20142014
PyErr_SetString(
20152015
PyCursesError,
20162016
"lost sys.stdout");

Modules/threadmodule.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -429,7 +429,7 @@ t_bootstrap(void *boot_raw)
429429
PySys_WriteStderr(
430430
"Unhandled exception in thread started by ");
431431
file = PySys_GetObject("stderr");
432-
if (file)
432+
if (file != NULL && file != Py_None)
433433
PyFile_WriteObject(boot->func, file, 0);
434434
else
435435
PyObject_Print(boot->func, stderr, 0);

Python/bltinmodule.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1265,17 +1265,17 @@ builtin_input(PyObject *self, PyObject *args)
12651265
return NULL;
12661266

12671267
/* Check that stdin/out/err are intact */
1268-
if (fin == NULL) {
1268+
if (fin == NULL || fin == Py_None) {
12691269
PyErr_SetString(PyExc_RuntimeError,
12701270
"input(): lost sys.stdin");
12711271
return NULL;
12721272
}
1273-
if (fout == NULL) {
1273+
if (fout == NULL || fout == Py_None) {
12741274
PyErr_SetString(PyExc_RuntimeError,
12751275
"input(): lost sys.stdout");
12761276
return NULL;
12771277
}
1278-
if (ferr == NULL) {
1278+
if (ferr == NULL || ferr == Py_None) {
12791279
PyErr_SetString(PyExc_RuntimeError,
12801280
"input(): lost sys.stderr");
12811281
return NULL;

Python/errors.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -626,7 +626,7 @@ PyErr_WriteUnraisable(PyObject *obj)
626626
PyObject *f, *t, *v, *tb;
627627
PyErr_Fetch(&t, &v, &tb);
628628
f = PySys_GetObject("stderr");
629-
if (f != NULL) {
629+
if (f != NULL && f != Py_None) {
630630
PyFile_WriteString("Exception ", f);
631631
if (t) {
632632
PyObject* moduleName;

Python/pythonrun.c

Lines changed: 9 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -335,15 +335,15 @@ flush_std_files(void)
335335
PyObject *ferr = PySys_GetObject("stderr");
336336
PyObject *tmp;
337337

338-
if (fout != NULL) {
338+
if (fout != NULL && fout != Py_None) {
339339
tmp = PyObject_CallMethod(fout, "flush", "");
340340
if (tmp == NULL)
341341
PyErr_Clear();
342342
else
343343
Py_DECREF(tmp);
344344
}
345345

346-
if (ferr != NULL) {
346+
if (ferr != NULL || ferr != Py_None) {
347347
tmp = PyObject_CallMethod(ferr, "flush", "");
348348
if (tmp == NULL)
349349
PyErr_Clear();
@@ -693,6 +693,8 @@ initsite(void)
693693
m = PyImport_ImportModule("site");
694694
if (m == NULL) {
695695
f = PySys_GetObject("stderr");
696+
if (f == NULL || f == Py_None)
697+
return;
696698
if (Py_VerboseFlag) {
697699
PyFile_WriteString(
698700
"'import site' failed; traceback:\n", f);
@@ -900,7 +902,7 @@ PyRun_InteractiveOneFlags(FILE *fp, const char *filename, PyCompilerFlags *flags
900902
if (fp == stdin) {
901903
/* Fetch encoding from sys.stdin */
902904
v = PySys_GetObject("stdin");
903-
if (!v)
905+
if (v == NULL || v == Py_None)
904906
return -1;
905907
oenc = PyObject_GetAttrString(v, "encoding");
906908
if (!oenc)
@@ -1293,7 +1295,10 @@ PyErr_Display(PyObject *exception, PyObject *value, PyObject *tb)
12931295
int err = 0;
12941296
PyObject *f = PySys_GetObject("stderr");
12951297
Py_INCREF(value);
1296-
if (f == NULL) {
1298+
if (f == Py_None) {
1299+
/* pass */
1300+
}
1301+
else if (f == NULL) {
12971302
_PyObject_Dump(value);
12981303
fprintf(stderr, "lost sys.stderr\n");
12991304
}

Python/sysmodule.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -89,7 +89,7 @@ sys_displayhook(PyObject *self, PyObject *o)
8989
if (PyObject_SetAttrString(builtins, "_", Py_None) != 0)
9090
return NULL;
9191
outf = PySys_GetObject("stdout");
92-
if (outf == NULL) {
92+
if (outf == NULL || outf == Py_None) {
9393
PyErr_SetString(PyExc_RuntimeError, "lost sys.stdout");
9494
return NULL;
9595
}

0 commit comments

Comments
 (0)