Commit 66725349 authored by Lionel Ulmer's avatar Lionel Ulmer Committed by Alexandre Julliard

Handle buffering in fgetpos / fsetpos.

parent ac6a413b
...@@ -2518,7 +2518,20 @@ MSVCRT_FILE* MSVCRT_freopen(const char *path, const char *mode,MSVCRT_FILE* file ...@@ -2518,7 +2518,20 @@ MSVCRT_FILE* MSVCRT_freopen(const char *path, const char *mode,MSVCRT_FILE* file
*/ */
int MSVCRT_fsetpos(MSVCRT_FILE* file, MSVCRT_fpos_t *pos) int MSVCRT_fsetpos(MSVCRT_FILE* file, MSVCRT_fpos_t *pos)
{ {
return _lseek(file->_file,*pos,SEEK_SET); /* Note that all this has been lifted 'as is' from fseek */
if(file->_flag & MSVCRT__IOWRT)
msvcrt_flush_buffer(file);
/* Discard buffered input */
file->_cnt = 0;
file->_ptr = file->_base;
/* Reset direction of i/o */
if(file->_flag & MSVCRT__IORW) {
file->_flag &= ~(MSVCRT__IOREAD|MSVCRT__IOWRT);
}
return _lseeki64(file->_file,*pos,SEEK_SET);
} }
/********************************************************************* /*********************************************************************
...@@ -2545,8 +2558,23 @@ LONG MSVCRT_ftell(MSVCRT_FILE* file) ...@@ -2545,8 +2558,23 @@ LONG MSVCRT_ftell(MSVCRT_FILE* file)
*/ */
int MSVCRT_fgetpos(MSVCRT_FILE* file, MSVCRT_fpos_t *pos) int MSVCRT_fgetpos(MSVCRT_FILE* file, MSVCRT_fpos_t *pos)
{ {
*pos = MSVCRT_ftell(file); /* This code has been lifted form the MSVCRT_ftell function */
return (*pos == -1? -1 : 0); int off=0;
*pos = _lseeki64(file->_file,0,SEEK_CUR);
if (*pos == -1) return -1;
if(file->_bufsiz) {
if( file->_flag & MSVCRT__IOWRT ) {
off = file->_ptr - file->_base;
} else {
off = -file->_cnt;
}
}
*pos += off;
return 0;
} }
/********************************************************************* /*********************************************************************
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment