parse.y revision 1.11 1 /* $NetBSD: parse.y,v 1.11 2003/05/08 16:20:57 dsl Exp $ */
2
3 /*
4 * Copyright 1997 Piermont Information Systems Inc.
5 * All rights reserved.
6 *
7 * Written by Philip A. Nelson for Piermont Information Systems Inc.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 * 3. All advertising materials mentioning features or use of this software
18 * must display the following acknowledgement:
19 * This product includes software develooped for the NetBSD Project by
20 * Piermont Information Systems Inc.
21 * 4. The name of Piermont Information Systems Inc. may not be used to endorse
22 * or promote products derived from this software without specific prior
23 * written permission.
24 *
25 * THIS SOFTWARE IS PROVIDED BY PIERMONT INFORMATION SYSTEMS INC. ``AS IS''
26 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
27 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
28 * ARE DISCLAIMED. IN NO EVENT SHALL PIERMONT INFORMATION SYSTEMS INC. BE
29 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
30 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
31 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
32 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
33 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
34 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
35 * THE POSSIBILITY OF SUCH DAMAGE.
36 *
37 */
38
39
40 %{
41
42 #include <stdio.h>
43 #include "defs.h"
44
45 static id_rec *cur_menu;
46 static optn_info *cur_optn;
47
48 %}
49
50 %union {
51 char *s_value;
52 int i_value;
53 optn_info *optn_value;
54 action a_value;
55 }
56
57
58 %token <i_value> X Y W H NO BOX SUB HELP MENU NEXT EXIT ACTION ENDWIN OPTION
59 %token <i_value> TITLE DEFAULT DISPLAY ERROR EXITSTRING ALLOW DYNAMIC MENUS
60 SCROLLABLE SHORTCUT
61 %token <s_value> STRING NAME CODE INT_CONST CHAR_CONST
62
63 %type <s_value> init_code system helpstr text
64 %type <optn_value> option option_list
65 %type <i_value> act_opt
66 %type <a_value> action exitact
67
68 %start system
69
70 %%
71
72 system : init_code menu_list
73 { check_defined();
74 if (!had_errors)
75 write_menu_file($1);
76 }
77 ;
78
79 init_code : /* empty */ { $$ = ""; }
80 | CODE
81 ;
82
83 menu_list : /* empty */
84 | menu_list menu_def
85 | menu_list default_def
86 | menu_list initerror_def
87 | menu_list dynamic_def
88 ;
89
90 dynamic_def : ALLOW DYNAMIC MENUS ';'
91 { do_dynamic = 1; }
92
93 initerror_def : ERROR action ';'
94 { error_act = $2; }
95
96 default_def : DEFAULT
97 { cur_menu = &default_menu; }
98 opt opt_list ";"
99
100 menu_def : MENU NAME
101 { cur_menu = get_menu ($2);
102 if (cur_menu->info != NULL)
103 yyerror ("Menu %s defined twice", $2);
104 else {
105 cur_menu->info =
106 (menu_info *) malloc (sizeof (menu_info));
107 *(cur_menu->info) = default_info;
108 }
109 }
110 opts ";" dispact option_list exitact helpstr
111 { optn_info *t;
112 cur_menu->info->optns = NULL;
113 while ($7 != NULL) {
114 t = $7;
115 $7 = $7->next;
116 t->next = cur_menu->info->optns;
117 cur_menu->info->optns = t;
118 cur_menu->info->numopt++;
119 }
120 }
121 ;
122
123 opts : /* empty */
124 | opt_list
125 ;
126
127 opt_list : "," opt
128 | opt_list "," opt
129 ;
130
131 text : NAME | STRING
132
133 opt : NO EXIT { cur_menu->info->mopt |= NOEXITOPT; }
134 | EXIT { cur_menu->info->mopt &= ~NOEXITOPT; }
135 | NO BOX { cur_menu->info->mopt |= NOBOX; }
136 | BOX { cur_menu->info->mopt &= ~NOBOX; }
137 | NO SCROLLABLE { cur_menu->info->mopt &= ~SCROLL; }
138 | SCROLLABLE { cur_menu->info->mopt |= SCROLL; }
139 | NO SHORTCUT { cur_menu->info->mopt |= NOSHORTCUT; }
140 | SHORTCUT { cur_menu->info->mopt &= ~NOSHORTCUT; }
141 | X "=" INT_CONST { cur_menu->info->x = atoi($3); }
142 | Y "=" INT_CONST { cur_menu->info->y = atoi($3); }
143 | W "=" INT_CONST { cur_menu->info->w = atoi($3); }
144 | H "=" INT_CONST { cur_menu->info->h = atoi($3); }
145 | TITLE text { cur_menu->info->title = $2; }
146 | EXITSTRING text { cur_menu->info->exitstr = $2;
147 cur_menu->info->mopt &= ~NOEXITOPT; }
148 ;
149
150 option_list : option
151 | option_list option { $2->next = $1; $$ = $2; }
152 ;
153
154 option : OPTION text ","
155 { cur_optn = (optn_info *) malloc (sizeof(optn_info));
156 cur_optn->name = $2;
157 cur_optn->menu = -1;
158 cur_optn->issub = FALSE;
159 cur_optn->doexit = FALSE;
160 cur_optn->optact.code = "";
161 cur_optn->optact.endwin = FALSE;
162 cur_optn->next = NULL;
163 }
164 elem_list ";"
165 { $$ = cur_optn; }
166 ;
167
168 elem_list : elem
169 | elem_list "," elem
170 ;
171
172 elem : NEXT MENU NAME
173 { id_rec *t = get_menu ($3);
174 if (cur_optn->menu != -1)
175 yyerror ("Double sub/next menu definition");
176 else {
177 cur_optn->menu = t->menu_no;
178 }
179 }
180 | SUB MENU NAME
181 { id_rec *t = get_menu ($3);
182 if (cur_optn->menu != -1)
183 yyerror ("Double sub/next menu definition");
184 else {
185 cur_optn->menu = t->menu_no;
186 cur_optn->issub = TRUE;
187 }
188 }
189 | action { cur_optn->optact = $1; }
190 | EXIT { cur_optn->doexit = TRUE; }
191 ;
192
193 action : ACTION act_opt CODE
194 { $$.code = $3;
195 $$.endwin = $2;
196 }
197 ;
198
199 act_opt : /* empty */ { $$ = 0; }
200 | "(" ENDWIN ")" { $$ = 1; }
201 ;
202
203 dispact : /* empty */ { cur_menu->info->postact.code = ""; }
204 | DISPLAY action ";" { cur_menu->info->postact = $2; }
205 ;
206
207
208 exitact : /* empty */ { cur_menu->info->exitact.code = ""; }
209 | EXIT action ";" { cur_menu->info->exitact = $2; }
210 ;
211
212 helpstr : /* empty */ { cur_menu->info->helpstr = NULL; }
213 | HELP CODE ";" { cur_menu->info->helpstr = $2; }
214 ;
215