Fixed obscure bug in setvbuf
authorceriel <none@none>
Mon, 4 Dec 1995 17:11:54 +0000 (17:11 +0000)
committerceriel <none@none>
Mon, 4 Dec 1995 17:11:54 +0000 (17:11 +0000)
lang/cem/libcc.ansi/stdio/setvbuf.c

index 3e6366b..c6dd3dc 100644 (file)
@@ -23,8 +23,9 @@ setvbuf(register FILE *stream, char *buf, int mode, size_t size)
 
        stream->_flags &= ~(_IOMYBUF | _IONBF | _IOLBF);
 
+       if (buf && size <= 0) retval = EOF;
        if (!buf && (mode != _IONBF)) {
-               if ((buf = (char *) malloc(size)) == NULL) {
+               if (size <= 0 || (buf = (char *) malloc(size)) == NULL) {
                        retval = EOF;
                } else {
                        stream->_flags |= _IOMYBUF;