fseek

Autres langues

Langue: fr

Version: 29 novembre 1993 (mandriva - 01/05/08)

Section: 3 (Bibliothèques de fonctions)

NOM

fgetpos, fseek, fsetpos, ftell, rewind - Accéder à la position courante d'un flux

SYNOPSIS

#include <stdio.h>

int fseek (FILE *stream, long offset, int whence);
long ftell (FILE *stream);
void rewind (FILE *stream);
int fgetpos (FILE *stream, fpos_t *pos);
int fsetpos (FILE *stream, fpos_t *pos);

DESCRIPTION

La fonction fseek() fixe l'indicateur de position du flux pointé par stream. La nouvelle position, mesurée en octets, est obtenue en additionnant offset octets au point de départ indiqué par whence. Si whence vaut SEEK_SET, SEEK_CUR, ou SEEK_END, le point de départ correspond respectivement au début du fichier, à la position actuelle, ou à la fin du fichier. Un appel réussi à fseek() efface l'indicateur de fin de fichier pour le flux, et annule les effets de toute fonction ungetc(3) précédente sur le même flux.

La fonction ftell() lit la valeur de l'indicateur de position pour le flux pointé par stream.

La fonction rewind() ramène l'indicateur de position du flux pointé par stream au début du fichier. C'est l'équivalent de :

(void) fseek(stream, 0L, SEEK_SET)

sauf que l'indicateur d'erreur du flux est également effacé. (voir clearerr(3)).

Les fonctions fgetpos() et fsetpos() sont des alternatives à ftell() et fseek() (avec whence valant SEEK_SET), en fixant, ou en mémorisant la valeur de l'indicateur de position du fichier dans l'objet référencé par pos. Sur certains systèmes non-UNIX, l'objet fpos_t peut être un objet complexe, et ces routines peuvent être les seules méthodes possibles pour repositionner un flux de texte de manière portable.

VALEUR RENVOYÉE

La fonction rewind() ne renvoie pas de valeur. Si elles réussissent totalement, fgetpos(), fseek(), fsetpos() renvoient 0, et ftell() renvoie la position actuelle. Sinon, elles renvoient -1 et errno contient le code d'erreur.

ERREURS

EBADF
Le flux stream n'est pas positionnable.
EINVAL
L'argument whence dans l'appel fseek() n'était ni SEEK_SET, ni SEEK_END, ni SEEK_CUR.

Les fonctions fgetpos(), fseek(), fsetpos(), et ftell() peuvent également, en cas d'échec, positionner errno sur n'importe quelle erreur indiquée par les routines fflush(3), fstat(2), lseek(2), et malloc(3).

CONFORMITÉ

C89, C99.

VOIR AUSSI

lseek(2), fseeko(3)

TRADUCTION

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 23 octobre 1996 et révisée le 24 novembre 2007.

L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 3 fseek ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.