]> git.saurik.com Git - bison.git/blame - tests/conflicts.at
(MUSCLE_TAB_H_): Was misspelled as MUSCLE_TAB_H_.
[bison.git] / tests / conflicts.at
CommitLineData
3c31a486 1# Exercising Bison on conflicts. -*- Autotest -*-
643a5994 2# Copyright (C) 2002 Free Software Foundation, Inc.
3c31a486
AD
3
4# This program is free software; you can redistribute it and/or modify
5# it under the terms of the GNU General Public License as published by
6# the Free Software Foundation; either version 2, or (at your option)
7# any later version.
8
9# This program is distributed in the hope that it will be useful,
10# but WITHOUT ANY WARRANTY; without even the implied warranty of
11# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12# GNU General Public License for more details.
13
14# You should have received a copy of the GNU General Public License
15# along with this program; if not, write to the Free Software
16# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
17# 02111-1307, USA.
18
19AT_BANNER([[Conflicts.]])
20
21
643a5994
AD
22## ---------------- ##
23## S/R in initial. ##
24## ---------------- ##
25
26# I once hacked Bison in such a way that it lost its reductions on the
27# initial state (because it was confusing it with the last state). It
28# took me a while to strip down my failures to this simple case. So
29# make sure it finds the s/r conflict below.
30
31AT_SETUP([S/R in initial])
32
33AT_DATA([[input.y]],
34[[%expect 1
35%%
36exp: e 'e';
37e: 'e' | /* Nothing. */;
38]])
39
b56471a6 40AT_CHECK([bison -o input.c input.y], 0, [],
e8832397
AD
41[[input.y:4.8: warning: rule never reduced because of conflicts: e: /* empty */
42]])
643a5994
AD
43
44AT_CLEANUP
45
bc933ef1 46
3c31a486
AD
47## ------------------- ##
48## %nonassoc and eof. ##
49## ------------------- ##
50
51AT_SETUP([%nonassoc and eof])
52
53AT_DATA([input.y],
54[[
55%{
1207eeac
AD
56#include <config.h>
57/* We don't need a perfect malloc for these tests. */
58#undef malloc
3c31a486 59#include <stdio.h>
1207eeac
AD
60
61#if STDC_HEADERS
62# include <stdlib.h>
63#endif
64
3c31a486 65#define YYERROR_VERBOSE 1
1207eeac
AD
66static void
67yyerror (const char *msg)
68{
69 fprintf (stderr, "%s\n", msg);
70 exit (1);
71}
3c31a486
AD
72
73/* The current argument. */
74static const char *input = NULL;
75
76static int
77yylex (void)
78{
79 /* No token stands for end of file. */
80 if (input && *input)
81 return *input++;
82 else
83 return 0;
84}
85
86%}
87
88%nonassoc '<' '>'
89
90%%
91expr: expr '<' expr
92 | expr '>' expr
93 | '0'
94 ;
95%%
96int
97main (int argc, const char *argv[])
98{
99 if (argc > 1)
100 input = argv[1];
101 return yyparse ();
102}
103]])
104
105# Specify the output files to avoid problems on different file systems.
b56471a6 106AT_CHECK([bison -o input.c input.y])
1154cced 107AT_COMPILE([input])
3c31a486 108
1154cced 109AT_PARSER_CHECK([./input '0<0'])
3c31a486
AD
110# FIXME: This is an actual bug, but a new one, in the sense that
111# no one has ever spotted it! The messages are *wrong*: there should
112# be nothing there, it should be expected eof.
1154cced 113AT_PARSER_CHECK([./input '0<0<0'], [1], [],
3c31a486
AD
114 [parse error, unexpected '<', expecting '<' or '>'
115])
116
1154cced
AD
117AT_PARSER_CHECK([./input '0>0'])
118AT_PARSER_CHECK([./input '0>0>0'], [1], [],
3c31a486
AD
119 [parse error, unexpected '>', expecting '<' or '>'
120])
121
1154cced 122AT_PARSER_CHECK([./input '0<0>0'], [1], [],
3c31a486
AD
123 [parse error, unexpected '>', expecting '<' or '>'
124])
125
126AT_CLEANUP
127
128
129
130## ------------------------- ##
131## Unresolved SR Conflicts. ##
132## ------------------------- ##
133
134AT_SETUP([Unresolved SR Conflicts])
135
6b98e4b5
AD
136AT_KEYWORDS([report])
137
3c31a486
AD
138AT_DATA([input.y],
139[[%token NUM OP
140%%
141exp: exp OP exp | NUM;
142]])
143
b56471a6 144AT_CHECK([bison -o input.c --report=all input.y], 0, [],
52489d44 145[input.y: warning: 1 shift/reduce conflict
3c31a486
AD
146])
147
148# Check the contents of the report.
149AT_CHECK([cat input.output], [],
150[[State 5 contains 1 shift/reduce conflict.
151
152
153Grammar
154
88bce5a2 155 0 $accept: exp $end
6b98e4b5
AD
156
157 1 exp: exp OP exp
158 2 | NUM
3c31a486
AD
159
160
161Terminals, with rules where they appear
162
88bce5a2 163$end (0) 0
3c31a486 164error (256)
007a50a4
AD
165NUM (258) 2
166OP (259) 1
3c31a486
AD
167
168
169Nonterminals, with rules where they appear
170
88bce5a2 171$accept (5)
3c31a486
AD
172 on left: 0
173exp (6)
174 on left: 1 2, on right: 0 1
175
176
177state 0
178
88bce5a2 179 0 $accept: . exp $end
ce4ccb4b
AD
180 1 exp: . exp OP exp
181 2 | . NUM
643a5994 182
87675353 183 NUM shift, and go to state 1
3c31a486 184
87675353 185 exp go to state 2
3c31a486
AD
186
187
188state 1
189
ce4ccb4b 190 2 exp: NUM .
3c31a486 191
87675353 192 $default reduce using rule 2 (exp)
3c31a486
AD
193
194
195state 2
196
88bce5a2 197 0 $accept: exp . $end
ce4ccb4b 198 1 exp: exp . OP exp
3c31a486 199
88bce5a2
AD
200 $end shift, and go to state 3
201 OP shift, and go to state 4
3c31a486
AD
202
203
204state 3
205
88bce5a2 206 0 $accept: exp $end .
3c31a486 207
e8832397 208 $default accept
3c31a486
AD
209
210
211state 4
212
ce4ccb4b
AD
213 1 exp: . exp OP exp
214 1 | exp OP . exp
215 2 | . NUM
3c31a486 216
87675353 217 NUM shift, and go to state 1
3c31a486 218
87675353 219 exp go to state 5
3c31a486
AD
220
221
222state 5
223
88bce5a2
AD
224 1 exp: exp . OP exp [$end, OP]
225 1 | exp OP exp . [$end, OP]
3c31a486 226
87675353 227 OP shift, and go to state 4
3c31a486 228
87675353
AD
229 OP [reduce using rule 1 (exp)]
230 $default reduce using rule 1 (exp)
3c31a486
AD
231]])
232
233AT_CLEANUP
234
235
3c31a486 236
ce4ccb4b
AD
237## ----------------------- ##
238## Resolved SR Conflicts. ##
239## ----------------------- ##
240
241AT_SETUP([Resolved SR Conflicts])
3c31a486 242
6b98e4b5
AD
243AT_KEYWORDS([report])
244
3c31a486
AD
245AT_DATA([input.y],
246[[%token NUM OP
ce4ccb4b 247%left OP
3c31a486
AD
248%%
249exp: exp OP exp | NUM;
250]])
251
b56471a6 252AT_CHECK([bison -o input.c --report=all input.y])
3c31a486
AD
253
254# Check the contents of the report.
255AT_CHECK([cat input.output], [],
ce4ccb4b 256[[Grammar
3c31a486 257
88bce5a2 258 0 $accept: exp $end
6b98e4b5
AD
259
260 1 exp: exp OP exp
261 2 | NUM
3c31a486
AD
262
263
264Terminals, with rules where they appear
265
88bce5a2 266$end (0) 0
3c31a486 267error (256)
007a50a4
AD
268NUM (258) 2
269OP (259) 1
3c31a486
AD
270
271
272Nonterminals, with rules where they appear
273
88bce5a2 274$accept (5)
3c31a486
AD
275 on left: 0
276exp (6)
277 on left: 1 2, on right: 0 1
278
279
280state 0
281
88bce5a2 282 0 $accept: . exp $end
ce4ccb4b
AD
283 1 exp: . exp OP exp
284 2 | . NUM
643a5994 285
87675353 286 NUM shift, and go to state 1
3c31a486 287
87675353 288 exp go to state 2
3c31a486
AD
289
290
291state 1
292
ce4ccb4b 293 2 exp: NUM .
3c31a486 294
87675353 295 $default reduce using rule 2 (exp)
3c31a486
AD
296
297
298state 2
299
88bce5a2 300 0 $accept: exp . $end
ce4ccb4b 301 1 exp: exp . OP exp
3c31a486 302
88bce5a2
AD
303 $end shift, and go to state 3
304 OP shift, and go to state 4
3c31a486
AD
305
306
307state 3
308
88bce5a2 309 0 $accept: exp $end .
3c31a486 310
e8832397 311 $default accept
3c31a486
AD
312
313
314state 4
315
ce4ccb4b
AD
316 1 exp: . exp OP exp
317 1 | exp OP . exp
318 2 | . NUM
3c31a486 319
87675353 320 NUM shift, and go to state 1
3c31a486 321
87675353 322 exp go to state 5
3c31a486
AD
323
324
325state 5
326
88bce5a2
AD
327 1 exp: exp . OP exp [$end, OP]
328 1 | exp OP exp . [$end, OP]
3c31a486 329
87675353 330 $default reduce using rule 1 (exp)
7ea9a33f 331
4b3d3a8e 332 Conflict between rule 1 and token OP resolved as reduce (%left OP).
bc933ef1
AD
333]])
334
335AT_CLEANUP
336
337
bc933ef1
AD
338## -------------------------------- ##
339## Defaulted Conflicted Reduction. ##
340## -------------------------------- ##
341
342# When there are RR conflicts, some rules are disabled. Usually it is
343# simply displayed as:
344#
88bce5a2
AD
345# $end reduce using rule 3 (num)
346# $end [reduce using rule 4 (id)]
bc933ef1
AD
347#
348# But when `reduce 3' is the default action, we'd produce:
349#
88bce5a2 350# $end [reduce using rule 4 (id)]
bc933ef1
AD
351# $default reduce using rule 3 (num)
352#
353# In this precise case (a reduction is masked by the default
354# reduction), we make the `reduce 3' explicit:
355#
88bce5a2
AD
356# $end reduce using rule 3 (num)
357# $end [reduce using rule 4 (id)]
bc933ef1
AD
358# $default reduce using rule 3 (num)
359#
360# Maybe that's not the best display, but then, please propose something
361# else.
362
363AT_SETUP([Defaulted Conflicted Reduction])
364AT_KEYWORDS([report])
365
366AT_DATA([input.y],
367[[%%
368exp: num | id;
369num: '0';
370id : '0';
371%%
372]])
373
b56471a6 374AT_CHECK([bison -o input.c --report=all input.y], 0, [],
52489d44 375[[input.y: warning: 1 reduce/reduce conflict
e8832397
AD
376input.y:4.4-8: warning: rule never reduced because of conflicts: id: '0'
377]])
bc933ef1
AD
378
379# Check the contents of the report.
380AT_CHECK([cat input.output], [],
c8f002c7
AD
381[[Rules never reduced
382
383 4 id: '0'
384
385
386State 1 contains 1 reduce/reduce conflict.
bc933ef1
AD
387
388
389Grammar
390
88bce5a2 391 0 $accept: exp $end
bc933ef1
AD
392
393 1 exp: num
394 2 | id
395
396 3 num: '0'
397
398 4 id: '0'
399
400
401Terminals, with rules where they appear
402
88bce5a2 403$end (0) 0
bc933ef1
AD
404'0' (48) 3 4
405error (256)
406
407
408Nonterminals, with rules where they appear
409
88bce5a2 410$accept (4)
bc933ef1
AD
411 on left: 0
412exp (5)
413 on left: 1 2, on right: 0
414num (6)
415 on left: 3, on right: 1
416id (7)
417 on left: 4, on right: 2
418
419
420state 0
421
88bce5a2 422 0 $accept: . exp $end
ce4ccb4b
AD
423 1 exp: . num
424 2 | . id
425 3 num: . '0'
426 4 id: . '0'
bc933ef1 427
87675353 428 '0' shift, and go to state 1
bc933ef1 429
87675353
AD
430 exp go to state 2
431 num go to state 3
432 id go to state 4
bc933ef1
AD
433
434
435state 1
436
88bce5a2
AD
437 3 num: '0' . [$end]
438 4 id: '0' . [$end]
bc933ef1 439
88bce5a2
AD
440 $end reduce using rule 3 (num)
441 $end [reduce using rule 4 (id)]
87675353 442 $default reduce using rule 3 (num)
bc933ef1
AD
443
444
445state 2
446
88bce5a2 447 0 $accept: exp . $end
bc933ef1 448
88bce5a2 449 $end shift, and go to state 5
bc933ef1
AD
450
451
452state 3
453
ce4ccb4b 454 1 exp: num .
bc933ef1 455
87675353 456 $default reduce using rule 1 (exp)
bc933ef1
AD
457
458
459state 4
460
ce4ccb4b 461 2 exp: id .
bc933ef1 462
87675353 463 $default reduce using rule 2 (exp)
bc933ef1
AD
464
465
466state 5
467
88bce5a2 468 0 $accept: exp $end .
bc933ef1 469
e8832397 470 $default accept
3c31a486
AD
471]])
472
473AT_CLEANUP
474
475
476
477
478## -------------------- ##
479## %expect not enough. ##
480## -------------------- ##
481
482AT_SETUP([%expect not enough])
483
484AT_DATA([input.y],
485[[%token NUM OP
486%expect 0
487%%
488exp: exp OP exp | NUM;
489]])
490
b56471a6 491AT_CHECK([bison -o input.c input.y], 1, [],
52489d44
AD
492[input.y: warning: 1 shift/reduce conflict
493input.y: expected 0 shift/reduce conflicts
3c31a486
AD
494])
495AT_CLEANUP
496
497
498## --------------- ##
499## %expect right. ##
500## --------------- ##
501
502AT_SETUP([%expect right])
503
504AT_DATA([input.y],
505[[%token NUM OP
506%expect 1
507%%
508exp: exp OP exp | NUM;
509]])
510
b56471a6 511AT_CHECK([bison -o input.c input.y])
3c31a486
AD
512AT_CLEANUP
513
514
515## ------------------ ##
516## %expect too much. ##
517## ------------------ ##
518
519AT_SETUP([%expect too much])
520
521AT_DATA([input.y],
522[[%token NUM OP
523%expect 2
524%%
525exp: exp OP exp | NUM;
526]])
527
b56471a6 528AT_CHECK([bison -o input.c input.y], 1, [],
52489d44
AD
529[input.y: warning: 1 shift/reduce conflict
530input.y: expected 2 shift/reduce conflicts
3c31a486
AD
531])
532AT_CLEANUP