3 * The Regents of the University of California. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * 3. Neither the name of the University nor the names of its contributors
14 * may be used to endorse or promote products derived from this software
15 * without specific prior written permission.
17 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
18 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * @(#)getmntopts.c 8.3 (Berkeley) 3/29/95
30 * $FreeBSD: src/sbin/mount/getmntopts.c,v 1.9 1999/10/09 11:54:06 phk Exp $
33 #include <sys/param.h>
43 int getmnt_silent
= 0;
46 getmntopts(const char *options
, const struct mntopt
*m0
, int *flagp
,
49 const struct mntopt
*m
;
51 char *opt
, *optbuf
, *p
;
54 /* Copy option string, since it is about to be torn asunder... */
55 if ((optbuf
= strdup(options
)) == NULL
)
58 for (opt
= optbuf
; (opt
= strtok(opt
, ",")) != NULL
; opt
= NULL
) {
59 /* Check for "no" prefix. */
60 if (opt
[0] == 'n' && opt
[1] == 'o') {
67 * for options with assignments in them (ie. quotas)
68 * ignore the assignment as it's handled elsewhere
74 /* Scan option table. */
75 for (m
= m0
; m
->m_option
!= NULL
; ++m
) {
76 if (strcasecmp(opt
, m
->m_option
) == 0)
80 /* Save flag, or fail if option is not recognized. */
82 thisflagp
= m
->m_altloc
? altflagp
: flagp
;
83 if (negative
== m
->m_inverse
)
84 *thisflagp
|= m
->m_flag
;
86 *thisflagp
&= ~m
->m_flag
;
87 } else if (!getmnt_silent
) {
88 errx(1, "-o %s: option not supported", opt
);
96 rmslashes(char *rrpin
, char *rrpout
)
101 for (rrpoutstart
= rrpout
; *rrpin
!= '\0'; *rrpout
++ = *rrpin
++) {
103 /* skip all double slashes */
104 while (*rrpin
== '/' && *(rrpin
+ 1) == '/')
108 /* remove trailing slash if necessary */
109 if (rrpout
- rrpoutstart
> 1 && *(rrpout
- 1) == '/')
110 *(rrpout
- 1) = '\0';
116 checkpath(const char *path
, char *resolved
)
120 if (realpath(path
, resolved
) != NULL
&& stat(resolved
, &sb
) == 0) {
121 if (!S_ISDIR(sb
.st_mode
))
122 errx(EX_USAGE
, "%s: not a directory", resolved
);
124 errx(EX_USAGE
, "%s: %s", resolved
, strerror(errno
));