msvcrt: Fix ^Z handling in text mode.
This commit is contained in:
parent
3978535ced
commit
56eb6f6730
|
@ -59,6 +59,7 @@ WINE_DEFAULT_DEBUG_CHANNEL(msvcrt);
|
||||||
/* values for wxflag in file descriptor */
|
/* values for wxflag in file descriptor */
|
||||||
#define WX_OPEN 0x01
|
#define WX_OPEN 0x01
|
||||||
#define WX_ATEOF 0x02
|
#define WX_ATEOF 0x02
|
||||||
|
#define WX_READEOF 0x04 /* like ATEOF, but for underlying file rather than buffer */
|
||||||
#define WX_DONTINHERIT 0x10
|
#define WX_DONTINHERIT 0x10
|
||||||
#define WX_APPEND 0x20
|
#define WX_APPEND 0x20
|
||||||
#define WX_TEXT 0x80
|
#define WX_TEXT 0x80
|
||||||
|
@ -827,7 +828,7 @@ __int64 CDECL _lseeki64(int fd, __int64 offset, int whence)
|
||||||
ofs.QuadPart = offset;
|
ofs.QuadPart = offset;
|
||||||
if (SetFilePointerEx(hand, ofs, &ret, whence))
|
if (SetFilePointerEx(hand, ofs, &ret, whence))
|
||||||
{
|
{
|
||||||
MSVCRT_fdesc[fd].wxflag &= ~WX_ATEOF;
|
MSVCRT_fdesc[fd].wxflag &= ~(WX_ATEOF|WX_READEOF);
|
||||||
/* FIXME: What if we seek _to_ EOF - is EOF set? */
|
/* FIXME: What if we seek _to_ EOF - is EOF set? */
|
||||||
|
|
||||||
return ret.QuadPart;
|
return ret.QuadPart;
|
||||||
|
@ -1666,6 +1667,11 @@ static int read_i(int fd, void *buf, unsigned int count)
|
||||||
char *bufstart = buf;
|
char *bufstart = buf;
|
||||||
HANDLE hand = msvcrt_fdtoh(fd);
|
HANDLE hand = msvcrt_fdtoh(fd);
|
||||||
|
|
||||||
|
if (MSVCRT_fdesc[fd].wxflag & WX_READEOF) {
|
||||||
|
MSVCRT_fdesc[fd].wxflag |= WX_ATEOF;
|
||||||
|
TRACE("already at EOF, returning 0\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
/* Don't trace small reads, it gets *very* annoying */
|
/* Don't trace small reads, it gets *very* annoying */
|
||||||
if (count > 4)
|
if (count > 4)
|
||||||
TRACE(":fd (%d) handle (%p) buf (%p) len (%d)\n",fd,hand,buf,count);
|
TRACE(":fd (%d) handle (%p) buf (%p) len (%d)\n",fd,hand,buf,count);
|
||||||
|
@ -1692,7 +1698,7 @@ static int read_i(int fd, void *buf, unsigned int count)
|
||||||
}
|
}
|
||||||
if (num_read != count)
|
if (num_read != count)
|
||||||
{
|
{
|
||||||
MSVCRT_fdesc[fd].wxflag |= WX_ATEOF;
|
MSVCRT_fdesc[fd].wxflag |= (WX_ATEOF|WX_READEOF);
|
||||||
TRACE(":EOF %s\n",debugstr_an(buf,num_read));
|
TRACE(":EOF %s\n",debugstr_an(buf,num_read));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -287,6 +287,23 @@ static void test_asciimode(void)
|
||||||
ok((fread(buf, 1, sizeof(buf), fp) == 2) && (0 == strcmp(buf, "\r\n")), "CR CR LF not read as CR LF\n");
|
ok((fread(buf, 1, sizeof(buf), fp) == 2) && (0 == strcmp(buf, "\r\n")), "CR CR LF not read as CR LF\n");
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
unlink("ascii.tst");
|
unlink("ascii.tst");
|
||||||
|
|
||||||
|
/* Simple test of foo ^Z [more than one block] bar handling */
|
||||||
|
fp = fopen("ascii.tst", "wb");
|
||||||
|
fputs("foo\032", fp); /* foo, logical EOF, ... */
|
||||||
|
fseek(fp, 65536L, SEEK_SET); /* ... more than MSVCRT_BUFSIZ, ... */
|
||||||
|
fputs("bar", fp); /* ... bar */
|
||||||
|
fclose(fp);
|
||||||
|
fp = fopen("ascii.tst", "rt");
|
||||||
|
ok(fgets(buf, sizeof(buf), fp) != NULL, "fgets foo\n");
|
||||||
|
ok(0 == strcmp(buf, "foo"), "foo ^Z not read as foo by fgets\n");
|
||||||
|
ok(fgets(buf, sizeof(buf), fp) == NULL, "fgets after logical EOF\n");
|
||||||
|
rewind(fp);
|
||||||
|
ok((fread(buf, 1, sizeof(buf), fp) == 3) && (0 == strcmp(buf, "foo")), "foo ^Z not read as foo by fread\n");
|
||||||
|
ok((fread(buf, 1, sizeof(buf), fp) == 0), "fread after logical EOF\n");
|
||||||
|
fclose(fp);
|
||||||
|
|
||||||
|
unlink("ascii.tst");
|
||||||
}
|
}
|
||||||
|
|
||||||
static WCHAR* AtoW( const char* p )
|
static WCHAR* AtoW( const char* p )
|
||||||
|
|
Loading…
Reference in New Issue