source: libabac/rt2.l @ 7b548fa

mei_rt2mei_rt2_fix_1meiyap-rt1rt2
Last change on this file since 7b548fa was d5bbd3e, checked in by Mei <mei@…>, 12 years ago

1) add alumni2_rt1_typed

(target static range constraint)

2) add another rule for fruits example
3) add target static range constraint handling for string & urn

  • Property mode set to 100644
File size: 7.9 KB
Line 
1%option stack
2%x BOOLEAN_S
3%x INTEGER_S
4%x FLOAT_S
5%x TIME_S
6%x URN_S
7%x STRING_S
8%x KEYID_S
9%x RANGE_S
10
11%top{
12#include <stdio.h>
13#include <string.h>
14#include "rt2.h"
15
16static int debug=0;
17
18/* if using canned fixed test string */
19char INPUT_LINE[] = "usc.playground <- usc.employee.friend";
20char *yyfptr = INPUT_LINE; /* assigned with default */
21char *yyfptr_encoded=NULL;
22
23/* with yacc */
24extern YYSTYPE yylval;
25extern char* abac_encode_string(char *);
26
27#undef YY_INPUT
28#define YY_INPUT(buf,result,max_size) \
29    { \
30    if(yyfptr != NULL) { \
31      char* c = strncpy(buf,yyfptr,max_size); \
32      if (max_size > 0) buf[max_size-1] = '\0'; \
33      if(strlen(yyfptr) > max_size) yyfptr = yyfptr + max_size-1;  \
34        else yyfptr=NULL; \
35      result = (c == NULL ) ? YY_NULL : strlen(buf); \
36      } else { \
37         buf[0] = '\0'; \
38         result = YY_NULL; \
39    } \
40    }
41
42}
43
44DIGIT    [0-9]
45%%
46\.           { if(debug) fprintf(yyout, " DOT " );
47             return DOT; }
48keyid        { yylval.string=strdup(yytext);
49             if(debug) fprintf(yyout," KEYTYPE ");
50             return KEYTYPE; }
51<KEYID_S>[a-zA-Z0-9]+ {
52             yylval.string=strdup(yytext);
53             if(debug) fprintf(yyout," KEYID_CONSTANT ");
54             return KEYID_CONSTANT; }
55oset         { if(debug) fprintf(yyout," OSET ");
56             return OSET; }
57role         { if(debug) fprintf(yyout," ROLE ");
58             return ROLE; }
59principal    { if(debug) fprintf(yyout," PRINCIPAL ");
60             return PRINCIPAL; }
61integer      { yylval.string=strdup(yytext);
62             if(debug) fprintf(yyout," OTYPE(INTEGER) ");
63             return OTYPE; }
64<INTEGER_S>{DIGIT}+ {
65             yylval.string=strdup(yytext);
66             if(debug) fprintf(yyout," OTYPE_CONSTANT(INTEGER) ");
67             return OTYPE_CONSTANT; }
68<INTEGER_S>[-]{DIGIT}+ {
69             yylval.string=strdup(yytext);
70             if(debug) fprintf(yyout," OTYPE_CONSTANT(INTEGER) ");
71             return OTYPE_CONSTANT; }
72boolean      { yylval.string =strdup(yytext);
73             if(debug) fprintf(yyout," OTYPE(BOOLEAN) ");
74             return OTYPE; }
75<BOOLEAN_S>true|false {
76             yylval.string=strdup(yytext);
77             if(debug) fprintf(yyout," OTYPE_CONSTANT(BOOLEAN) ");
78             return OTYPE_CONSTANT; }
79<BOOLEAN_S,INTEGER_S,FLOAT_S,URN_S,STRING_S,TIME_S>[?][A-Z][_a-zA-Z0-9]* {
80             yylval.string=strdup(yytext+1);
81             if(debug) fprintf(yyout," VARIABLE_CONSTANT(%s) ",yylval.string);
82             return VARIABLE_CONSTANT; }
83<BOOLEAN_S,INTEGER_S,FLOAT_S,URN_S,STRING_S,TIME_S>\[ {
84             if(debug) fprintf(yyout," LSQUARE ");
85             return LSQUARE; }
86<BOOLEAN_S,INTEGER_S,FLOAT_S,URN_S,STRING_S,TIME_S>\] {
87             if(debug) fprintf(yyout," RSQUARE ");
88             return RSQUARE; }
89<BOOLEAN_S,INTEGER_S,FLOAT_S,URN_S,STRING_S,TIME_S>\: {
90             if(debug) fprintf(yyout," COLON ");
91             return COLON; }
92float        { yylval.string =strdup(yytext);
93             if(debug) fprintf(yyout," OTYPE(FLOAT) ");
94             return OTYPE; }
95<FLOAT_S>-{DIGIT}+"."{DIGIT}+ |
96<FLOAT_S>{DIGIT}+"."{DIGIT}+ |
97<FLOAT_S>{DIGIT}+ |
98<FLOAT_S>-{DIGIT}+ {
99             yylval.string=strdup(yytext);
100             if(debug) fprintf(yyout," OTYPE_CONSTANT(FLOAT) ");
101             return OTYPE_CONSTANT; }
102time         { yylval.string=strdup(yytext);
103             if(debug) fprintf(yyout," OTYPE(TIME) ");
104             return OTYPE; }
105<TIME_S>{DIGIT}{DIGIT}*"T"{DIGIT}* {
106             yylval.string=strdup(yytext);
107             if(debug) fprintf(yyout," OTYPE_CONSTANT(TIME) ");
108             return OTYPE_CONSTANT; }
109urn          { yylval.string=strdup(yytext);
110             if(debug) fprintf(yyout," OTYPE(URN) ");
111             return OTYPE; }
112<URN_S>[']([^']|\\')*['] |
113<URN_S>["]([^"]|\")*["] {
114             yylval.string=strdup(yytext);
115             if(debug) fprintf(yyout," OTYPE_CONSTANT(URN)(%s) ",yylval.string);
116             return OTYPE_CONSTANT; }
117string       { yylval.string=strdup(yytext);
118             if(debug) fprintf(yyout," OTYPE(STRING) ");
119             return OTYPE; }
120<STRING_S>[']([^']|\\')*['] |
121<STRING_S>["]([^"]|\")*["] {
122             yylval.string=strdup(yytext);
123             if(debug) fprintf(yyout," OTYPE_CONSTANT(STRING)(%s) ", yylval.string);
124             return OTYPE_CONSTANT; }
125<RANGE_S>\[ {
126             if(debug) fprintf(yyout," LSQUARE ");
127             return LSQUARE; }
128<RANGE_S>\] {
129             if(debug) fprintf(yyout," RSQUARE ");
130             return RSQUARE; }
131<RANGE_S>\.\. {
132             if(debug) fprintf(yyout," DOTDOT ");
133             return DOTDOT; }
134<RANGE_S>, {
135             if(debug) fprintf(yyout," COMMA ");
136             return COMMA; }
137<RANGE_S>[']([^']|\\')*['] |
138<RANGE_S>["]([^"]|\")*["] {
139             yylval.string=strdup(yytext);
140             if(debug) fprintf(yyout," VALUE(STRING)(%s) ", yylval.string);
141             return VALUE; }
142<RANGE_S>{DIGIT}+ |
143<RANGE_S>-{DIGIT}+ |
144<RANGE_S>-{DIGIT}.{DIGIT}+ |
145<RANGE_S>{DIGIT}.{DIGIT}+ |
146<RANGE_S>{DIGIT}+T{DIGIT}+ {
147             yylval.string=strdup(yytext);
148             if(debug) fprintf(yyout," VALUE(%s) ",yylval.string);
149             return VALUE; }
150[a-zA-Z0-9][_a-zA-Z0-9]* {
151             yylval.string=strdup(yytext);
152             if(debug) fprintf(yyout," IDEN(%s) ", yylval.string);
153             return IDEN; }
154\<-          { if(debug) fprintf(yyout," DERIVE ");
155             return DERIVE; }
156&            { if(debug) fprintf(yyout, " AND " );
157             return AND; }
158,            { if(debug) fprintf(yyout, " COMMA ");
159             return COMMA; }
160\(           { if(debug) fprintf(yyout, " LPAREN ");
161             return LPAREN; }
162\)           { if(debug) fprintf(yyout, " RPAREN ");
163             return RPAREN; }
164\[           { if(debug) fprintf(yyout, " LSQUARE ");
165             return LSQUARE; }
166\]           { if(debug) fprintf(yyout, " RSQUARE ");
167             return RSQUARE; }
168\:           { if(debug) fprintf(yyout, " COLON ");
169             return COLON; }
170\?           { if(debug) fprintf(yyout, " QMARK ");
171             return QMARK; }
172\n           { /* ignore end-of-line */; }
173[ \t]+       { /* ignore whitespace */; }
174%%
175
176void abac_reset_yyfptr(char *str) {
177    yyfptr=str;
178    yyfptr_encoded=abac_encode_string(str);
179}
180
181char* abac_get_yyfptr() {
182    return yyfptr;
183}
184
185char *abac_get_yyfptr_encoded() {
186    return yyfptr_encoded;
187}
188
189/* if using external file input, output */
190void abac_reset_yyin(FILE *new_yyin) {
191    yyin=new_yyin;
192}
193
194void abac_reset_yyout(FILE *new_yyout) {
195    if(yyout) {
196      fflush(yyout);
197      fclose(yyout);
198    }
199    yyout=new_yyout;
200}
201
202void abac_flush_yyout() {
203    if(yyout)
204      fflush(yyout);
205}
206
207FILE *abac_get_yyin() {
208    if(yyin) return yyin;
209    else return stdin;
210}
211FILE *abac_get_yyout() {
212    if(yyout) return yyout;
213    else return stdout;
214}
215
216void abac_push_keyid_yystate()
217{
218    if(debug) fprintf(yyout, "\n push keyid state\n");
219    yy_push_state(KEYID_S);
220}
221
222void abac_push_range_yystate()
223{
224    if(debug) fprintf(yyout, "\n push range state\n");
225    yy_push_state(RANGE_S);
226}
227
228void abac_push_yystate(char *str)
229{
230   if(strcmp(str,"boolean")==0) {
231      if(debug) fprintf(yyout, "\n push boolean state\n");
232      yy_push_state(BOOLEAN_S);
233      return;
234   }
235   if(strcmp(str,"integer")==0) {
236      if(debug) fprintf(yyout, "\n push integer state\n");
237      yy_push_state(INTEGER_S);
238      return;
239   }
240   if(strcmp(str,"float")==0) {
241      if(debug) fprintf(yyout, "\n push float state\n");
242      yy_push_state(FLOAT_S);
243      return;
244   }
245   if(strcmp(str,"time")==0) {
246      if(debug) fprintf(yyout, "\n push time state\n");
247      yy_push_state(TIME_S);
248      return;
249   }
250   if(strcmp(str,"urn")==0) {
251      if(debug) fprintf(yyout, "\n push urn state\n");
252      yy_push_state(URN_S);
253      return;
254   }
255   if(strcmp(str,"string")==0) {
256      if(debug) fprintf(yyout, "\n push string state\n");
257      yy_push_state(STRING_S);
258      return;
259   }
260   
261   if(debug) fprintf(yyout, "eek.. lost in push_state\n");
262}
263
264void abac_pop_yystate()
265{
266   if(debug) fprintf(yyout, " pop a state\n");
267   yy_pop_state();
268}
Note: See TracBrowser for help on using the repository browser.