Re-add linux-style getmntent
[kopensolaris-gnu/glibc.git] / sysdeps / unix / sysv / solaris2 / kopensolaris-gnu / mntent_sun.c
1 /* Copyright (C) 2008 Free Software Foundation, Inc.
2    This file is part of the GNU C Library.
3    Contributed by David Bartley <dtbartle@csclub.uwaterloo.ca>, 2008.
4
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
9
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
14
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
19
20 #include <mntentP.h>
21 #include <stdio.h>
22 #include <string.h>
23 #include <ctype.h>
24 #include <sys/ioctl.h>
25
26 /* Docs: http://docs.sun.com/app/docs/doc/816-5168/resetmnttab-3c  */
27
28 #define _MNT_CMP(x, y, f) \
29         (!y->f || (y->f && strcmp (x->f, y->f) == 0))
30
31
32 int getmntent (FILE *fp, struct mnttab *mt)
33 {
34   struct extmnttab emt;
35   int res = ioctl (fileno (fp), MNTIOC_GETMNTENT, &emt);
36   if (res != 0)
37     return -1;
38
39   mt->mnt_special = emt.mnt_special;
40   mt->mnt_mountp = emt.mnt_mountp;
41   mt->mnt_fstype = emt.mnt_fstype;
42   mt->mnt_mntopts = emt.mnt_mntopts;
43   mt->mnt_time = emt.mnt_time;
44
45   return 0;
46 }
47
48 int getmntany (FILE *fp, struct mnttab *mt, struct mnttab *mtpref)
49 {
50   int res;
51   while ((res = getmntent (fp, mt)) == 0)
52     {
53       if (_MNT_CMP (mt, mtpref, mnt_special) &&
54           _MNT_CMP (mt, mtpref, mnt_mountp) &&
55           _MNT_CMP (mt, mtpref, mnt_fstype) &&
56           _MNT_CMP (mt, mtpref, mnt_mntopts) &&
57           _MNT_CMP (mt, mtpref, mnt_time))
58         return 0;
59     }
60
61   return res;
62 }
63
64
65 int getextmntent(FILE *fp, struct extmnttab *emt, int len)
66 {
67   int res = ioctl (fileno (fp), MNTIOC_GETMNTENT, emt);
68   if (res != 0)
69     return -1;
70   return 0;
71 }
72
73
74 char *mntopt (char **opts)
75 {
76   char *optsp = *opts;
77
78   /* Strip leading spaces.  */
79   while (*optsp == ' ')
80     optsp++;
81
82   /* Find comma.  */
83   char *ret = optsp;
84   while (*optsp != ',' && *optsp != '\0')
85     optsp++;
86
87   /* Replace comma with null terminator.  */
88   if (*optsp == ',')
89     optsp++;
90   *opts = optsp;
91
92   return ret;
93 }
94
95
96 char * hasmntopt (struct mnttab *mt, char *opt)
97 {
98   /* We make a copy of mnt_mntopts since we modify it.  */
99   char buf[MNT_LINE_MAX + 1];
100   strncpy (buf, mt->mnt_mntopts, sizeof (buf))[MNT_LINE_MAX] = '\0';
101
102   char *opts = buf;
103   char *optp;
104   size_t len = strlen (opt);
105   while (*(optp = mntopt (&opts)))
106     {
107       /* Check if opt matched, taking into account delimiters (e.g. '=').  */
108       if (strncmp (optp, opt, len) == 0 && !isalnum (optp[len]))
109         return mt->mnt_mntopts + (optp - buf);
110     }
111
112   return NULL;
113 }
114
115
116 void resetmnttab (FILE *fp)
117 {
118   rewind (fp);
119 }