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