b64481fed4
* Check for non-ASCII characters in getch() because the rest of the code doesn't expect such. * Removed use of -traditional and constructs which relied on this. * Use raise(SIGFPE) in dump() instead of attempting a division-by-zero. * Fixed compiler warnings regarding missing prototypes or unused parameters.
459 lines
10 KiB
C
459 lines
10 KiB
C
/* $NetBSD: xebec.c,v 1.11 2007/01/18 12:43:38 cbiere Exp $ */
|
|
|
|
#include <sys/cdefs.h>
|
|
__RCSID("$NetBSD: xebec.c,v 1.11 2007/01/18 12:43:38 cbiere Exp $");
|
|
|
|
#include "xebec.h"
|
|
#include "llparse.h"
|
|
#ifndef E_TABLE
|
|
#define E_TABLE "xebec.e"
|
|
#endif /* !E_TABLE */
|
|
|
|
#include "main.h"
|
|
#include "sets.h"
|
|
#include "procs.h"
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
extern FILE *eventfile_h, *actfile;
|
|
|
|
void
|
|
llaction(lln,token)
|
|
int lln;
|
|
LLtoken *token;
|
|
{
|
|
struct llattr *llattr;
|
|
(void) token;
|
|
llattr = &llattrdesc[lldescindex-1];
|
|
switch(lln) {
|
|
case 1:
|
|
llfinprod();
|
|
break;
|
|
|
|
case 10: {
|
|
|
|
if(strlen(llattr->llabase[3].ID.address) > 50 ) {
|
|
fprintf(stderr,
|
|
"Protocol name may not exceed 50 chars in length.\n");
|
|
Exit(-1);
|
|
}
|
|
strcpy(protocol, llattr->llabase[3].ID.address);
|
|
openfiles(protocol);
|
|
|
|
} break;
|
|
|
|
case 11: {
|
|
|
|
llattr->llabase[7].pcb.isevent = 0;
|
|
|
|
} break;
|
|
|
|
case 12: {
|
|
|
|
fprintf(actfile, "\ntypedef %s %s%s;\n",
|
|
llattr->llabase[7].pcb.address,protocol, PCBNAME);
|
|
llattr->llabase[8].syn.type = PCB_SYN;
|
|
|
|
} break;
|
|
|
|
case 13: {
|
|
llattr->llabase[11].part.type = (unsigned char) STATESET;
|
|
} break;
|
|
|
|
case 14: {
|
|
end_states(eventfile_h);
|
|
} break;
|
|
|
|
case 15: {
|
|
llattr->llabase[14].pcb.isevent = 1;
|
|
} break;
|
|
|
|
case 16: {
|
|
|
|
fprintf(eventfile_h, "\t"); /* fmq gags on single chars */
|
|
includecode(eventfile_h, llattr->llabase[14].pcb.address);
|
|
fprintf(eventfile_h, "\n"); /* fmq gags on single chars */
|
|
llattr->llabase[15].syn.type = EVENT_SYN;
|
|
|
|
} break;
|
|
|
|
case 17: {
|
|
|
|
llattr->llabase[16].part.type = (unsigned char)EVENTSET;
|
|
|
|
} break;
|
|
|
|
case 18: {
|
|
end_events();
|
|
} break;
|
|
|
|
case 19: {
|
|
|
|
putincludes();
|
|
putdriver(actfile, 9);
|
|
|
|
} break;
|
|
|
|
case 20: {
|
|
if(llattr->llabase[0].pcb.isevent) {
|
|
fprintf(stderr,
|
|
"Event is a list of objects enclosed by \"{}\"\n");
|
|
Exit(-1);
|
|
}
|
|
fprintf(eventfile_h, "struct ");
|
|
|
|
} break;
|
|
|
|
case 21: {
|
|
llattr->llabase[0].pcb.address = llattr->llabase[2].ACTION.address;
|
|
} break;
|
|
|
|
case 22: {
|
|
if( ! llattr->llabase[0].pcb.isevent) {
|
|
fprintf(stderr,
|
|
"Pcb requires a type or structure definition.\"{}\"\n");
|
|
Exit(-1);
|
|
}
|
|
llattr->llabase[0].pcb.address = llattr->llabase[1].ACTION.address;
|
|
|
|
} break;
|
|
|
|
case 23: {
|
|
llattr->llabase[0].pcb.address = llattr->llabase[1].ID.address;
|
|
} break;
|
|
|
|
case 24: {
|
|
synonyms[llattr->llabase[0].syn.type] = stash( llattr->llabase[2].ID.address );
|
|
} break;
|
|
|
|
case 25: {
|
|
includecode(actfile, llattr->llabase[2].ACTION.address);
|
|
} break;
|
|
|
|
case 26: {
|
|
|
|
llattr->llabase[2].partrest.address = llattr->llabase[1].ID.address;
|
|
llattr->llabase[2].partrest.type = llattr->llabase[0].part.type;
|
|
|
|
} break;
|
|
|
|
case 27: {
|
|
llattr->llabase[3].parttail.type = llattr->llabase[0].part.type;
|
|
} break;
|
|
|
|
case 28: {
|
|
llattr->llabase[1].part.type = llattr->llabase[0].parttail.type;
|
|
} break;
|
|
|
|
case 29: {
|
|
|
|
if( lookup( llattr->llabase[0].partrest.type, llattr->llabase[0].partrest.address ) ) {
|
|
fprintf(stderr, "bnf:trying to redefine obj type 0x%x, adr %s\n",
|
|
llattr->llabase[0].partrest.type, llattr->llabase[0].partrest.address);
|
|
Exit(-1);
|
|
}
|
|
llattr->llabase[2].setdef.type = llattr->llabase[0].partrest.type;
|
|
llattr->llabase[2].setdef.address = stash( llattr->llabase[0].partrest.address );
|
|
llattr->llabase[2].setdef.keep = 1;
|
|
|
|
} break;
|
|
|
|
case 30: {
|
|
llattr->llabase[3].setstruct.object = llattr->llabase[2].setdef.object;
|
|
} break;
|
|
|
|
case 31: {
|
|
|
|
defineitem(llattr->llabase[0].partrest.type,
|
|
llattr->llabase[0].partrest.address, llattr->llabase[1].ACTION.address);
|
|
|
|
} break;
|
|
|
|
case 32: {
|
|
|
|
defineitem(llattr->llabase[0].partrest.type, llattr->llabase[0].partrest.address, (char *)0);
|
|
|
|
} break;
|
|
|
|
case 33: {
|
|
|
|
if(llattr->llabase[0].setstruct.object) {
|
|
/* WHEN COULD THIS BE FALSE??
|
|
* isn't it supposed to be setstruct.object???
|
|
* (it used to be $ACTION.address)
|
|
*/
|
|
|
|
llattr->llabase[0].setstruct.object->obj_struc = llattr->llabase[1].ACTION.address;
|
|
fprintf(eventfile_h,
|
|
"struct %s %s%s;\n\n", llattr->llabase[1].ACTION.address,
|
|
EV_PREFIX, llattr->llabase[0].setstruct.object->obj_name);
|
|
}
|
|
|
|
} break;
|
|
|
|
case 34: {
|
|
|
|
llattr->llabase[2].setlist.setnum =
|
|
defineset(llattr->llabase[0].setdef.type, llattr->llabase[0].setdef.address, llattr->llabase[0].setdef.keep);
|
|
|
|
} break;
|
|
|
|
case 35: {
|
|
llattr->llabase[0].setdef.object = llattr->llabase[2].setlist.setnum;
|
|
} break;
|
|
|
|
case 36: {
|
|
|
|
member(llattr->llabase[0].setlist.setnum, llattr->llabase[1].ID.address);
|
|
llattr->llabase[2].setlisttail.setnum = llattr->llabase[0].setlist.setnum;
|
|
|
|
} break;
|
|
|
|
case 37: {
|
|
llattr->llabase[2].setlist.setnum = llattr->llabase[0].setlisttail.setnum;
|
|
} break;
|
|
|
|
case 38: {
|
|
transno++;
|
|
} break;
|
|
|
|
case 39: {
|
|
|
|
CurrentEvent /* GAG! */ = llattr->llabase[6].event.object;
|
|
|
|
} break;
|
|
|
|
case 40: {
|
|
|
|
llattr->llabase[8].actionpart.string = llattr->llabase[7].predicatepart.string;
|
|
llattr->llabase[8].actionpart.newstate = llattr->llabase[1].newstate.object;
|
|
llattr->llabase[8].actionpart.oldstate = llattr->llabase[5].oldstate.object;
|
|
|
|
} break;
|
|
|
|
case 41: {
|
|
|
|
llattr->llabase[0].predicatepart.string = stash ( llattr->llabase[1].PREDICATE.address );
|
|
|
|
} break;
|
|
|
|
case 42: {
|
|
|
|
llattr->llabase[0].predicatepart.string = (char *)0;
|
|
|
|
} break;
|
|
|
|
case 43: {
|
|
|
|
statetable( llattr->llabase[0].actionpart.string, llattr->llabase[0].actionpart.oldstate,
|
|
llattr->llabase[0].actionpart.newstate,
|
|
acttable(actfile, llattr->llabase[1].ACTION.address ),
|
|
CurrentEvent );
|
|
if( print_trans ) {
|
|
dump_trans( llattr->llabase[0].actionpart.string, llattr->llabase[0].actionpart.oldstate,
|
|
llattr->llabase[0].actionpart.newstate,
|
|
llattr->llabase[1].ACTION.address, CurrentEvent );
|
|
}
|
|
|
|
} break;
|
|
|
|
case 44: {
|
|
|
|
statetable(llattr->llabase[0].actionpart.string, llattr->llabase[0].actionpart.oldstate, llattr->llabase[0].actionpart.newstate,
|
|
0, CurrentEvent ); /* KLUDGE - remove this */
|
|
if( print_trans ) {
|
|
dump_trans( llattr->llabase[0].actionpart.string, llattr->llabase[0].actionpart.oldstate,
|
|
llattr->llabase[0].actionpart.newstate,
|
|
"NULLACTION", CurrentEvent );
|
|
}
|
|
|
|
} break;
|
|
|
|
case 45: {
|
|
|
|
llattr->llabase[0].oldstate.object = Lookup(STATESET, llattr->llabase[1].ID.address);
|
|
|
|
} break;
|
|
|
|
case 46: {
|
|
|
|
llattr->llabase[1].setdef.address = (char *)0;
|
|
llattr->llabase[1].setdef.type = (unsigned char)STATESET;
|
|
llattr->llabase[1].setdef.keep = 0;
|
|
|
|
} break;
|
|
|
|
case 47: {
|
|
|
|
llattr->llabase[0].oldstate.object = llattr->llabase[1].setdef.object;
|
|
|
|
} break;
|
|
|
|
case 48: {
|
|
|
|
llattr->llabase[0].newstate.object = Lookup(STATESET, llattr->llabase[1].ID.address);
|
|
|
|
} break;
|
|
|
|
case 49: {
|
|
|
|
extern struct Object *SameState;
|
|
|
|
llattr->llabase[0].newstate.object = SameState;
|
|
|
|
} break;
|
|
|
|
case 50: {
|
|
|
|
llattr->llabase[0].event.object = Lookup(EVENTSET, llattr->llabase[1].ID.address);
|
|
|
|
} break;
|
|
|
|
case 51: {
|
|
|
|
llattr->llabase[1].setdef.address = (char *)0;
|
|
llattr->llabase[1].setdef.type = (unsigned char)EVENTSET;
|
|
llattr->llabase[1].setdef.keep = 0;
|
|
|
|
} break;
|
|
|
|
case 52: {
|
|
|
|
llattr->llabase[0].event.object = llattr->llabase[1].setdef.object;
|
|
|
|
} break;
|
|
}
|
|
}
|
|
char *llstrings[] = {
|
|
"<null>",
|
|
"ID",
|
|
"STRUCT",
|
|
"SYNONYM",
|
|
"PREDICATE",
|
|
"ACTION",
|
|
"PROTOCOL",
|
|
"LBRACK",
|
|
"RBRACK",
|
|
"LANGLE",
|
|
"EQUAL",
|
|
"COMMA",
|
|
"STAR",
|
|
"EVENTS",
|
|
"TRANSITIONS",
|
|
"INCLUDE",
|
|
"STATES",
|
|
"SEMI",
|
|
"PCB",
|
|
"DEFAULT",
|
|
"NULLACTION",
|
|
"SAME",
|
|
"ENDMARKER",
|
|
"pcb",
|
|
"syn",
|
|
"setlist",
|
|
"setlisttail",
|
|
"part",
|
|
"parttail",
|
|
"partrest",
|
|
"setstruct",
|
|
"setdef",
|
|
"translist",
|
|
"transition",
|
|
"event",
|
|
"oldstate",
|
|
"newstate",
|
|
"predicatepart",
|
|
"actionpart",
|
|
"program",
|
|
"includelist",
|
|
"optsemi",
|
|
"translisttail",
|
|
"$goal$",
|
|
(char *) 0
|
|
};
|
|
short llnterms = 23;
|
|
short llnsyms = 44;
|
|
short llnprods = 38;
|
|
short llinfinite = 10000;
|
|
short llproductions[] = {
|
|
41, -21, 5, -20, 2,
|
|
41, -22, 5,
|
|
41, -23, 1,
|
|
-24, 1, 3,
|
|
|
|
26, -36, 1,
|
|
25, -37, 11,
|
|
|
|
28, -27, 29, -26, 1,
|
|
27, -28,
|
|
|
|
30, -30, 31, -29, 10,
|
|
-31, 5,
|
|
-32,
|
|
-33, 5,
|
|
|
|
-35, 8, 25, -34, 7,
|
|
42, 33,
|
|
17, 38, -40, 37, -39, 34, 35, 10, 10, 9, -38, 36,
|
|
-50, 1,
|
|
-52, 31, -51,
|
|
-45, 1,
|
|
-47, 31, -46,
|
|
-48, 1,
|
|
-49, 21,
|
|
-41, 4,
|
|
-42, 19,
|
|
-43, 5,
|
|
-44, 20,
|
|
32, -19, 14, -18, 12, 27, -17, 24, -16, 23, -15, 13, -14, 12, 27, -13, 16, 12, 24, -12, 23, -11, 18, 40, 12, -10, 1, 6, 12,
|
|
12, -25, 5, 15,
|
|
|
|
17,
|
|
|
|
32,
|
|
|
|
22, 39,
|
|
0
|
|
};
|
|
struct llprodindex llprodindex[] = {
|
|
{ 0, 0, 0 }, { 0, 5, 19 }, { 5, 3, 3 }, { 8, 3, 2 },
|
|
{ 11, 3, 2 }, { 14, 0, 2 }, { 14, 3, 0 }, { 17, 3, 1 },
|
|
{ 20, 0, 0 }, { 20, 5, 3 }, { 25, 2, 0 }, { 27, 0, 3 },
|
|
{ 27, 5, 1 }, { 32, 2, 0 }, { 34, 1, 3 }, { 35, 2, 1 },
|
|
{ 37, 0, 0 }, { 37, 5, 1 }, { 42, 2, 0 }, { 44, 12, 3 },
|
|
{ 56, 2, 2 }, { 58, 3, 2 }, { 61, 2, 0 }, { 63, 3, 2 },
|
|
{ 66, 2, 1 }, { 68, 2, 0 }, { 70, 2, 9 }, { 72, 2, 1 },
|
|
{ 74, 2, 1 }, { 76, 2, 1 }, { 78, 29, 1 }, { 107, 4, 1 },
|
|
{ 111, 0, 1 }, { 111, 1, 1 }, { 112, 0, 1 }, { 112, 1, 1 },
|
|
{ 113, 0, 1 }, { 113, 2, 2 }, { 0, 0, 0 }
|
|
};
|
|
short llepsilon[] = {
|
|
0, 0, 0, 0, 0, 1, 0, 0, 1, 0,
|
|
0, 1, 0, 0, 1, 0, 1, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 1, 0, 1, 0, 1, 0, 0
|
|
};
|
|
struct llparsetable llparsetable[] = {
|
|
{ 1, 3 }, { 2, 1 }, { 5, 2 }, { 0, 23 }, { 1, 5 },
|
|
{ 3, 4 }, { 12, 5 }, { 0, 24 }, { 1, 6 }, { 0, 25 },
|
|
{ 8, 8 }, { 11, 7 }, { 0, 26 }, { 1, 9 }, { 0, 27 },
|
|
{ 1, 10 }, { 12, 11 }, { 0, 28 }, { 1, 14 }, { 5, 13 },
|
|
{ 10, 12 }, { 12, 14 }, { 0, 29 }, { 1, 16 }, { 5, 15 },
|
|
{ 12, 16 }, { 0, 30 }, { 7, 17 }, { 0, 31 }, { 1, 18 },
|
|
{ 21, 18 }, { 0, 32 }, { 1, 19 }, { 21, 19 }, { 0, 33 },
|
|
{ 1, 20 }, { 7, 21 }, { 0, 34 }, { 1, 22 }, { 7, 23 },
|
|
{ 0, 35 }, { 1, 24 }, { 21, 25 }, { 0, 36 }, { 4, 26 },
|
|
{ 19, 27 }, { 0, 37 }, { 5, 28 }, { 20, 29 }, { 0, 38 },
|
|
{ 12, 30 }, { 0, 39 }, { 15, 31 }, { 18, 32 }, { 0, 40 },
|
|
{ 1, 34 }, { 3, 34 }, { 12, 34 }, { 17, 33 }, { 0, 41 },
|
|
{ 1, 35 }, { 21, 35 }, { 22, 36 }, { 0, 42 }, { 12, 37 },
|
|
{ 0, 43 }, { 0, 0 }
|
|
};
|
|
short llparseindex[] = {
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 4, 8, 10, 13, 15, 18,
|
|
23, 27, 29, 32, 35, 38, 41, 44, 47, 50,
|
|
52, 55, 60, 64, 0
|
|
};
|