getmntopts.c revision 4065
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
351558Srgrimesstatic char sccsid[] = "@(#)getmntopts.c	8.1 (Berkeley) 3/27/94";
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;
601558Srgrimes	char *opt, *optbuf;
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
751558Srgrimes		/* Scan option table. */
763202Sache		for (m = m0; m->m_option != NULL; ++m) {
773202Sache			len = strlen(m->m_option);
783202Sache			if (strncasecmp(opt, m->m_option, len) == 0)
793202Sache				if (   m->m_option[len]	== '\0'
803202Sache				    || m->m_option[len]	== '='
813202Sache				   )
821558Srgrimes				break;
833202Sache		}
841558Srgrimes
851558Srgrimes		/* Save flag, or fail if option is not recognised. */
861558Srgrimes		if (m->m_option) {
874065Swollman			thisflagp = m->m_altloc ? altflagp : flagp;
881558Srgrimes			if (negative == m->m_inverse)
894065Swollman				*thisflagp |= m->m_flag;
901558Srgrimes			else
914065Swollman				*thisflagp &= ~m->m_flag;
924065Swollman		} else if(!getmnt_silent) {
931558Srgrimes			errx(1, "-o %s: option not supported", opt);
944065Swollman		}
951558Srgrimes	}
961558Srgrimes
971558Srgrimes	free(optbuf);
981558Srgrimes}
99