vfslist.c revision 1.1 1 1.1 lukem /*
2 1.1 lukem * Copyright (c) 1995
3 1.1 lukem * The Regents of the University of California. All rights reserved.
4 1.1 lukem *
5 1.1 lukem * Redistribution and use in source and binary forms, with or without
6 1.1 lukem * modification, are permitted provided that the following conditions
7 1.1 lukem * are met:
8 1.1 lukem * 1. Redistributions of source code must retain the above copyright
9 1.1 lukem * notice, this list of conditions and the following disclaimer.
10 1.1 lukem * 2. Redistributions in binary form must reproduce the above copyright
11 1.1 lukem * notice, this list of conditions and the following disclaimer in the
12 1.1 lukem * documentation and/or other materials provided with the distribution.
13 1.1 lukem * 3. All advertising materials mentioning features or use of this software
14 1.1 lukem * must display the following acknowledgement:
15 1.1 lukem * This product includes software developed by the University of
16 1.1 lukem * California, Berkeley and its contributors.
17 1.1 lukem * 4. Neither the name of the University nor the names of its contributors
18 1.1 lukem * may be used to endorse or promote products derived from this software
19 1.1 lukem * without specific prior written permission.
20 1.1 lukem *
21 1.1 lukem * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22 1.1 lukem * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 1.1 lukem * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 1.1 lukem * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25 1.1 lukem * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 1.1 lukem * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 1.1 lukem * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 1.1 lukem * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 1.1 lukem * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 1.1 lukem * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 1.1 lukem * SUCH DAMAGE.
32 1.1 lukem */
33 1.1 lukem
34 1.1 lukem #ifndef lint
35 1.1 lukem static char sccsid[] = "@(#)vfslist.c 8.1 (Berkeley) 5/8/95";
36 1.1 lukem #endif /* not lint */
37 1.1 lukem
38 1.1 lukem #include <stdlib.h>
39 1.1 lukem #include <string.h>
40 1.1 lukem #include <unistd.h>
41 1.1 lukem
42 1.1 lukem int checkvfsname __P((const char *, const char **));
43 1.1 lukem const char **makevfslist __P((char *));
44 1.1 lukem static int skipvfs;
45 1.1 lukem
46 1.1 lukem int
47 1.1 lukem checkvfsname(vfsname, vfslist)
48 1.1 lukem const char *vfsname;
49 1.1 lukem const char **vfslist;
50 1.1 lukem {
51 1.1 lukem
52 1.1 lukem if (vfslist == NULL)
53 1.1 lukem return (0);
54 1.1 lukem while (*vfslist != NULL) {
55 1.1 lukem if (strcmp(vfsname, *vfslist) == 0)
56 1.1 lukem return (skipvfs);
57 1.1 lukem ++vfslist;
58 1.1 lukem }
59 1.1 lukem return (!skipvfs);
60 1.1 lukem }
61 1.1 lukem
62 1.1 lukem const char **
63 1.1 lukem makevfslist(fslist)
64 1.1 lukem char *fslist;
65 1.1 lukem {
66 1.1 lukem const char **av;
67 1.1 lukem int i;
68 1.1 lukem char *nextcp;
69 1.1 lukem
70 1.1 lukem if (fslist == NULL)
71 1.1 lukem return (NULL);
72 1.1 lukem if (fslist[0] == 'n' && fslist[1] == 'o') {
73 1.1 lukem fslist += 2;
74 1.1 lukem skipvfs = 1;
75 1.1 lukem }
76 1.1 lukem for (i = 0, nextcp = fslist; *nextcp; nextcp++)
77 1.1 lukem if (*nextcp == ',')
78 1.1 lukem i++;
79 1.1 lukem if ((av = malloc((size_t)(i + 2) * sizeof(char *))) == NULL) {
80 1.1 lukem warn(NULL);
81 1.1 lukem return (NULL);
82 1.1 lukem }
83 1.1 lukem nextcp = fslist;
84 1.1 lukem i = 0;
85 1.1 lukem av[i++] = nextcp;
86 1.1 lukem while ((nextcp = strchr(nextcp, ',')) != NULL) {
87 1.1 lukem *nextcp++ = '\0';
88 1.1 lukem av[i++] = nextcp;
89 1.1 lukem }
90 1.1 lukem av[i++] = NULL;
91 1.1 lukem return (av);
92 1.1 lukem }
93