Usermode/libc - Flush stdout on getchar
[tpg/acess2.git] / Usermode / Libraries / libc.so_src / stdio.c
index 372c489..e98ca42 100644 (file)
@@ -612,12 +612,12 @@ size_t _fread_memstream(void *ptr, size_t size, size_t num, FILE *fp)
 \r
 size_t _fread_buffered(void *ptr, size_t size, FILE *fp)\r
 {\r
-       _SysDebug("%p: %i-%i <= %i", fp,\r
-               (int)fp->Pos, (int)fp->BufferOfs, (int)fp->BufferPos);\r
+       //_SysDebug("%p: %i-%i <= %i", fp,\r
+       //      (int)fp->Pos, (int)fp->BufferOfs, (int)fp->BufferPos);\r
        if( fp->BufferPos > 0 ) {\r
-               assert( fp->Pos - fp->BufferOfs <= fp->BufferPos );\r
+               assert( fp->Pos - fp->BufferOfs <= (int)fp->BufferPos );\r
        }\r
-       if( fp->BufferPos == 0 || fp->Pos - fp->BufferOfs == fp->BufferPos )\r
+       if( fp->BufferPos == 0 || fp->Pos - fp->BufferOfs == (int)fp->BufferPos )\r
        {\r
                int rv = _SysRead(fp->FD, fp->Buffer, fp->BufferSpace);\r
                if( rv <= 0 ) {\r
@@ -627,15 +627,15 @@ size_t _fread_buffered(void *ptr, size_t size, FILE *fp)
                \r
                fp->BufferPos = rv;\r
                fp->BufferOfs = fp->Pos;\r
-               _SysDebug("%p: Buffered %i at %i", fp, rv, fp->Pos);\r
+               //_SysDebug("%p: Buffered %i at %i", fp, rv, fp->Pos);\r
        }\r
        \r
        size_t  inner_ofs = fp->Pos - fp->BufferOfs;\r
        if(size > fp->BufferPos - inner_ofs)\r
                size = fp->BufferPos - inner_ofs;\r
        \r
-       _SysDebug("%p: Read %i from %i+%i", fp, size,\r
-               (int)fp->BufferOfs, inner_ofs);\r
+       //_SysDebug("%p: Read %i from %i+%i", fp, size,\r
+       //      (int)fp->BufferOfs, inner_ofs);\r
        memcpy(ptr, fp->Buffer + inner_ofs, size);\r
        fp->Pos += size;\r
        return size;\r
@@ -774,6 +774,7 @@ EXPORT int fgetc(FILE *fp)
 \r
 EXPORT int getchar(void)\r
 {\r
+       fflush(stdout);\r
        return fgetc(stdin);\r
 }\r
 \r

UCC git Repository :: git.ucc.asn.au