fseeko(3S)


fseeko, fseeko64, ftello, ftello64 -- reposition a file pointer in a stream

Synopsis

   #include <stdio.h> 
   

int fseeko(FILE *stream, off_t offset, int ptrname);

int fseeko64(FILE *stream, off64_t offset, int ptrname);

off_t ftello(FILE *stream);

off64_t ftello64(FILE *stream);

Description

fseeko sets the position of the next input or output operation on the stream (see intro(3)). The new position is at the signed distance offset bytes from the beginning, from the current position, or from the end of the file, according to a ptrname value of SEEK_SET, SEEK_CUR, or SEEK_END (defined in stdio.h) as follows:

SEEK_SET
set position equal to offset bytes.

SEEK_CUR
set position to current location plus offset.

SEEK_END
set position to EOF plus offset.

fseeko allows the file position indicator to be set beyond the end of the existing data in the file. If data is later written at this point, subsequent reads of data in the gap will return zero until data is actually written into the gap. fseeko, by itself, does not extend the size of the file.

fseek clears the EOF indicator and undoes any effects of ungetc on stream. After fseek, the next operation on a file opened for update may be either input or output.

If stream is writable and buffered data has not been written to the underlying file, fseek causes the unwritten data to be written to the file.

ftello returns the offset of the current byte relative to the beginning of the file associated with the named stream.

Errors

fseeko and fseeko64 return -1 for improper seeks, otherwise zero. An improper seek can be, for example, an fseeko or an fseeko64 done on a file that has not been opened via fopen or fopen64; in particular, fseeko and fseeko64 may not be used on a terminal or on a file opened via popen. After a stream is closed, no further operations are defined on that stream.

fseeko and ftello fail when the resulting file offset would be a value which cannot be represented correctly in an object of type off_t.

References

fopen(3S), intro(2), Intro(3S), lseek(2), popen(3S), ungetc(3S), write(2)

Notices

Although on the UNIX system an offset returned by ftello is measured in bytes, and it is permissible to seek to positions relative to that offset, portability to non-UNIX systems requires that an offset be used by fseeko directly. Arithmetic may not meaningfully be performed on such an offset, which is not necessarily measured in bytes.

Considerations for large file support

fseeko64 and ftello64 support large files, but are otherwise identical to fseeko and ftello, respectively. For details on programming for large file capable applications, see ``Large File Support'' on intro(2).
30 January 1998
© 1998 The Santa Cruz Operation, Inc. All rights reserved.