getmntopts.c revision 25301
11558Srgrimes/*-
21558Srgrimes * Copyright (c) 1994
31558Srgrimes *	The Regents of the University of California.  All rights reserved.
41558Srgrimes *
51558Srgrimes * Redistribution and use in source and binary forms, with or without
61558Srgrimes * modification, are permitted provided that the following conditions
71558Srgrimes * are met:
81558Srgrimes * 1. Redistributions of source code must retain the above copyright
91558Srgrimes *    notice, this list of conditions and the following disclaimer.
101558Srgrimes * 2. Redistributions in binary form must reproduce the above copyright
111558Srgrimes *    notice, this list of conditions and the following disclaimer in the
121558Srgrimes *    documentation and/or other materials provided with the distribution.
131558Srgrimes * 3. All advertising materials mentioning features or use of this software
141558Srgrimes *    must display the following acknowledgement:
151558Srgrimes *	This product includes software developed by the University of
161558Srgrimes *	California, Berkeley and its contributors.
171558Srgrimes * 4. Neither the name of the University nor the names of its contributors
181558Srgrimes *    may be used to endorse or promote products derived from this software
191558Srgrimes *    without specific prior written permission.
201558Srgrimes *
211558Srgrimes * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
221558Srgrimes * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
231558Srgrimes * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
241558Srgrimes * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
251558Srgrimes * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
261558Srgrimes * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
271558Srgrimes * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
281558Srgrimes * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
291558Srgrimes * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
301558Srgrimes * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
311558Srgrimes * SUCH DAMAGE.
321558Srgrimes */
331558Srgrimes
341558Srgrimes#ifndef lint
3523678Speterstatic char sccsid[] = "@(#)getmntopts.c	8.3 (Berkeley) 3/29/95";
361558Srgrimes#endif /* not lint */
371558Srgrimes
381558Srgrimes#include <sys/param.h>
391558Srgrimes#include <sys/mount.h>
401558Srgrimes
411558Srgrimes#include <err.h>
421558Srgrimes#include <errno.h>
431558Srgrimes#include <fstab.h>
441558Srgrimes#include <stdlib.h>
451558Srgrimes#include <string.h>
461558Srgrimes
471558Srgrimes#include "mntopts.h"
481558Srgrimes
494065Swollmanint getmnt_silent = 0;
504065Swollman
511558Srgrimesvoid
524065Swollmangetmntopts(options, m0, flagp, altflagp)
531558Srgrimes	const char *options;
541558Srgrimes	const struct mntopt *m0;
551558Srgrimes	int *flagp;
564065Swollman	int *altflagp;
571558Srgrimes{
581558Srgrimes	const struct mntopt *m;
593202Sache	int negative, len;
6023678Speter	char *opt, *optbuf, *p;
614065Swollman	int *thisflagp;
621558Srgrimes
631558Srgrimes	/* Copy option string, since it is about to be torn asunder... */
641558Srgrimes	if ((optbuf = strdup(options)) == NULL)
651558Srgrimes		err(1, NULL);
661558Srgrimes
671558Srgrimes	for (opt = optbuf; (opt = strtok(opt, ",")) != NULL; opt = NULL) {
681558Srgrimes		/* Check for "no" prefix. */
691558Srgrimes		if (opt[0] == 'n' && opt[1] == 'o') {
701558Srgrimes			negative = 1;
711558Srgrimes			opt += 2;
721558Srgrimes		} else
731558Srgrimes			negative = 0;
741558Srgrimes
7523678Speter		/*
7623678Speter		 * for options with assignments in them (ie. quotas)
7723678Speter		 * ignore the assignment as it's handled elsewhere
7823678Speter		 */
7923678Speter		p = strchr(opt, '=');
8023678Speter		if (p)
8125301Smsmith			 *++p = '\0';
8223678Speter
831558Srgrimes		/* Scan option table. */
843202Sache		for (m = m0; m->m_option != NULL; ++m) {
853202Sache			len = strlen(m->m_option);
863202Sache			if (strncasecmp(opt, m->m_option, len) == 0)
873202Sache				if (   m->m_option[len]	== '\0'
883202Sache				    || m->m_option[len]	== '='
893202Sache				   )
901558Srgrimes				break;
913202Sache		}
921558Srgrimes
931558Srgrimes		/* Save flag, or fail if option is not recognised. */
941558Srgrimes		if (m->m_option) {
954065Swollman			thisflagp = m->m_altloc ? altflagp : flagp;
961558Srgrimes			if (negative == m->m_inverse)
974065Swollman				*thisflagp |= m->m_flag;
981558Srgrimes			else
994065Swollman				*thisflagp &= ~m->m_flag;
10023678Speter		} else if (!getmnt_silent) {
1011558Srgrimes			errx(1, "-o %s: option not supported", opt);
1024065Swollman		}
1031558Srgrimes	}
1041558Srgrimes
1051558Srgrimes	free(optbuf);
1061558Srgrimes}
107