[Python-checkins] cpython (merge 3.2 -> default): (Merge 3.2) Issue #12016: my_fgets() now always clears errors before calling
victor.stinner
python-checkins at python.org
Mon May 30 23:47:17 CEST 2011
http://hg.python.org/cpython/rev/deb6e7859211
changeset: 70536:deb6e7859211
parent: 70533:4b6e76d3b1fa
parent: 70535:de07f90ef45c
user: Victor Stinner <victor.stinner at haypocalc.com>
date: Mon May 30 23:47:01 2011 +0200
summary:
(Merge 3.2) Issue #12016: my_fgets() now always clears errors before calling
fgets(). Fix the following case: sys.stdin.read() stopped with CTRL+d (end of
file), raw_input() interrupted by CTRL+c.
files:
Misc/NEWS | 4 ++++
Parser/myreadline.c | 1 +
2 files changed, 5 insertions(+), 0 deletions(-)
diff --git a/Misc/NEWS b/Misc/NEWS
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,6 +10,10 @@
Core and Builtins
-----------------
+- Issue #12016: my_fgets() now always clears errors before calling fgets(). Fix
+ the following case: sys.stdin.read() stopped with CTRL+d (end of file),
+ raw_input() interrupted by CTRL+c.
+
- Issue #12216: Allow unexpected EOF errors to happen on any line of the file.
- Issue #12199: The TryExcept and TryFinally and AST nodes have been unified
diff --git a/Parser/myreadline.c b/Parser/myreadline.c
--- a/Parser/myreadline.c
+++ b/Parser/myreadline.c
@@ -40,6 +40,7 @@
if (PyOS_InputHook != NULL)
(void)(PyOS_InputHook)();
errno = 0;
+ clearerr(fp);
p = fgets(buf, len, fp);
if (p != NULL)
return 0; /* No error */
--
Repository URL: http://hg.python.org/cpython
More information about the Python-checkins
mailing list