- Generated new parser.

This commit is contained in:
ccremers 2007-01-09 15:27:19 +00:00
parent eb7f14c891
commit 4ba6c82968
2 changed files with 78 additions and 156 deletions

View File

@ -27,7 +27,6 @@
#line 1 "parser.y" #line 1 "parser.y"
#include "pheading.h" #include "pheading.h"
/* #include "lex.yy.c" */
#include "tac.h" #include "tac.h"
#include "error.h" #include "error.h"
@ -37,7 +36,7 @@ int yyerror(char *s);
int yylex(void); int yylex(void);
#line 14 "parser.y" #line 13 "parser.y"
typedef union{ typedef union{
char* str; char* str;
struct tacnode* tac; struct tacnode* tac;
@ -124,11 +123,11 @@ static const short yyrhs[] = { 32,
#if YYDEBUG != 0 #if YYDEBUG != 0
static const short yyrline[] = { 0, static const short yyrline[] = { 0,
70, 74, 76, 80, 86, 93, 101, 107, 113, 115, 69, 73, 75, 79, 85, 92, 100, 106, 112, 114,
117, 121, 132, 134, 138, 140, 144, 146, 148, 150, 116, 120, 131, 133, 137, 139, 143, 145, 147, 149,
154, 161, 168, 177, 185, 192, 199, 206, 212, 218, 153, 160, 167, 176, 184, 191, 198, 205, 211, 217,
225, 229, 236, 241, 248, 253, 259, 263, 265, 270, 224, 228, 235, 240, 247, 252, 258, 262, 264, 269,
278, 280, 286, 290, 296, 298, 302, 304, 308 277, 279, 285, 289, 295, 297, 301, 303, 307
}; };
#endif #endif
@ -782,19 +781,19 @@ yyreduce:
switch (yyn) { switch (yyn) {
case 1: case 1:
#line 71 "parser.y" #line 70 "parser.y"
{ spdltac = yyvsp[0].tac; ; { spdltac = yyvsp[0].tac; ;
break;} break;}
case 2: case 2:
#line 75 "parser.y" #line 74 "parser.y"
{ yyval.tac = NULL; ; { yyval.tac = NULL; ;
break;} break;}
case 3: case 3:
#line 77 "parser.y" #line 76 "parser.y"
{ yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ;
break;} break;}
case 4: case 4:
#line 81 "parser.y" #line 80 "parser.y"
{ {
Tac t = tacCreate(TAC_UNTRUSTED); Tac t = tacCreate(TAC_UNTRUSTED);
t->t1.tac = yyvsp[-1].tac; t->t1.tac = yyvsp[-1].tac;
@ -802,7 +801,7 @@ case 4:
; ;
break;} break;}
case 5: case 5:
#line 87 "parser.y" #line 86 "parser.y"
{ {
Tac t = tacCreate(TAC_RUN); Tac t = tacCreate(TAC_RUN);
t->t1.tac = yyvsp[-4].tac; t->t1.tac = yyvsp[-4].tac;
@ -811,7 +810,7 @@ case 5:
; ;
break;} break;}
case 6: case 6:
#line 94 "parser.y" #line 93 "parser.y"
{ {
Tac t = tacCreate(TAC_PROTOCOL); Tac t = tacCreate(TAC_PROTOCOL);
t->t1.sym = yyvsp[-7].symb; t->t1.sym = yyvsp[-7].symb;
@ -821,7 +820,7 @@ case 6:
; ;
break;} break;}
case 7: case 7:
#line 102 "parser.y" #line 101 "parser.y"
{ {
Tac t = tacCreate(TAC_USERTYPE); Tac t = tacCreate(TAC_USERTYPE);
t->t1.tac = yyvsp[-1].tac; t->t1.tac = yyvsp[-1].tac;
@ -829,25 +828,25 @@ case 7:
; ;
break;} break;}
case 8: case 8:
#line 108 "parser.y" #line 107 "parser.y"
{ {
yyval.tac = yyvsp[0].tac; yyval.tac = yyvsp[0].tac;
; ;
break;} break;}
case 9: case 9:
#line 114 "parser.y" #line 113 "parser.y"
{ yyval.tac = NULL; ; { yyval.tac = NULL; ;
break;} break;}
case 10: case 10:
#line 116 "parser.y" #line 115 "parser.y"
{ yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ;
break;} break;}
case 11: case 11:
#line 118 "parser.y" #line 117 "parser.y"
{ yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ;
break;} break;}
case 12: case 12:
#line 122 "parser.y" #line 121 "parser.y"
{ {
// TODO process singular (0/1) // TODO process singular (0/1)
Tac t = tacCreate(TAC_ROLE); Tac t = tacCreate(TAC_ROLE);
@ -858,39 +857,39 @@ case 12:
; ;
break;} break;}
case 13: case 13:
#line 133 "parser.y" #line 132 "parser.y"
{ yyval.value = 0; ; { yyval.value = 0; ;
break;} break;}
case 14: case 14:
#line 135 "parser.y" #line 134 "parser.y"
{ yyval.value = 1; ; { yyval.value = 1; ;
break;} break;}
case 15: case 15:
#line 139 "parser.y" #line 138 "parser.y"
{ ; { ;
break;} break;}
case 16: case 16:
#line 141 "parser.y" #line 140 "parser.y"
{ ; { ;
break;} break;}
case 17: case 17:
#line 145 "parser.y" #line 144 "parser.y"
{ yyval.tac = NULL; ; { yyval.tac = NULL; ;
break;} break;}
case 18: case 18:
#line 147 "parser.y" #line 146 "parser.y"
{ yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ;
break;} break;}
case 19: case 19:
#line 149 "parser.y" #line 148 "parser.y"
{ yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ;
break;} break;}
case 20: case 20:
#line 151 "parser.y" #line 150 "parser.y"
{ yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-1].tac,yyvsp[0].tac); ;
break;} break;}
case 21: case 21:
#line 155 "parser.y" #line 154 "parser.y"
{ Tac t = tacCreate(TAC_READ); { Tac t = tacCreate(TAC_READ);
t->t1.sym = yyvsp[-4].symb; t->t1.sym = yyvsp[-4].symb;
/* TODO test here: tac2 should have at least 3 elements */ /* TODO test here: tac2 should have at least 3 elements */
@ -899,7 +898,7 @@ case 21:
; ;
break;} break;}
case 22: case 22:
#line 162 "parser.y" #line 161 "parser.y"
{ Tac t = tacCreate(TAC_SEND); { Tac t = tacCreate(TAC_SEND);
t->t1.sym = yyvsp[-4].symb; t->t1.sym = yyvsp[-4].symb;
/* TODO test here: tac2 should have at least 3 elements */ /* TODO test here: tac2 should have at least 3 elements */
@ -908,7 +907,7 @@ case 22:
; ;
break;} break;}
case 23: case 23:
#line 170 "parser.y" #line 169 "parser.y"
{ Tac t = tacCreate(TAC_CLAIM); { Tac t = tacCreate(TAC_CLAIM);
t->t1.sym = yyvsp[-4].symb; t->t1.sym = yyvsp[-4].symb;
t->t2.tac = yyvsp[-2].tac; t->t2.tac = yyvsp[-2].tac;
@ -916,7 +915,7 @@ case 23:
; ;
break;} break;}
case 24: case 24:
#line 178 "parser.y" #line 177 "parser.y"
{ Tac t = tacCreate(TAC_ROLEREF); { Tac t = tacCreate(TAC_ROLEREF);
t->t1.sym = yyvsp[-2].symb; t->t1.sym = yyvsp[-2].symb;
t->t2.sym = yyvsp[0].symb; t->t2.sym = yyvsp[0].symb;
@ -924,14 +923,14 @@ case 24:
; ;
break;} break;}
case 25: case 25:
#line 186 "parser.y" #line 185 "parser.y"
{ Tac t = tacCreate(TAC_KNOWS); { Tac t = tacCreate(TAC_KNOWS);
t->t1.tac = yyvsp[-1].tac; t->t1.tac = yyvsp[-1].tac;
yyval.tac = t; yyval.tac = t;
; ;
break;} break;}
case 26: case 26:
#line 193 "parser.y" #line 192 "parser.y"
{ Tac t = tacCreate(TAC_CONST); { Tac t = tacCreate(TAC_CONST);
t->t1.tac = yyvsp[-2].tac; t->t1.tac = yyvsp[-2].tac;
t->t2.tac = yyvsp[-1].tac; t->t2.tac = yyvsp[-1].tac;
@ -940,7 +939,7 @@ case 26:
; ;
break;} break;}
case 27: case 27:
#line 200 "parser.y" #line 199 "parser.y"
{ Tac t = tacCreate(TAC_VAR); { Tac t = tacCreate(TAC_VAR);
t->t1.tac = yyvsp[-2].tac; t->t1.tac = yyvsp[-2].tac;
t->t2.tac = yyvsp[-1].tac; t->t2.tac = yyvsp[-1].tac;
@ -949,7 +948,7 @@ case 27:
; ;
break;} break;}
case 28: case 28:
#line 207 "parser.y" #line 206 "parser.y"
{ Tac t = tacCreate(TAC_SECRET); { Tac t = tacCreate(TAC_SECRET);
t->t1.tac = yyvsp[-2].tac; t->t1.tac = yyvsp[-2].tac;
t->t2.tac = yyvsp[-1].tac; t->t2.tac = yyvsp[-1].tac;
@ -957,7 +956,7 @@ case 28:
; ;
break;} break;}
case 29: case 29:
#line 213 "parser.y" #line 212 "parser.y"
{ Tac t = tacCreate(TAC_INVERSEKEYS); { Tac t = tacCreate(TAC_INVERSEKEYS);
t->t1.tac = yyvsp[-4].tac; t->t1.tac = yyvsp[-4].tac;
t->t2.tac = yyvsp[-2].tac; t->t2.tac = yyvsp[-2].tac;
@ -965,66 +964,66 @@ case 29:
; ;
break;} break;}
case 30: case 30:
#line 219 "parser.y" #line 218 "parser.y"
{ Tac t = tacCreate(TAC_COMPROMISED); { Tac t = tacCreate(TAC_COMPROMISED);
t->t1.tac= yyvsp[-1].tac; t->t1.tac= yyvsp[-1].tac;
yyval.tac = t; yyval.tac = t;
; ;
break;} break;}
case 31: case 31:
#line 226 "parser.y" #line 225 "parser.y"
{ {
yyval.tac = NULL; yyval.tac = NULL;
; ;
break;} break;}
case 32: case 32:
#line 230 "parser.y" #line 229 "parser.y"
{ {
Tac t = tacCreate(TAC_SECRET); Tac t = tacCreate(TAC_SECRET);
yyval.tac = t; yyval.tac = t;
; ;
break;} break;}
case 33: case 33:
#line 237 "parser.y" #line 236 "parser.y"
{ {
Tac t = tacCreate(TAC_UNDEF); Tac t = tacCreate(TAC_UNDEF);
yyval.tac = t; yyval.tac = t;
; ;
break;} break;}
case 34: case 34:
#line 242 "parser.y" #line 241 "parser.y"
{ Tac t = tacCreate(TAC_STRING); { Tac t = tacCreate(TAC_STRING);
t->t1.sym = yyvsp[0].symb; t->t1.sym = yyvsp[0].symb;
yyval.tac = t; yyval.tac = t;
; ;
break;} break;}
case 35: case 35:
#line 249 "parser.y" #line 248 "parser.y"
{ {
Tac t = tacCreate(TAC_UNDEF); Tac t = tacCreate(TAC_UNDEF);
yyval.tac = t; yyval.tac = t;
; ;
break;} break;}
case 36: case 36:
#line 254 "parser.y" #line 253 "parser.y"
{ {
yyval.tac = yyvsp[0].tac; yyval.tac = yyvsp[0].tac;
; ;
break;} break;}
case 37: case 37:
#line 260 "parser.y" #line 259 "parser.y"
{ yyval.symb = yyvsp[0].symb; ; { yyval.symb = yyvsp[0].symb; ;
break;} break;}
case 38: case 38:
#line 264 "parser.y" #line 263 "parser.y"
{ yyval.symb = NULL; ; { yyval.symb = NULL; ;
break;} break;}
case 39: case 39:
#line 266 "parser.y" #line 265 "parser.y"
{ ; { ;
break;} break;}
case 40: case 40:
#line 271 "parser.y" #line 270 "parser.y"
{ {
Tac t = tacCreate(TAC_STRING); Tac t = tacCreate(TAC_STRING);
t->t1.sym = yyvsp[0].symb; t->t1.sym = yyvsp[0].symb;
@ -1032,11 +1031,11 @@ case 40:
; ;
break;} break;}
case 41: case 41:
#line 279 "parser.y" #line 278 "parser.y"
{ ; { ;
break;} break;}
case 42: case 42:
#line 281 "parser.y" #line 280 "parser.y"
{ {
Tac t = tacCreate(TAC_STRING); Tac t = tacCreate(TAC_STRING);
t->t1.sym = yyvsp[-3].symb; t->t1.sym = yyvsp[-3].symb;
@ -1044,35 +1043,35 @@ case 42:
; ;
break;} break;}
case 43: case 43:
#line 287 "parser.y" #line 286 "parser.y"
{ {
yyval.tac = tacJoin(TAC_ENCRYPT,tacTuple(yyvsp[-2].tac),yyvsp[0].tac,NULL); yyval.tac = tacJoin(TAC_ENCRYPT,tacTuple(yyvsp[-2].tac),yyvsp[0].tac,NULL);
; ;
break;} break;}
case 44: case 44:
#line 291 "parser.y" #line 290 "parser.y"
{ {
yyval.tac = tacTuple(yyvsp[-1].tac); yyval.tac = tacTuple(yyvsp[-1].tac);
; ;
break;} break;}
case 45: case 45:
#line 297 "parser.y" #line 296 "parser.y"
{ ; { ;
break;} break;}
case 46: case 46:
#line 299 "parser.y" #line 298 "parser.y"
{ yyval.tac = tacCat(yyvsp[-2].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-2].tac,yyvsp[0].tac); ;
break;} break;}
case 47: case 47:
#line 303 "parser.y" #line 302 "parser.y"
{ ; { ;
break;} break;}
case 48: case 48:
#line 305 "parser.y" #line 304 "parser.y"
{ yyval.tac = tacCat(yyvsp[-2].tac,yyvsp[0].tac); ; { yyval.tac = tacCat(yyvsp[-2].tac,yyvsp[0].tac); ;
break;} break;}
case 49: case 49:
#line 309 "parser.y" #line 308 "parser.y"
{ ; { ;
break;} break;}
} }
@ -1297,7 +1296,7 @@ yyerrhandle:
} }
return 1; return 1;
} }
#line 314 "parser.y" #line 313 "parser.y"
//! error handler routing //! error handler routing

