Scroll to navigation

GETMNTENT(3) Manuel du programmeur Linux GETMNTENT(3)

NOM

getmntent, setmntent, addmntent, endmntent, hasmntopt, getmntent_r - Obtenir des descriptions d'un système de fichiers

SYNOPSIS

#include <stdio.h>
#include <mntent.h>
FILE *setmntent(const char *nom_fichier, const char *type);
struct mntent *getmntent(FILE *flux);
int addmntent(FILE *restrict flux,
              const struct mntent *restrict mnt);
int endmntent(FILE *flux);
char *hasmntopt(const struct mntent *mnt, const char *opt);
/* GNU extension */
#include <mntent.h>
struct mntent *getmntent_r(FILE *restrict flux,
              struct mntent *restrict tampon_mnt,
              char *restrict tampon, int taille_tampon);

Exigences de macros de test de fonctionnalités pour la glibc (consulter feature_test_macros(7)) :

getmntent_r() :


Depuis la glibc 2.19 :
_DEFAULT_SOURCE
Pour la glibc 2.19 et précédentes :
_BSD_SOURCE || _SVID_SOURCE

DESCRIPTION

Ces routines permettent d'accéder au fichier de description des systèmes de fichiers /etc/fstab et au fichier de description des systèmes de fichiers montés /etc/mtab.

La fonction setmntent() ouvre le fichier de description de systèmes de fichiers nom_fichier et renvoie un pointeur de fichier utilisable par getmntent(). L'argument type est le type d'accès demandé, et peut prendre les même valeurs que l'argument mode de fopen(3). Pour fermer le flux renvoyé, il est préférable d'utiliser endmntent() plutôt que fclose(3).

La fonction getmntent() lit la ligne suivante du fichier de description de systèmes de fichiers sur flux et renvoie un pointeur vers une structure contenant une ligne de ce fichier décomposée en champs. Il s'agit d'un pointeur vers une zone de données statiques, dont le contenu est écrasée par des appels ultérieurs à getmntent().

La fonction addmntent() ajoute la structure mntent mnt à la fin du flux ouvert.

La fonction endmntent() ferme le flux associé au fichier de description de systèmes de fichiers.

La fonction hasmntopt() parcourt le champ mnt_opts (voir plus bas) de la structure mntent mnt à la recherche d'une chaîne correspondant à opt. Voir <mntent.h> et mount(8) pour les options de montage valables.

La fonction réentrante getmntent_r() est similaire à getmntent(), mais enregistre la structure mntent dans le tampon_mnt fourni et enregistre les chaînes pointées par les entrées de cette structure dans le tampon fourni de taille taille_tampon.

La structure mntent est définie dans <mntent.h> ainsi :


struct mntent {

char *mnt_fsname; /* Nom du système de fichiers monté */
char *mnt_dir; /* Chemin d'accès au système de fichiers */
char *mnt_type; /* Type de montage (voir mntent.h) */
char *mnt_opts; /* Options de montage (voir mntent.h) */
int mnt_freq; /* Fréquence de sauvegarde (en jour) */
int mnt_passno; /* Ordre de passage dans fsck */ };

Comme les champs dans les fichiers mtab et fstab sont séparés par des espaces, des échappements en valeurs octales sont utilisés pour représenter les caractères espace (\040), tabulation (\011), nouvelle ligne (\012) et barre oblique inverse (\\) dans ces fichiers lorsqu'ils apparaissent dans l'une des quatre chaînes d'une structure mntent. Les routines addmntent() et getmntent() convertiront la représentation des chaînes en représentations échappées et vice-versa. Lors de la conversion vers une représentation échappée, la séquence \134 est aussi convertie en barre oblique inverse.

VALEUR RENVOYÉE

Les fonctions getmntent() et getmntent_r() renvoient un pointeur sur la structure de type mntent, ou NULL en cas d'échec.

La fonction addmntent() renvoie 0 si elle réussit et 1 si elle échoue.

La fonction endmntent() renvoie toujours 1.

La fonction hasmntopt() renvoie l'adresse de la sous-chaîne si une correspondance est trouvée, ou NULL dans le cas contraire.

FICHIERS

/etc/fstab
fichier de description des systèmes de fichiers
/etc/mtab
fichier de description des systèmes de fichiers montés

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes(7).

Interface Attribut Valeur
setmntent(), endmntent(), hasmntopt() Sécurité des threads MT-Safe
getmntent() Sécurité des threads MT-Unsafe race:mntentbuf locale
addmntent() Sécurité des threads MT-Safe race:stream locale
getmntent_r() Sécurité des threads MT-Safe locale

CONFORMITÉ

Les fonctions non réentrantes viennent de SunOS 4.1.3. Une routine getmntent_r() a été introduite dans HP-UX 10, mais elle renvoie un entier. Le prototype ci-dessus n'est fourni que par la glibc.

NOTES

System V a aussi une fonction getmntent(), mais l'appel est différent, ainsi que la structure renvoyée. Sous System V, le fichier /etc/mnttab est utilisé. BSD 4.4 et Digital UNIX ont une routine getmntinfo() qui sert à invoquer l'appel système getfsstat().

VOIR AUSSI

fopen(3), fstab(5), mount(8)

COLOPHON

Cette page fait partie de la publication 5.13 du projet man-pages Linux. Une description du projet et des instructions pour signaler des anomalies et la dernière version de cette page peuvent être trouvées à l'adresse https://www.kernel.org/doc/man-pages/.

TRADUCTION

La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org> et Lucien Gentis <lucien.gentis@waika9.com>

Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à debian-l10n-french@lists.debian.org.

22 mars 2021