nsparser.y revision 1.4
11.2Slukem%{
21.4Skleink/*	$NetBSD: nsparser.y,v 1.4 1999/07/02 15:27:09 kleink Exp $	*/
31.2Slukem
41.2Slukem/*-
51.2Slukem * Copyright (c) 1997, 1998, 1999 The NetBSD Foundation, Inc.
61.2Slukem * All rights reserved.
71.2Slukem *
81.2Slukem * This code is derived from software contributed to The NetBSD Foundation
91.2Slukem * by Luke Mewburn.
101.2Slukem *
111.2Slukem * Redistribution and use in source and binary forms, with or without
121.2Slukem * modification, are permitted provided that the following conditions
131.2Slukem * are met:
141.2Slukem * 1. Redistributions of source code must retain the above copyright
151.2Slukem *    notice, this list of conditions and the following disclaimer.
161.2Slukem * 2. Redistributions in binary form must reproduce the above copyright
171.2Slukem *    notice, this list of conditions and the following disclaimer in the
181.2Slukem *    documentation and/or other materials provided with the distribution.
191.2Slukem * 3. All advertising materials mentioning features or use of this software
201.2Slukem *    must display the following acknowledgement:
211.2Slukem *        This product includes software developed by the NetBSD
221.2Slukem *        Foundation, Inc. and its contributors.
231.2Slukem * 4. Neither the name of The NetBSD Foundation nor the names of its
241.2Slukem *    contributors may be used to endorse or promote products derived
251.2Slukem *    from this software without specific prior written permission.
261.2Slukem *
271.2Slukem * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
281.2Slukem * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
291.2Slukem * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
301.2Slukem * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
311.2Slukem * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
321.2Slukem * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
331.2Slukem * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
341.2Slukem * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
351.2Slukem * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
361.2Slukem * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
371.2Slukem * POSSIBILITY OF SUCH DAMAGE.
381.2Slukem */
391.2Slukem
401.3Slukem#include <sys/cdefs.h>
411.3Slukem#if defined(LIBC_SCCS) && !defined(lint)
421.4Skleink__RCSID("$NetBSD: nsparser.y,v 1.4 1999/07/02 15:27:09 kleink Exp $");
431.3Slukem#endif /* LIBC_SCCS and not lint */
441.3Slukem
451.4Skleink#include "namespace.h"
461.3Slukem#include <err.h>
471.2Slukem#define _NS_PRIVATE
481.2Slukem#include <nsswitch.h>
491.2Slukem#include <stdio.h>
501.2Slukem#include <string.h>
511.2Slukem
521.2Slukem
531.2Slukemstatic	void	_nsaddsrctomap __P((const char *));
541.2Slukem
551.2Slukemstatic	ns_dbt		curdbt;
561.2Slukemstatic	ns_src		cursrc;
571.2Slukem%}
581.2Slukem
591.2Slukem%union {
601.2Slukem	char *str;
611.2Slukem	int   mapval;
621.2Slukem}
631.2Slukem
641.2Slukem%token	NL
651.2Slukem%token	SUCCESS UNAVAIL NOTFOUND TRYAGAIN
661.2Slukem%token	RETURN CONTINUE
671.2Slukem%token	<str> STRING
681.2Slukem
691.2Slukem%type	<mapval> Status Action
701.2Slukem
711.2Slukem%%
721.2Slukem
731.2SlukemFile
741.2Slukem	:	/* empty */
751.2Slukem	| Lines
761.2Slukem	;
771.2Slukem
781.2SlukemLines
791.2Slukem	: Entry
801.2Slukem	| Lines Entry
811.2Slukem	;
821.2Slukem
831.2SlukemEntry
841.2Slukem	: NL
851.2Slukem	| Database ':' NL
861.2Slukem	| Database ':' Srclist NL
871.2Slukem		{
881.2Slukem			_nsdbtput(&curdbt);
891.2Slukem		}
901.2Slukem	;
911.2Slukem
921.2SlukemDatabase
931.2Slukem	: STRING
941.2Slukem		{
951.2Slukem			curdbt.name = yylval.str;
961.2Slukem			curdbt.srclist = NULL;
971.2Slukem			curdbt.srclistsize = 0;
981.2Slukem		}
991.2Slukem	;
1001.2Slukem
1011.2SlukemSrclist
1021.2Slukem	: Item
1031.2Slukem	| Srclist Item
1041.2Slukem	;
1051.2Slukem
1061.2SlukemItem
1071.2Slukem	: STRING
1081.2Slukem		{
1091.2Slukem			cursrc.flags = NS_SUCCESS;
1101.2Slukem			_nsaddsrctomap($1);
1111.2Slukem		}
1121.2Slukem	| STRING '[' { cursrc.flags = NS_SUCCESS; } Criteria ']'
1131.2Slukem		{
1141.2Slukem			_nsaddsrctomap($1);
1151.2Slukem		}
1161.2Slukem	;
1171.2Slukem
1181.2SlukemCriteria
1191.2Slukem	: Criterion
1201.2Slukem	| Criteria Criterion
1211.2Slukem	;
1221.2Slukem
1231.2SlukemCriterion
1241.2Slukem	: Status '=' Action
1251.2Slukem		{
1261.2Slukem			if ($3)		/* if action == RETURN set RETURN bit */
1271.2Slukem				cursrc.flags |= $1;
1281.2Slukem			else		/* else unset it */
1291.2Slukem				cursrc.flags &= ~$1;
1301.2Slukem		}
1311.2Slukem	;
1321.2Slukem
1331.2SlukemStatus
1341.2Slukem	: SUCCESS	{ $$ = NS_SUCCESS; }
1351.2Slukem	| UNAVAIL	{ $$ = NS_UNAVAIL; }
1361.2Slukem	| NOTFOUND	{ $$ = NS_NOTFOUND; }
1371.2Slukem	| TRYAGAIN	{ $$ = NS_TRYAGAIN; }
1381.2Slukem	;
1391.2Slukem
1401.2SlukemAction
1411.2Slukem	: RETURN	{ $$ = 1L; }
1421.2Slukem	| CONTINUE	{ $$ = 0L; }
1431.2Slukem	;
1441.2Slukem
1451.2Slukem%%
1461.2Slukem
1471.2Slukemstatic void
1481.2Slukem_nsaddsrctomap(elem)
1491.2Slukem	const char *elem;
1501.2Slukem{
1511.2Slukem	int		i, lineno;
1521.2Slukem	extern int	_nsyylineno;
1531.2Slukem	extern char *	_nsyytext;
1541.2Slukem
1551.2Slukem	lineno = _nsyylineno - (*_nsyytext == '\n' ? 1 : 0);
1561.2Slukem	if (curdbt.srclistsize > 0) {
1571.2Slukem		if ((strcasecmp(elem, NSSRC_COMPAT) == 0) ||
1581.2Slukem		    (strcasecmp(curdbt.srclist[0].name, NSSRC_COMPAT) == 0)) {
1591.2Slukem				/* XXX: syslog the following */
1601.2Slukem			warnx("%s line %d: 'compat' used with other sources",
1611.2Slukem			    _PATH_NS_CONF, lineno);
1621.2Slukem			return;
1631.2Slukem		}
1641.2Slukem	}
1651.2Slukem	for (i = 0; i < curdbt.srclistsize; i++) {
1661.2Slukem		if (strcasecmp(curdbt.srclist[i].name, elem) == 0) {
1671.2Slukem				/* XXX: syslog the following */
1681.2Slukem			warnx("%s line %d: duplicate source '%s'",
1691.2Slukem			    _PATH_NS_CONF, lineno, elem);
1701.2Slukem			return;
1711.2Slukem		}
1721.2Slukem	}
1731.2Slukem	cursrc.name = elem;
1741.2Slukem	_nsdbtaddsrc(&curdbt, &cursrc);
1751.2Slukem}
176