Mercurial > hg > octave-lyh > gnulib-hg
changeset 619:dbaeca6a1983
(read_filesystem_list) [MOUNTED_LISTMNTENT]: New function.
From Johan Danielsson (joda@pdc.kth.se).
author | Jim Meyering <jim@meyering.net> |
---|---|
date | Thu, 23 May 1996 13:04:41 +0000 |
parents | 2cc24260a2fc |
children | 1078d7ac00eb |
files | lib/mountlist.c |
diffstat | 1 files changed, 34 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/lib/mountlist.c +++ b/lib/mountlist.c @@ -80,6 +80,10 @@ #include <sys/statfs.h> #endif +#ifdef MOUNTED_LISTMNTENT +#include <mntent.h> +#endif + #ifdef MOUNTED_GETMNTENT2 /* SVR4. */ #include <sys/mnttab.h> #endif @@ -195,6 +199,36 @@ me->me_next = NULL; mount_list = mtail = me; +#ifdef MOUNTED_LISTMNTENT + { + struct tabmntent *mntlist, *p; + struct mntent *mnt; + struct mount_entry *me; + + /* the third and fourth arguments could be used to filter mounts, + but Crays doesn't seem to have any mounts that we want to + remove. Specifically, automount create normal NFS mounts. + */ + + if(listmntent(&mntlist, KMTAB, NULL, NULL) < 0) + return NULL; + p = mntlist; + while(p){ + mnt = p->ment; + me = (struct mount_entry*) xmalloc(sizeof (struct mount_entry)); + me->me_devname = xstrdup(mnt->mnt_fsname); + me->me_mountdir = xstrdup(mnt->mnt_dir); + me->me_type = xstrdup(mnt->mnt_type); + me->me_dev = -1; + me->me_next = NULL; + mtail->me_next = me; + mtail = me; + p = p->next; + } + freemntlist(mntlist); + } +#endif + #ifdef MOUNTED_GETMNTENT1 /* 4.3BSD, SunOS, HP-UX, Dynix, Irix. */ { struct mntent *mnt;