View File

@ -1,105 +1,28 @@
/* A Bison parser, made by GNU Bison 2.3. */ typedef union{
/* Skeleton interface for Bison's Yacc-like parsers in C
Copyright (C) 1984, 1989, 1990, 2000, 2001, 2002, 2003, 2004, 2005, 2006
Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
/* As a special exception, you may create a larger work that contains
part or all of the Bison parser skeleton and distribute that work
under terms of your choice, so long as that work isn't itself a
parser generator using the skeleton or a modified version thereof
as a parser skeleton. Alternatively, if you modify or redistribute
the parser skeleton itself, you may (at your option) remove this
special exception, which will cause the skeleton and the resulting
Bison output files to be licensed under the GNU General Public
License without this special exception.
This special exception was added by the Free Software Foundation in
version 2.2 of Bison. */
/* Tokens. */
#ifndef YYTOKENTYPE
# define YYTOKENTYPE
/* Put the tokens into the symbol table, so that GDB and other debuggers
know about them. */
enum yytokentype {
ID = 258,
PROTOCOL = 259,
ROLE = 260,
READT = 261,
SENDT = 262,
CLAIMT = 263,
VAR = 264,
CONST = 265,
RUN = 266,
SECRET = 267,
COMPROMISED = 268,
INVERSEKEYS = 269,
UNTRUSTED = 270,
USERTYPE = 271,
SINGULAR = 272,
FUNCTION = 273,
HASHFUNCTION = 274,
KNOWS = 275,
TRUSTED = 276
};
#endif
/* Tokens. */
#define ID 258
#define PROTOCOL 259
#define ROLE 260
#define READT 261
#define SENDT 262
#define CLAIMT 263
#define VAR 264
#define CONST 265
#define RUN 266
#define SECRET 267
#define COMPROMISED 268
#define INVERSEKEYS 269
#define UNTRUSTED 270
#define USERTYPE 271
#define SINGULAR 272
#define FUNCTION 273
#define HASHFUNCTION 274
#define KNOWS 275
#define TRUSTED 276
#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
typedef union YYSTYPE
#line 14 "parser.y"
{
char* str; char* str;
struct tacnode* tac; struct tacnode* tac;
Symbol symb; Symbol symb;
int value; int value;
} } YYSTYPE;
/* Line 1529 of yacc.c. */ #define ID 257
#line 98 "parser.h" #define PROTOCOL 258
YYSTYPE; #define ROLE 259
# define yystype YYSTYPE /* obsolescent; will be withdrawn */ #define READT 260
# define YYSTYPE_IS_DECLARED 1 #define SENDT 261
# define YYSTYPE_IS_TRIVIAL 1 #define CLAIMT 262
#endif #define VAR 263
#define CONST 264
#define RUN 265
#define SECRET 266
#define COMPROMISED 267
#define INVERSEKEYS 268
#define UNTRUSTED 269
#define USERTYPE 270
#define SINGULAR 271
#define FUNCTION 272
#define HASHFUNCTION 273
#define KNOWS 274
#define TRUSTED 275
extern YYSTYPE yylval; extern YYSTYPE yylval;