=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/parse/stdio.c,v retrieving revision 1.2 retrieving revision 1.8 diff -u -p -r1.2 -r1.8 --- OpenXM_contrib2/asir2000/parse/stdio.c 2000/08/21 08:31:47 1.2 +++ OpenXM_contrib2/asir2000/parse/stdio.c 2017/08/31 02:36:21 1.8 @@ -23,7 +23,7 @@ * shall be made on your publication or presentation in any form of the * results obtained by use of the SOFTWARE. * (4) In the event that you modify the SOFTWARE, you shall notify FLL by - * e-mail at risa-admin@flab.fujitsu.co.jp of the detailed specification + * e-mail at risa-admin@sec.flab.fujitsu.co.jp of the detailed specification * for such modification or the source code of the modified part of the * SOFTWARE. * @@ -45,7 +45,7 @@ * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. * - * $OpenXM: OpenXM_contrib2/asir2000/parse/stdio.c,v 1.1.1.1 1999/12/03 07:39:12 noro Exp $ + * $OpenXM: OpenXM_contrib2/asir2000/parse/stdio.c,v 1.7 2005/10/19 04:51:15 noro Exp $ */ #include #include @@ -61,18 +61,32 @@ static struct w_buf { } W_BUF; static int noflush; +extern int emergency; #define INBUF_EMPTY (W_BUF.inpos >= W_BUF.inlen) +void w_purge_stdin(void) +{ + W_BUF.inpos = 0; + W_BUF.inlen = 0; +} + int w_filbuf(void) { int status = get_line(W_BUF.inbuf); + + /* XXX */ + if ( emergency ) return 0; + W_BUF.inpos = 0; W_BUF.inlen = strlen(W_BUF.inbuf); return status; } int w_flushbuf(void) { + /* XXX */ + if ( emergency ) return 0; + W_BUF.outbuf[W_BUF.outpos] = 0; W_BUF.outpos = 0; put_line(W_BUF.outbuf); @@ -135,16 +149,18 @@ int unget_char(int c) return c; } -int put_char(int c,FILE *file) +int win_put_string(char *s,FILE *file); + +int win_put_char(int c,FILE *file) { static char s[2]; s[0] = (char)c; - put_string(s,file); + win_put_string(s,file); return c; } -int put_string(char *s,FILE *file) +int win_put_string(char *s,FILE *file) { char c; @@ -186,17 +202,15 @@ int w_ungetc(int c, FILE *file) int w_fputc(int c, FILE *file) { if ( file == stdout || file == stderr ) - return put_char(c,file); + return win_put_char(c,file); else return fputc(c,file); } int w_fputs(char *s, FILE *file) { - int status; - if ( file == stdout || file == stderr ) - return put_string(s,file); + return win_put_string(s,file); else return fputs(s,file); } @@ -205,11 +219,19 @@ int w_printf(char *format, ...) { va_list ap; int status; - char buf[BUFSIZ]; + static char *buf; + static int bufsiz=0; + if ( !bufsiz ) { + bufsiz = BUFSIZ*10; buf = (char *)malloc(bufsiz); + } va_start(ap,format); + status = vsnprintf(buf,0,format,ap); + if ( status > bufsiz ) { + bufsiz = 2*status; free(buf); buf = (char *)malloc(bufsiz); + } status = vsprintf(buf,format,ap); - put_string(buf,stdout); + win_put_string(buf,stdout); return status; } @@ -217,12 +239,20 @@ int w_fprintf(FILE *file, char *format, ...) { va_list ap; int status; - char buf[BUFSIZ]; + static char *buf; + static int bufsiz=0; + if ( !bufsiz ) { + bufsiz = BUFSIZ*10; buf = (char *)malloc(bufsiz); + } va_start(ap,format); if ( file == stdout || file == stderr ) { + status = vsnprintf(buf,0,format,ap); + if ( status > bufsiz ) { + bufsiz = 2*status; free(buf); buf = (char *)malloc(bufsiz); + } status = vsprintf(buf,format,ap); - put_string(buf,file); + win_put_string(buf,file); } else { status = vfprintf(file,format,ap); }