fix scanf %c conversion wrongly storing a terminating null byte
authorRich Felker <dalias@aerifal.cx>
Sat, 22 Jun 2013 21:23:45 +0000 (17:23 -0400)
committerRich Felker <dalias@aerifal.cx>
Sat, 22 Jun 2013 21:23:45 +0000 (17:23 -0400)
this seems to have been a regression from the refactoring which added
the 'm' modifier.

src/stdio/vfscanf.c
src/stdio/vfwscanf.c

index 6bea6ad..bb92848 100644 (file)
@@ -265,8 +265,10 @@ int vfscanf(FILE *restrict f, const char *restrict fmt, va_list ap)
                                if (size == SIZE_l) *(wchar_t **)dest = wcs;
                                else *(char **)dest = s;
                        }
                                if (size == SIZE_l) *(wchar_t **)dest = wcs;
                                else *(char **)dest = s;
                        }
-                       if (wcs) wcs[i] = 0;
-                       if (s) s[i] = 0;
+                       if (t != 'c') {
+                               if (wcs) wcs[i] = 0;
+                               if (s) s[i] = 0;
+                       }
                        break;
                case 'p':
                case 'X':
                        break;
                case 'p':
                case 'X':
index b1eb793..760864f 100644 (file)
@@ -281,8 +281,10 @@ int vfwscanf(FILE *restrict f, const wchar_t *restrict fmt, va_list ap)
                                if (size == SIZE_l) *(wchar_t **)dest = wcs;
                                else *(char **)dest = s;
                        }
                                if (size == SIZE_l) *(wchar_t **)dest = wcs;
                                else *(char **)dest = s;
                        }
-                       if (wcs) wcs[i] = 0;
-                       if (s) s[i] = 0;
+                       if (t != 'c') {
+                               if (wcs) wcs[i] = 0;
+                               if (s) s[i] = 0;
+                       }
                        break;
 
                case 'd': case 'i': case 'o': case 'u': case 'x':
                        break;
 
                case 'd': case 'i': case 'o': case 'u': case 'x':