diff options
| author | Antoine Pitrou <solipsis@pitrou.net> | 2011-12-16 12:29:37 +0100 | 
|---|---|---|
| committer | Antoine Pitrou <solipsis@pitrou.net> | 2011-12-16 12:29:37 +0100 | 
| commit | ab0e9f7089c04df546af6cacbc8751247cf4020a (patch) | |
| tree | 3494351a976a17a62146a3ddd365fe2b5936fca4 /Parser | |
| parent | e2b2bf55b30299e310b246b5b4b6f5a5f66e75b2 (diff) | |
| parent | c345ce1a69b3c4a46d87ef56d859bc70abfc74b4 (diff) | |
| download | cpython-git-ab0e9f7089c04df546af6cacbc8751247cf4020a.tar.gz | |
Issue #10350: Read and save errno before calling a function which might overwrite it.
Original patch by Hallvard B Furuseth.
Diffstat (limited to 'Parser')
| -rw-r--r-- | Parser/myreadline.c | 4 | 
1 files changed, 3 insertions, 1 deletions
| diff --git a/Parser/myreadline.c b/Parser/myreadline.c index fb4b805e20..33d5b3d4cc 100644 --- a/Parser/myreadline.c +++ b/Parser/myreadline.c @@ -36,6 +36,7 @@ static int  my_fgets(char *buf, int len, FILE *fp)  {      char *p; +    int err;      while (1) {          if (PyOS_InputHook != NULL)              (void)(PyOS_InputHook)(); @@ -44,6 +45,7 @@ my_fgets(char *buf, int len, FILE *fp)          p = fgets(buf, len, fp);          if (p != NULL)              return 0; /* No error */ +        err = errno;  #ifdef MS_WINDOWS          /* In the case of a Ctrl+C or some other external event             interrupting the operation: @@ -78,7 +80,7 @@ my_fgets(char *buf, int len, FILE *fp)              return -1; /* EOF */          }  #ifdef EINTR -        if (errno == EINTR) { +        if (err == EINTR) {              int s;  #ifdef WITH_THREAD              PyEval_RestoreThread(_PyOS_ReadlineTState); | 
