7267
|
1 # -----------------------------------------------------------------------------
|
|
2 # cparse.py
|
|
3 #
|
|
4 # Simple parser for ANSI C. Based on the grammar in K&R, 2nd Ed.
|
|
5 # -----------------------------------------------------------------------------
|
|
6
|
|
7 import sys
|
|
8 import clex
|
|
9 import ply.yacc as yacc
|
|
10
|
|
11 # Get the token map
|
|
12 tokens = clex.tokens
|
|
13
|
|
14 # translation-unit:
|
|
15
|
|
16 def p_translation_unit_1(t):
|
|
17 'translation_unit : external_declaration'
|
|
18 pass
|
|
19
|
|
20 def p_translation_unit_2(t):
|
|
21 'translation_unit : translation_unit external_declaration'
|
|
22 pass
|
|
23
|
|
24 # external-declaration:
|
|
25
|
|
26 def p_external_declaration_1(t):
|
|
27 'external_declaration : function_definition'
|
|
28 pass
|
|
29
|
|
30 def p_external_declaration_2(t):
|
|
31 'external_declaration : declaration'
|
|
32 pass
|
|
33
|
|
34 # function-definition:
|
|
35
|
|
36 def p_function_definition_1(t):
|
|
37 'function_definition : declaration_specifiers declarator declaration_list compound_statement'
|
|
38 pass
|
|
39
|
|
40 def p_function_definition_2(t):
|
|
41 'function_definition : declarator declaration_list compound_statement'
|
|
42 pass
|
|
43
|
|
44 def p_function_definition_3(t):
|
|
45 'function_definition : declarator compound_statement'
|
|
46 pass
|
|
47
|
|
48 def p_function_definition_4(t):
|
|
49 'function_definition : declaration_specifiers declarator compound_statement'
|
|
50 pass
|
|
51
|
|
52 # declaration:
|
|
53
|
|
54 def p_declaration_1(t):
|
|
55 'declaration : declaration_specifiers init_declarator_list SEMI'
|
|
56 pass
|
|
57
|
|
58 def p_declaration_2(t):
|
|
59 'declaration : declaration_specifiers SEMI'
|
|
60 pass
|
|
61
|
|
62 # declaration-list:
|
|
63
|
|
64 def p_declaration_list_1(t):
|
|
65 'declaration_list : declaration'
|
|
66 pass
|
|
67
|
|
68 def p_declaration_list_2(t):
|
|
69 'declaration_list : declaration_list declaration '
|
|
70 pass
|
|
71
|
|
72 # declaration-specifiers
|
|
73 def p_declaration_specifiers_1(t):
|
|
74 'declaration_specifiers : storage_class_specifier declaration_specifiers'
|
|
75 pass
|
|
76
|
|
77 def p_declaration_specifiers_2(t):
|
|
78 'declaration_specifiers : type_specifier declaration_specifiers'
|
|
79 pass
|
|
80
|
|
81 def p_declaration_specifiers_3(t):
|
|
82 'declaration_specifiers : type_qualifier declaration_specifiers'
|
|
83 pass
|
|
84
|
|
85 def p_declaration_specifiers_4(t):
|
|
86 'declaration_specifiers : storage_class_specifier'
|
|
87 pass
|
|
88
|
|
89 def p_declaration_specifiers_5(t):
|
|
90 'declaration_specifiers : type_specifier'
|
|
91 pass
|
|
92
|
|
93 def p_declaration_specifiers_6(t):
|
|
94 'declaration_specifiers : type_qualifier'
|
|
95 pass
|
|
96
|
|
97 # storage-class-specifier
|
|
98 def p_storage_class_specifier(t):
|
|
99 '''storage_class_specifier : AUTO
|
|
100 | REGISTER
|
|
101 | STATIC
|
|
102 | EXTERN
|
|
103 | TYPEDEF
|
|
104 '''
|
|
105 pass
|
|
106
|
|
107 # type-specifier:
|
|
108 def p_type_specifier(t):
|
|
109 '''type_specifier : VOID
|
|
110 | CHAR
|
|
111 | SHORT
|
|
112 | INT
|
|
113 | LONG
|
|
114 | FLOAT
|
|
115 | DOUBLE
|
|
116 | SIGNED
|
|
117 | UNSIGNED
|
|
118 | struct_or_union_specifier
|
|
119 | enum_specifier
|
|
120 | TYPEID
|
|
121 '''
|
|
122 pass
|
|
123
|
|
124 # type-qualifier:
|
|
125 def p_type_qualifier(t):
|
|
126 '''type_qualifier : CONST
|
|
127 | VOLATILE'''
|
|
128 pass
|
|
129
|
|
130 # struct-or-union-specifier
|
|
131
|
|
132 def p_struct_or_union_specifier_1(t):
|
|
133 'struct_or_union_specifier : struct_or_union ID LBRACE struct_declaration_list RBRACE'
|
|
134 pass
|
|
135
|
|
136 def p_struct_or_union_specifier_2(t):
|
|
137 'struct_or_union_specifier : struct_or_union LBRACE struct_declaration_list RBRACE'
|
|
138 pass
|
|
139
|
|
140 def p_struct_or_union_specifier_3(t):
|
|
141 'struct_or_union_specifier : struct_or_union ID'
|
|
142 pass
|
|
143
|
|
144 # struct-or-union:
|
|
145 def p_struct_or_union(t):
|
|
146 '''struct_or_union : STRUCT
|
|
147 | UNION
|
|
148 '''
|
|
149 pass
|
|
150
|
|
151 # struct-declaration-list:
|
|
152
|
|
153 def p_struct_declaration_list_1(t):
|
|
154 'struct_declaration_list : struct_declaration'
|
|
155 pass
|
|
156
|
|
157 def p_struct_declaration_list_2(t):
|
|
158 'struct_declaration_list : struct_declaration_list struct_declaration'
|
|
159 pass
|
|
160
|
|
161 # init-declarator-list:
|
|
162
|
|
163 def p_init_declarator_list_1(t):
|
|
164 'init_declarator_list : init_declarator'
|
|
165 pass
|
|
166
|
|
167 def p_init_declarator_list_2(t):
|
|
168 'init_declarator_list : init_declarator_list COMMA init_declarator'
|
|
169 pass
|
|
170
|
|
171 # init-declarator
|
|
172
|
|
173 def p_init_declarator_1(t):
|
|
174 'init_declarator : declarator'
|
|
175 pass
|
|
176
|
|
177 def p_init_declarator_2(t):
|
|
178 'init_declarator : declarator EQUALS initializer'
|
|
179 pass
|
|
180
|
|
181 # struct-declaration:
|
|
182
|
|
183 def p_struct_declaration(t):
|
|
184 'struct_declaration : specifier_qualifier_list struct_declarator_list SEMI'
|
|
185 pass
|
|
186
|
|
187 # specifier-qualifier-list:
|
|
188
|
|
189 def p_specifier_qualifier_list_1(t):
|
|
190 'specifier_qualifier_list : type_specifier specifier_qualifier_list'
|
|
191 pass
|
|
192
|
|
193 def p_specifier_qualifier_list_2(t):
|
|
194 'specifier_qualifier_list : type_specifier'
|
|
195 pass
|
|
196
|
|
197 def p_specifier_qualifier_list_3(t):
|
|
198 'specifier_qualifier_list : type_qualifier specifier_qualifier_list'
|
|
199 pass
|
|
200
|
|
201 def p_specifier_qualifier_list_4(t):
|
|
202 'specifier_qualifier_list : type_qualifier'
|
|
203 pass
|
|
204
|
|
205 # struct-declarator-list:
|
|
206
|
|
207 def p_struct_declarator_list_1(t):
|
|
208 'struct_declarator_list : struct_declarator'
|
|
209 pass
|
|
210
|
|
211 def p_struct_declarator_list_2(t):
|
|
212 'struct_declarator_list : struct_declarator_list COMMA struct_declarator'
|
|
213 pass
|
|
214
|
|
215 # struct-declarator:
|
|
216
|
|
217 def p_struct_declarator_1(t):
|
|
218 'struct_declarator : declarator'
|
|
219 pass
|
|
220
|
|
221 def p_struct_declarator_2(t):
|
|
222 'struct_declarator : declarator COLON constant_expression'
|
|
223 pass
|
|
224
|
|
225 def p_struct_declarator_3(t):
|
|
226 'struct_declarator : COLON constant_expression'
|
|
227 pass
|
|
228
|
|
229 # enum-specifier:
|
|
230
|
|
231 def p_enum_specifier_1(t):
|
|
232 'enum_specifier : ENUM ID LBRACE enumerator_list RBRACE'
|
|
233 pass
|
|
234
|
|
235 def p_enum_specifier_2(t):
|
|
236 'enum_specifier : ENUM LBRACE enumerator_list RBRACE'
|
|
237 pass
|
|
238
|
|
239 def p_enum_specifier_3(t):
|
|
240 'enum_specifier : ENUM ID'
|
|
241 pass
|
|
242
|
|
243 # enumerator_list:
|
|
244 def p_enumerator_list_1(t):
|
|
245 'enumerator_list : enumerator'
|
|
246 pass
|
|
247
|
|
248 def p_enumerator_list_2(t):
|
|
249 'enumerator_list : enumerator_list COMMA enumerator'
|
|
250 pass
|
|
251
|
|
252 # enumerator:
|
|
253 def p_enumerator_1(t):
|
|
254 'enumerator : ID'
|
|
255 pass
|
|
256
|
|
257 def p_enumerator_2(t):
|
|
258 'enumerator : ID EQUALS constant_expression'
|
|
259 pass
|
|
260
|
|
261 # declarator:
|
|
262
|
|
263 def p_declarator_1(t):
|
|
264 'declarator : pointer direct_declarator'
|
|
265 pass
|
|
266
|
|
267 def p_declarator_2(t):
|
|
268 'declarator : direct_declarator'
|
|
269 pass
|
|
270
|
|
271 # direct-declarator:
|
|
272
|
|
273 def p_direct_declarator_1(t):
|
|
274 'direct_declarator : ID'
|
|
275 pass
|
|
276
|
|
277 def p_direct_declarator_2(t):
|
|
278 'direct_declarator : LPAREN declarator RPAREN'
|
|
279 pass
|
|
280
|
|
281 def p_direct_declarator_3(t):
|
|
282 'direct_declarator : direct_declarator LBRACKET constant_expression_opt RBRACKET'
|
|
283 pass
|
|
284
|
|
285 def p_direct_declarator_4(t):
|
|
286 'direct_declarator : direct_declarator LPAREN parameter_type_list RPAREN '
|
|
287 pass
|
|
288
|
|
289 def p_direct_declarator_5(t):
|
|
290 'direct_declarator : direct_declarator LPAREN identifier_list RPAREN '
|
|
291 pass
|
|
292
|
|
293 def p_direct_declarator_6(t):
|
|
294 'direct_declarator : direct_declarator LPAREN RPAREN '
|
|
295 pass
|
|
296
|
|
297 # pointer:
|
|
298 def p_pointer_1(t):
|
|
299 'pointer : TIMES type_qualifier_list'
|
|
300 pass
|
|
301
|
|
302 def p_pointer_2(t):
|
|
303 'pointer : TIMES'
|
|
304 pass
|
|
305
|
|
306 def p_pointer_3(t):
|
|
307 'pointer : TIMES type_qualifier_list pointer'
|
|
308 pass
|
|
309
|
|
310 def p_pointer_4(t):
|
|
311 'pointer : TIMES pointer'
|
|
312 pass
|
|
313
|
|
314 # type-qualifier-list:
|
|
315
|
|
316 def p_type_qualifier_list_1(t):
|
|
317 'type_qualifier_list : type_qualifier'
|
|
318 pass
|
|
319
|
|
320 def p_type_qualifier_list_2(t):
|
|
321 'type_qualifier_list : type_qualifier_list type_qualifier'
|
|
322 pass
|
|
323
|
|
324 # parameter-type-list:
|
|
325
|
|
326 def p_parameter_type_list_1(t):
|
|
327 'parameter_type_list : parameter_list'
|
|
328 pass
|
|
329
|
|
330 def p_parameter_type_list_2(t):
|
|
331 'parameter_type_list : parameter_list COMMA ELLIPSIS'
|
|
332 pass
|
|
333
|
|
334 # parameter-list:
|
|
335
|
|
336 def p_parameter_list_1(t):
|
|
337 'parameter_list : parameter_declaration'
|
|
338 pass
|
|
339
|
|
340 def p_parameter_list_2(t):
|
|
341 'parameter_list : parameter_list COMMA parameter_declaration'
|
|
342 pass
|
|
343
|
|
344 # parameter-declaration:
|
|
345 def p_parameter_declaration_1(t):
|
|
346 'parameter_declaration : declaration_specifiers declarator'
|
|
347 pass
|
|
348
|
|
349 def p_parameter_declaration_2(t):
|
|
350 'parameter_declaration : declaration_specifiers abstract_declarator_opt'
|
|
351 pass
|
|
352
|
|
353 # identifier-list:
|
|
354 def p_identifier_list_1(t):
|
|
355 'identifier_list : ID'
|
|
356 pass
|
|
357
|
|
358 def p_identifier_list_2(t):
|
|
359 'identifier_list : identifier_list COMMA ID'
|
|
360 pass
|
|
361
|
|
362 # initializer:
|
|
363
|
|
364 def p_initializer_1(t):
|
|
365 'initializer : assignment_expression'
|
|
366 pass
|
|
367
|
|
368 def p_initializer_2(t):
|
|
369 '''initializer : LBRACE initializer_list RBRACE
|
|
370 | LBRACE initializer_list COMMA RBRACE'''
|
|
371 pass
|
|
372
|
|
373 # initializer-list:
|
|
374
|
|
375 def p_initializer_list_1(t):
|
|
376 'initializer_list : initializer'
|
|
377 pass
|
|
378
|
|
379 def p_initializer_list_2(t):
|
|
380 'initializer_list : initializer_list COMMA initializer'
|
|
381 pass
|
|
382
|
|
383 # type-name:
|
|
384
|
|
385 def p_type_name(t):
|
|
386 'type_name : specifier_qualifier_list abstract_declarator_opt'
|
|
387 pass
|
|
388
|
|
389 def p_abstract_declarator_opt_1(t):
|
|
390 'abstract_declarator_opt : empty'
|
|
391 pass
|
|
392
|
|
393 def p_abstract_declarator_opt_2(t):
|
|
394 'abstract_declarator_opt : abstract_declarator'
|
|
395 pass
|
|
396
|
|
397 # abstract-declarator:
|
|
398
|
|
399 def p_abstract_declarator_1(t):
|
|
400 'abstract_declarator : pointer '
|
|
401 pass
|
|
402
|
|
403 def p_abstract_declarator_2(t):
|
|
404 'abstract_declarator : pointer direct_abstract_declarator'
|
|
405 pass
|
|
406
|
|
407 def p_abstract_declarator_3(t):
|
|
408 'abstract_declarator : direct_abstract_declarator'
|
|
409 pass
|
|
410
|
|
411 # direct-abstract-declarator:
|
|
412
|
|
413 def p_direct_abstract_declarator_1(t):
|
|
414 'direct_abstract_declarator : LPAREN abstract_declarator RPAREN'
|
|
415 pass
|
|
416
|
|
417 def p_direct_abstract_declarator_2(t):
|
|
418 'direct_abstract_declarator : direct_abstract_declarator LBRACKET constant_expression_opt RBRACKET'
|
|
419 pass
|
|
420
|
|
421 def p_direct_abstract_declarator_3(t):
|
|
422 'direct_abstract_declarator : LBRACKET constant_expression_opt RBRACKET'
|
|
423 pass
|
|
424
|
|
425 def p_direct_abstract_declarator_4(t):
|
|
426 'direct_abstract_declarator : direct_abstract_declarator LPAREN parameter_type_list_opt RPAREN'
|
|
427 pass
|
|
428
|
|
429 def p_direct_abstract_declarator_5(t):
|
|
430 'direct_abstract_declarator : LPAREN parameter_type_list_opt RPAREN'
|
|
431 pass
|
|
432
|
|
433 # Optional fields in abstract declarators
|
|
434
|
|
435 def p_constant_expression_opt_1(t):
|
|
436 'constant_expression_opt : empty'
|
|
437 pass
|
|
438
|
|
439 def p_constant_expression_opt_2(t):
|
|
440 'constant_expression_opt : constant_expression'
|
|
441 pass
|
|
442
|
|
443 def p_parameter_type_list_opt_1(t):
|
|
444 'parameter_type_list_opt : empty'
|
|
445 pass
|
|
446
|
|
447 def p_parameter_type_list_opt_2(t):
|
|
448 'parameter_type_list_opt : parameter_type_list'
|
|
449 pass
|
|
450
|
|
451 # statement:
|
|
452
|
|
453 def p_statement(t):
|
|
454 '''
|
|
455 statement : labeled_statement
|
|
456 | expression_statement
|
|
457 | compound_statement
|
|
458 | selection_statement
|
|
459 | iteration_statement
|
|
460 | jump_statement
|
|
461 '''
|
|
462 pass
|
|
463
|
|
464 # labeled-statement:
|
|
465
|
|
466 def p_labeled_statement_1(t):
|
|
467 'labeled_statement : ID COLON statement'
|
|
468 pass
|
|
469
|
|
470 def p_labeled_statement_2(t):
|
|
471 'labeled_statement : CASE constant_expression COLON statement'
|
|
472 pass
|
|
473
|
|
474 def p_labeled_statement_3(t):
|
|
475 'labeled_statement : DEFAULT COLON statement'
|
|
476 pass
|
|
477
|
|
478 # expression-statement:
|
|
479 def p_expression_statement(t):
|
|
480 'expression_statement : expression_opt SEMI'
|
|
481 pass
|
|
482
|
|
483 # compound-statement:
|
|
484
|
|
485 def p_compound_statement_1(t):
|
|
486 'compound_statement : LBRACE declaration_list statement_list RBRACE'
|
|
487 pass
|
|
488
|
|
489 def p_compound_statement_2(t):
|
|
490 'compound_statement : LBRACE statement_list RBRACE'
|
|
491 pass
|
|
492
|
|
493 def p_compound_statement_3(t):
|
|
494 'compound_statement : LBRACE declaration_list RBRACE'
|
|
495 pass
|
|
496
|
|
497 def p_compound_statement_4(t):
|
|
498 'compound_statement : LBRACE RBRACE'
|
|
499 pass
|
|
500
|
|
501 # statement-list:
|
|
502
|
|
503 def p_statement_list_1(t):
|
|
504 'statement_list : statement'
|
|
505 pass
|
|
506
|
|
507 def p_statement_list_2(t):
|
|
508 'statement_list : statement_list statement'
|
|
509 pass
|
|
510
|
|
511 # selection-statement
|
|
512
|
|
513 def p_selection_statement_1(t):
|
|
514 'selection_statement : IF LPAREN expression RPAREN statement'
|
|
515 pass
|
|
516
|
|
517 def p_selection_statement_2(t):
|
|
518 'selection_statement : IF LPAREN expression RPAREN statement ELSE statement '
|
|
519 pass
|
|
520
|
|
521 def p_selection_statement_3(t):
|
|
522 'selection_statement : SWITCH LPAREN expression RPAREN statement '
|
|
523 pass
|
|
524
|
|
525 # iteration_statement:
|
|
526
|
|
527 def p_iteration_statement_1(t):
|
|
528 'iteration_statement : WHILE LPAREN expression RPAREN statement'
|
|
529 pass
|
|
530
|
|
531 def p_iteration_statement_2(t):
|
|
532 'iteration_statement : FOR LPAREN expression_opt SEMI expression_opt SEMI expression_opt RPAREN statement '
|
|
533 pass
|
|
534
|
|
535 def p_iteration_statement_3(t):
|
|
536 'iteration_statement : DO statement WHILE LPAREN expression RPAREN SEMI'
|
|
537 pass
|
|
538
|
|
539 # jump_statement:
|
|
540
|
|
541 def p_jump_statement_1(t):
|
|
542 'jump_statement : GOTO ID SEMI'
|
|
543 pass
|
|
544
|
|
545 def p_jump_statement_2(t):
|
|
546 'jump_statement : CONTINUE SEMI'
|
|
547 pass
|
|
548
|
|
549 def p_jump_statement_3(t):
|
|
550 'jump_statement : BREAK SEMI'
|
|
551 pass
|
|
552
|
|
553 def p_jump_statement_4(t):
|
|
554 'jump_statement : RETURN expression_opt SEMI'
|
|
555 pass
|
|
556
|
|
557 def p_expression_opt_1(t):
|
|
558 'expression_opt : empty'
|
|
559 pass
|
|
560
|
|
561 def p_expression_opt_2(t):
|
|
562 'expression_opt : expression'
|
|
563 pass
|
|
564
|
|
565 # expression:
|
|
566 def p_expression_1(t):
|
|
567 'expression : assignment_expression'
|
|
568 pass
|
|
569
|
|
570 def p_expression_2(t):
|
|
571 'expression : expression COMMA assignment_expression'
|
|
572 pass
|
|
573
|
|
574 # assigment_expression:
|
|
575 def p_assignment_expression_1(t):
|
|
576 'assignment_expression : conditional_expression'
|
|
577 pass
|
|
578
|
|
579 def p_assignment_expression_2(t):
|
|
580 'assignment_expression : unary_expression assignment_operator assignment_expression'
|
|
581 pass
|
|
582
|
|
583 # assignment_operator:
|
|
584 def p_assignment_operator(t):
|
|
585 '''
|
|
586 assignment_operator : EQUALS
|
|
587 | TIMESEQUAL
|
|
588 | DIVEQUAL
|
|
589 | MODEQUAL
|
|
590 | PLUSEQUAL
|
|
591 | MINUSEQUAL
|
|
592 | LSHIFTEQUAL
|
|
593 | RSHIFTEQUAL
|
|
594 | ANDEQUAL
|
|
595 | OREQUAL
|
|
596 | XOREQUAL
|
|
597 '''
|
|
598 pass
|
|
599
|
|
600 # conditional-expression
|
|
601 def p_conditional_expression_1(t):
|
|
602 'conditional_expression : logical_or_expression'
|
|
603 pass
|
|
604
|
|
605 def p_conditional_expression_2(t):
|
|
606 'conditional_expression : logical_or_expression CONDOP expression COLON conditional_expression '
|
|
607 pass
|
|
608
|
|
609 # constant-expression
|
|
610
|
|
611 def p_constant_expression(t):
|
|
612 'constant_expression : conditional_expression'
|
|
613 pass
|
|
614
|
|
615 # logical-or-expression
|
|
616
|
|
617 def p_logical_or_expression_1(t):
|
|
618 'logical_or_expression : logical_and_expression'
|
|
619 pass
|
|
620
|
|
621 def p_logical_or_expression_2(t):
|
|
622 'logical_or_expression : logical_or_expression LOR logical_and_expression'
|
|
623 pass
|
|
624
|
|
625 # logical-and-expression
|
|
626
|
|
627 def p_logical_and_expression_1(t):
|
|
628 'logical_and_expression : inclusive_or_expression'
|
|
629 pass
|
|
630
|
|
631 def p_logical_and_expression_2(t):
|
|
632 'logical_and_expression : logical_and_expression LAND inclusive_or_expression'
|
|
633 pass
|
|
634
|
|
635 # inclusive-or-expression:
|
|
636
|
|
637 def p_inclusive_or_expression_1(t):
|
|
638 'inclusive_or_expression : exclusive_or_expression'
|
|
639 pass
|
|
640
|
|
641 def p_inclusive_or_expression_2(t):
|
|
642 'inclusive_or_expression : inclusive_or_expression OR exclusive_or_expression'
|
|
643 pass
|
|
644
|
|
645 # exclusive-or-expression:
|
|
646
|
|
647 def p_exclusive_or_expression_1(t):
|
|
648 'exclusive_or_expression : and_expression'
|
|
649 pass
|
|
650
|
|
651 def p_exclusive_or_expression_2(t):
|
|
652 'exclusive_or_expression : exclusive_or_expression XOR and_expression'
|
|
653 pass
|
|
654
|
|
655 # AND-expression
|
|
656
|
|
657 def p_and_expression_1(t):
|
|
658 'and_expression : equality_expression'
|
|
659 pass
|
|
660
|
|
661 def p_and_expression_2(t):
|
|
662 'and_expression : and_expression AND equality_expression'
|
|
663 pass
|
|
664
|
|
665
|
|
666 # equality-expression:
|
|
667 def p_equality_expression_1(t):
|
|
668 'equality_expression : relational_expression'
|
|
669 pass
|
|
670
|
|
671 def p_equality_expression_2(t):
|
|
672 'equality_expression : equality_expression EQ relational_expression'
|
|
673 pass
|
|
674
|
|
675 def p_equality_expression_3(t):
|
|
676 'equality_expression : equality_expression NE relational_expression'
|
|
677 pass
|
|
678
|
|
679
|
|
680 # relational-expression:
|
|
681 def p_relational_expression_1(t):
|
|
682 'relational_expression : shift_expression'
|
|
683 pass
|
|
684
|
|
685 def p_relational_expression_2(t):
|
|
686 'relational_expression : relational_expression LT shift_expression'
|
|
687 pass
|
|
688
|
|
689 def p_relational_expression_3(t):
|
|
690 'relational_expression : relational_expression GT shift_expression'
|
|
691 pass
|
|
692
|
|
693 def p_relational_expression_4(t):
|
|
694 'relational_expression : relational_expression LE shift_expression'
|
|
695 pass
|
|
696
|
|
697 def p_relational_expression_5(t):
|
|
698 'relational_expression : relational_expression GE shift_expression'
|
|
699 pass
|
|
700
|
|
701 # shift-expression
|
|
702
|
|
703 def p_shift_expression_1(t):
|
|
704 'shift_expression : additive_expression'
|
|
705 pass
|
|
706
|
|
707 def p_shift_expression_2(t):
|
|
708 'shift_expression : shift_expression LSHIFT additive_expression'
|
|
709 pass
|
|
710
|
|
711 def p_shift_expression_3(t):
|
|
712 'shift_expression : shift_expression RSHIFT additive_expression'
|
|
713 pass
|
|
714
|
|
715 # additive-expression
|
|
716
|
|
717 def p_additive_expression_1(t):
|
|
718 'additive_expression : multiplicative_expression'
|
|
719 pass
|
|
720
|
|
721 def p_additive_expression_2(t):
|
|
722 'additive_expression : additive_expression PLUS multiplicative_expression'
|
|
723 pass
|
|
724
|
|
725 def p_additive_expression_3(t):
|
|
726 'additive_expression : additive_expression MINUS multiplicative_expression'
|
|
727 pass
|
|
728
|
|
729 # multiplicative-expression
|
|
730
|
|
731 def p_multiplicative_expression_1(t):
|
|
732 'multiplicative_expression : cast_expression'
|
|
733 pass
|
|
734
|
|
735 def p_multiplicative_expression_2(t):
|
|
736 'multiplicative_expression : multiplicative_expression TIMES cast_expression'
|
|
737 pass
|
|
738
|
|
739 def p_multiplicative_expression_3(t):
|
|
740 'multiplicative_expression : multiplicative_expression DIVIDE cast_expression'
|
|
741 pass
|
|
742
|
|
743 def p_multiplicative_expression_4(t):
|
|
744 'multiplicative_expression : multiplicative_expression MOD cast_expression'
|
|
745 pass
|
|
746
|
|
747 # cast-expression:
|
|
748
|
|
749 def p_cast_expression_1(t):
|
|
750 'cast_expression : unary_expression'
|
|
751 pass
|
|
752
|
|
753 def p_cast_expression_2(t):
|
|
754 'cast_expression : LPAREN type_name RPAREN cast_expression'
|
|
755 pass
|
|
756
|
|
757 # unary-expression:
|
|
758 def p_unary_expression_1(t):
|
|
759 'unary_expression : postfix_expression'
|
|
760 pass
|
|
761
|
|
762 def p_unary_expression_2(t):
|
|
763 'unary_expression : PLUSPLUS unary_expression'
|
|
764 pass
|
|
765
|
|
766 def p_unary_expression_3(t):
|
|
767 'unary_expression : MINUSMINUS unary_expression'
|
|
768 pass
|
|
769
|
|
770 def p_unary_expression_4(t):
|
|
771 'unary_expression : unary_operator cast_expression'
|
|
772 pass
|
|
773
|
|
774 def p_unary_expression_5(t):
|
|
775 'unary_expression : SIZEOF unary_expression'
|
|
776 pass
|
|
777
|
|
778 def p_unary_expression_6(t):
|
|
779 'unary_expression : SIZEOF LPAREN type_name RPAREN'
|
|
780 pass
|
|
781
|
|
782 #unary-operator
|
|
783 def p_unary_operator(t):
|
|
784 '''unary_operator : AND
|
|
785 | TIMES
|
|
786 | PLUS
|
|
787 | MINUS
|
|
788 | NOT
|
|
789 | LNOT '''
|
|
790 pass
|
|
791
|
|
792 # postfix-expression:
|
|
793 def p_postfix_expression_1(t):
|
|
794 'postfix_expression : primary_expression'
|
|
795 pass
|
|
796
|
|
797 def p_postfix_expression_2(t):
|
|
798 'postfix_expression : postfix_expression LBRACKET expression RBRACKET'
|
|
799 pass
|
|
800
|
|
801 def p_postfix_expression_3(t):
|
|
802 'postfix_expression : postfix_expression LPAREN argument_expression_list RPAREN'
|
|
803 pass
|
|
804
|
|
805 def p_postfix_expression_4(t):
|
|
806 'postfix_expression : postfix_expression LPAREN RPAREN'
|
|
807 pass
|
|
808
|
|
809 def p_postfix_expression_5(t):
|
|
810 'postfix_expression : postfix_expression PERIOD ID'
|
|
811 pass
|
|
812
|
|
813 def p_postfix_expression_6(t):
|
|
814 'postfix_expression : postfix_expression ARROW ID'
|
|
815 pass
|
|
816
|
|
817 def p_postfix_expression_7(t):
|
|
818 'postfix_expression : postfix_expression PLUSPLUS'
|
|
819 pass
|
|
820
|
|
821 def p_postfix_expression_8(t):
|
|
822 'postfix_expression : postfix_expression MINUSMINUS'
|
|
823 pass
|
|
824
|
|
825 # primary-expression:
|
|
826 def p_primary_expression(t):
|
|
827 '''primary_expression : ID
|
|
828 | constant
|
|
829 | SCONST
|
|
830 | LPAREN expression RPAREN'''
|
|
831 pass
|
|
832
|
|
833 # argument-expression-list:
|
|
834 def p_argument_expression_list(t):
|
|
835 '''argument_expression_list : assignment_expression
|
|
836 | argument_expression_list COMMA assignment_expression'''
|
|
837 pass
|
|
838
|
|
839 # constant:
|
|
840 def p_constant(t):
|
|
841 '''constant : ICONST
|
|
842 | FCONST
|
|
843 | CCONST'''
|
|
844 pass
|
|
845
|
|
846
|
|
847 def p_empty(t):
|
|
848 'empty : '
|
|
849 pass
|
|
850
|
|
851 def p_error(t):
|
|
852 print("Whoa. We're hosed")
|
|
853
|
|
854 import profile
|
|
855 # Build the grammar
|
|
856
|
|
857 yacc.yacc()
|
|
858 #yacc.yacc(method='LALR',write_tables=False,debug=True)
|
|
859
|
|
860 #profile.run("yacc.yacc(method='LALR')")
|
|
861
|
|
862
|
|
863
|
|
864
|