]> git.saurik.com Git - bison.git/blame - tests/input.at
regen
[bison.git] / tests / input.at
CommitLineData
087b9fdf 1# Checking the Bison scanner. -*- Autotest -*-
7d424de1 2
34136e65 3# Copyright (C) 2002-2012 Free Software Foundation, Inc.
9b2d0677 4
f16b0819 5# This program is free software: you can redistribute it and/or modify
9b2d0677 6# it under the terms of the GNU General Public License as published by
f16b0819
PE
7# the Free Software Foundation, either version 3 of the License, or
8# (at your option) any later version.
9#
9b2d0677
AD
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
f16b0819 14#
9b2d0677 15# You should have received a copy of the GNU General Public License
f16b0819 16# along with this program. If not, see <http://www.gnu.org/licenses/>.
9b2d0677
AD
17
18AT_BANNER([[Input Processing.]])
19
20# Mostly test that we are robust to mistakes.
21
6c35d22c 22
9b2d0677
AD
23## ------------ ##
24## Invalid $n. ##
25## ------------ ##
26
287b314e 27AT_SETUP([Invalid $n and @n])
9b2d0677
AD
28
29AT_DATA([input.y],
30[[%%
bfcf1f3a 31exp: { $$ = $1 ; };
bfcf1f3a 32exp: { @$ = @1 ; };
9b2d0677
AD
33]])
34
da730230 35AT_BISON_CHECK([input.y], [1], [],
ae93e4e4
JM
36[[input.y:2.13-14: integer out of range: '$1'
37input.y:3.13-14: integer out of range: '@1'
9b2d0677
AD
38]])
39
40AT_CLEANUP
9af3fbce
AD
41
42
43## -------------- ##
e776192e 44## Type Clashes. ##
9af3fbce
AD
45## -------------- ##
46
e776192e 47AT_SETUP([Type Clashes])
9af3fbce
AD
48
49AT_DATA([input.y],
ffa4ba3a
JD
50[[%union { int bar; }
51%token foo
9af3fbce
AD
52%type <bar> exp
53%%
ffa4ba3a 54exp: foo { $$; } foo { $2; } foo
9af3fbce
AD
55 | foo
56 | /* Empty. */
57 ;
58]])
59
da730230 60AT_BISON_CHECK([input.y], [1], [],
ae93e4e4
JM
61[[input.y:5.12-13: $$ for the midrule at $2 of 'exp' has no declared type
62input.y:5.24-25: $2 of 'exp' has no declared type
73370a9d
VS
63input.y:5.6-32: warning: type clash on default action: <bar> != <> [-Wother]
64input.y:6.6-8: warning: type clash on default action: <bar> != <> [-Wother]
65input.y:7.5: warning: empty rule for typed nonterminal, and no action [-Wother]
9af3fbce
AD
66]])
67
68AT_CLEANUP
5a08f1ce
AD
69
70
ffa4ba3a 71# _AT_UNUSED_VALUES_DECLARATIONS()
dab244d5 72# --------------------------------
ffa4ba3a
JD
73# Generate the token, type, and destructor
74# declarations for the unused values tests.
ffa4ba3a
JD
75m4_define([_AT_UNUSED_VALUES_DECLARATIONS],
76[[[%token <integer> INT;
77%type <integer> a b c d e f g h i j k l;
78%destructor { destroy ($$); } INT a b c d e f g h i j k l;]]])
378f4bd8 79
ffa4ba3a 80
17bd8a73 81# AT_CHECK_UNUSED_VALUES(DECLARATIONS_AFTER, CHECK_MIDRULE_VALUES)
dab244d5
AD
82# ----------------------------------------------------------------
83# Generate a grammar to test unused values, compile it, run it. If
84# DECLARATIONS_AFTER is set, then the token, type, and destructor
85# declarations are generated after the rules rather than before. If
86# CHECK_MIDRULE_VALUES is set, then --warnings=midrule-values is set.
ffa4ba3a
JD
87m4_define([AT_CHECK_UNUSED_VALUES],
88[AT_DATA([input.y],
89m4_ifval($1, [
90
91
92], [_AT_UNUSED_VALUES_DECLARATIONS
93])[[%%
27622431 94start:
e8cd1ad6
DJ
95 'a' a { $]2[; } | 'b' b { $]2[; } | 'c' c { $]2[; } | 'd' d { $]2[; }
96| 'e' e { $]2[; } | 'f' f { $]2[; } | 'g' g { $]2[; } | 'h' h { $]2[; }
97| 'i' i { $]2[; } | 'j' j { $]2[; } | 'k' k { $]2[; } | 'l' l { $]2[; }
378f4bd8 98;
27622431
PE
99
100a: INT | INT { } INT { } INT { };
101b: INT | /* empty */;
e8cd1ad6
DJ
102c: INT | INT { $]1[; } INT { $<integer>2; } INT { $<integer>4; };
103d: INT | INT { } INT { $]1[; } INT { $<integer>2; };
104e: INT | INT { } INT { } INT { $]1[; };
ffa4ba3a 105f: INT | INT { } INT { } INT { $]$[ = $]1[ + $]3[ + $]5[; };
ddc8ede1
PE
106g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
107h: INT | INT { $<integer>$; } INT { $<integer>$ = $<integer>2; } INT { };
ffa4ba3a
JD
108i: INT | INT INT { } { $]$[ = $]1[ + $]2[; };
109j: INT | INT INT { $<integer>$ = 1; } { $]$[ = $]1[ + $]2[; };
ddc8ede1
PE
110k: INT | INT INT { $<integer>$; } { $<integer>$ = $<integer>3; } { };
111l: INT | INT { $<integer>$ = $<integer>1; } INT { $<integer>$ = $<integer>2 + $<integer>3; } INT { $<integer>$ = $<integer>4 + $<integer>5; };]]m4_ifval($1, [
ffa4ba3a
JD
112_AT_UNUSED_VALUES_DECLARATIONS])
113)
114
da730230 115AT_BISON_CHECK(m4_ifval($2, [ --warnings=midrule-values ])[ input.y], [0], [],
73370a9d
VS
116[[input.y:11.10-32: warning: unset value: $]$[ [-Wother]
117input.y:11.10-32: warning: unused value: $]1[ [-Wother]
118input.y:11.10-32: warning: unused value: $]3[ [-Wother]
119input.y:11.10-32: warning: unused value: $]5[ [-Wother]
120input.y:12.9: warning: empty rule for typed nonterminal, and no action [-Wother]
121]]m4_ifval($2, [[[input.y:13.14-20: warning: unset value: $$ [-Wmidrule-values]
122input.y:13.26-41: warning: unset value: $$ [-Wmidrule-values]
123]]])[[input.y:13.10-62: warning: unset value: $]$[ [-Wother]
124input.y:13.10-62: warning: unused value: $]3[ [-Wother]
125input.y:13.10-62: warning: unused value: $]5[ [-Wother]
126]]m4_ifval($2, [[[input.y:14.14-16: warning: unset value: $$ [-Wmidrule-values]
127]]])[[input.y:14.10-49: warning: unset value: $]$[ [-Wother]
128input.y:14.10-49: warning: unused value: $]3[ [-Wother]
129input.y:14.10-49: warning: unused value: $]5[ [-Wother]
130input.y:15.10-37: warning: unset value: $]$[ [-Wother]
131input.y:15.10-37: warning: unused value: $]3[ [-Wother]
132input.y:15.10-37: warning: unused value: $]5[ [-Wother]
133input.y:17.10-58: warning: unset value: $]$[ [-Wother]
134input.y:17.10-58: warning: unused value: $]1[ [-Wother]
135]]m4_ifval($2, [[[input.y:17.10-58: warning: unused value: $]2[ [-Wmidrule-values]
136]]])[[input.y:17.10-58: warning: unused value: $]3[ [-Wother]
137]]m4_ifval($2, [[[input.y:17.10-58: warning: unused value: $]4[ [-Wmidrule-values]
138]]])[[input.y:17.10-58: warning: unused value: $]5[ [-Wother]
139input.y:18.10-72: warning: unset value: $]$[ [-Wother]
140input.y:18.10-72: warning: unused value: $]1[ [-Wother]
141input.y:18.10-72: warning: unused value: $]3[ [-Wother]
142]]m4_ifval($2, [[[input.y:18.10-72: warning: unused value: $]4[ [-Wmidrule-values]
143]]])[[input.y:18.10-72: warning: unused value: $]5[ [-Wother]
144]]m4_ifval($2, [[[input.y:20.10-55: warning: unused value: $]3[ [-Wmidrule-values]
145]]])[[input.y:21.10-68: warning: unset value: $]$[ [-Wother]
146input.y:21.10-68: warning: unused value: $]1[ [-Wother]
147input.y:21.10-68: warning: unused value: $]2[ [-Wother]
148]]m4_ifval($2, [[[input.y:21.10-68: warning: unused value: $]4[ [-Wmidrule-values]
17bd8a73 149]]]))])
27622431 150
378f4bd8 151
ffa4ba3a
JD
152## --------------- ##
153## Unused values. ##
154## --------------- ##
155
156AT_SETUP([Unused values])
157AT_CHECK_UNUSED_VALUES
17bd8a73 158AT_CHECK_UNUSED_VALUES(, [1])
ffa4ba3a
JD
159AT_CLEANUP
160
161
162## ------------------------------------------ ##
163## Unused values before symbol declarations. ##
164## ------------------------------------------ ##
84866159 165
ffa4ba3a
JD
166AT_SETUP([Unused values before symbol declarations])
167AT_CHECK_UNUSED_VALUES([1])
17bd8a73 168AT_CHECK_UNUSED_VALUES([1], [1])
84866159 169AT_CLEANUP
378f4bd8
AD
170
171
ec5479ce
JD
172## --------------------------------------------- ##
173## Default %printer and %destructor redeclared. ##
174## --------------------------------------------- ##
175
176AT_SETUP([Default %printer and %destructor redeclared])
177
178AT_DATA([[input.y]],
12e35840 179[[%destructor { destroy ($$); } <*> <*>
abcd36ca 180%printer { print ($$); } <*> <*>
ec5479ce 181
12e35840 182%destructor { destroy ($$); } <*>
abcd36ca 183%printer { print ($$); } <*>
12e35840 184
3ebecc24 185%destructor { destroy ($$); } <> <>
abcd36ca 186%printer { print ($$); } <> <>
12e35840 187
3ebecc24 188%destructor { destroy ($$); } <>
abcd36ca 189%printer { print ($$); } <>
ec5479ce
JD
190
191%%
192
193start: ;
194
12e35840 195%destructor { destroy ($$); } <*>;
abcd36ca 196%printer { print ($$); } <*>;
12e35840 197
3ebecc24 198%destructor { destroy ($$); } <>;
abcd36ca 199%printer { print ($$); } <>;
ec5479ce
JD
200]])
201
da730230 202AT_BISON_CHECK([input.y], [1], [],
9534d2be 203[[input.y:1.13-29: %destructor redeclaration for <*>
b2a0b7ca 204input.y:1.13-29: previous declaration
9534d2be 205input.y:2.10-24: %printer redeclaration for <*>
abcd36ca 206input.y:2.10-24: previous declaration
9534d2be 207input.y:4.13-29: %destructor redeclaration for <*>
ec5479ce 208input.y:1.13-29: previous declaration
9534d2be 209input.y:5.10-24: %printer redeclaration for <*>
abcd36ca 210input.y:2.10-24: previous declaration
9534d2be 211input.y:7.13-29: %destructor redeclaration for <>
12e35840 212input.y:7.13-29: previous declaration
9534d2be 213input.y:8.10-24: %printer redeclaration for <>
abcd36ca 214input.y:8.10-24: previous declaration
9534d2be 215input.y:10.13-29: %destructor redeclaration for <>
12e35840 216input.y:7.13-29: previous declaration
9534d2be 217input.y:11.10-24: %printer redeclaration for <>
abcd36ca 218input.y:8.10-24: previous declaration
9534d2be 219input.y:17.13-29: %destructor redeclaration for <*>
ec5479ce 220input.y:4.13-29: previous declaration
9534d2be 221input.y:18.10-24: %printer redeclaration for <*>
abcd36ca 222input.y:5.10-24: previous declaration
9534d2be 223input.y:20.13-29: %destructor redeclaration for <>
12e35840 224input.y:10.13-29: previous declaration
9534d2be 225input.y:21.10-24: %printer redeclaration for <>
abcd36ca 226input.y:11.10-24: previous declaration
ec5479ce
JD
227]])
228
229AT_CLEANUP
230
231
b2a0b7ca
JD
232## ---------------------------------------------- ##
233## Per-type %printer and %destructor redeclared. ##
234## ---------------------------------------------- ##
235
236AT_SETUP([Per-type %printer and %destructor redeclared])
237
238AT_DATA([[input.y]],
239[[%destructor { destroy ($$); } <field1> <field2>
abcd36ca 240%printer { print ($$); } <field1> <field2>
b2a0b7ca
JD
241
242%destructor { destroy ($$); } <field1> <field1>
abcd36ca 243%printer { print ($$); } <field2> <field2>
b2a0b7ca
JD
244
245%%
246
247start: ;
248
249%destructor { destroy ($$); } <field2> <field1>;
abcd36ca 250%printer { print ($$); } <field2> <field1>;
b2a0b7ca
JD
251]])
252
da730230 253AT_BISON_CHECK([input.y], [1], [],
b2a0b7ca
JD
254[[input.y:4.13-29: %destructor redeclaration for <field1>
255input.y:1.13-29: previous declaration
256input.y:4.13-29: %destructor redeclaration for <field1>
257input.y:4.13-29: previous declaration
abcd36ca
AD
258input.y:5.10-24: %printer redeclaration for <field2>
259input.y:2.10-24: previous declaration
260input.y:5.10-24: %printer redeclaration for <field2>
261input.y:5.10-24: previous declaration
b2a0b7ca
JD
262input.y:11.13-29: %destructor redeclaration for <field1>
263input.y:4.13-29: previous declaration
264input.y:11.13-29: %destructor redeclaration for <field2>
265input.y:1.13-29: previous declaration
abcd36ca
AD
266input.y:12.10-24: %printer redeclaration for <field1>
267input.y:2.10-24: previous declaration
268input.y:12.10-24: %printer redeclaration for <field2>
269input.y:5.10-24: previous declaration
b2a0b7ca
JD
270]])
271
272AT_CLEANUP
273
3b0b682f
AD
274## ----------------------------------------------------- ##
275## Undeclared symbols used for a printer or destructor. ##
276## ----------------------------------------------------- ##
b921d92f
VS
277
278AT_SETUP([Undeclared symbols used for a printer or destructor])
279
280AT_DATA([[input.y]],
3b0b682f
AD
281[[%printer {} foo baz
282%destructor {} bar
b921d92f
VS
283
284%%
3b0b682f 285exp: bar;
b921d92f
VS
286]])
287
3b0b682f
AD
288AT_BISON_CHECK([input.y], [1], [],
289[[input.y:2.16-18: symbol bar is used, but is not defined as a token and has no rules
73370a9d
VS
290input.y:1.17-19: warning: symbol baz is used, but is not defined as a token and has no rules [-Wother]
291input.y:1.13-15: warning: symbol foo is used, but is not defined as a token and has no rules [-Wother]
b921d92f
VS
292]])
293
294AT_CLEANUP
295
b2a0b7ca 296
9641b918
VS
297## ----------------------------------------------------- ##
298## Unassociated types used for a printer or destructor. ##
299## ----------------------------------------------------- ##
300
301AT_SETUP([Unassociated types used for a printer or destructor])
302
303AT_DATA([[input.y]],
304[[%token <type1> tag1
305%type <type2> tag2
306
307%printer { } <type1> <type3>
308%destructor { } <type2> <type4>
309
310%%
311
312exp: tag1 { $1; }
313 | tag2 { $1; }
314
315tag2: "a" { $$; }
316]])
317
318AT_BISON_CHECK([input.y], [0], [],
73370a9d
VS
319[[input.y:4.22-28: warning: type <type3> is used, but is not associated to any symbol [-Wother]
320input.y:5.25-31: warning: type <type4> is used, but is not associated to any symbol [-Wother]
9641b918
VS
321]])
322
323AT_CLEANUP
324
325
ea9a35c6
VS
326## --------------------------------- ##
327## Useless printers or destructors. ##
328## --------------------------------- ##
329
330AT_SETUP([Useless printers or destructors])
331
9534d2be
AD
332# AT_TEST([INPUT], [STDERR])
333# --------------------------
334m4_pushdef([AT_TEST],
335[AT_DATA([[input.y]],
336[$1
337])
338AT_BISON_CHECK([input.y], [0], [], [$2
339])])
340
341AT_TEST([[%token <type1> token1
ea9a35c6
VS
342%token <type2> token2
343%token <type3> token3
344%token <type4> token4
345%token <type5> token51 token52
346%token <type6> token61 token62
347%token <type7> token7
348
349%printer {} token1
350%destructor {} token2
351%printer {} token51
352%destructor {} token61
353
354%printer {} token7
355
356%printer {} <type1>
357%destructor {} <type2>
358%printer {} <type3>
359%destructor {} <type4>
360
361%printer {} <type5>
362%destructor {} <type6>
363
364%destructor {} <type7>
365
366%%
9534d2be 367exp: "a";]],
73370a9d 368[[input.y:16.13-19: warning: useless %printer for type <type1> [-Wother]
9534d2be
AD
369input.y:17.16-22: warning: useless %destructor for type <type2> [-Wother]]])
370
371# If everybody is typed, <> is useless.
372AT_TEST([[%type <type> exp
373%token <type> a
374%printer {} <> <*>
375%%
376exp: a;]],
377[[input.y:3.13-14: warning: useless %printer for type <> [-Wother]]])
378
379# If nobody is is typed, <*> is useless.
380AT_TEST([[%token a
381%printer {} <> <*>
382%%
383exp: a;]],
384[[input.y:2.16-18: warning: useless %printer for type <*> [-Wother]]])
ea9a35c6 385
9534d2be 386m4_popdef([AT_TEST])
ea9a35c6
VS
387
388AT_CLEANUP
389
390
ec5479ce
JD
391## ---------------------------------------- ##
392## Unused values with default %destructor. ##
393## ---------------------------------------- ##
394
395AT_SETUP([Unused values with default %destructor])
396
397AT_DATA([[input.y]],
3ebecc24 398[[%destructor { destroy ($$); } <>
12e35840
JD
399%type <tag> tagged
400
401%%
402
403start: end end tagged tagged { $<tag>1; $3; } ;
404end: { } ;
405tagged: { } ;
406]])
407
da730230 408AT_BISON_CHECK([input.y], [0], [],
73370a9d
VS
409[[input.y:6.8-45: warning: unset value: $$ [-Wother]
410input.y:6.8-45: warning: unused value: $2 [-Wother]
411input.y:7.6-8: warning: unset value: $$ [-Wother]
12e35840
JD
412]])
413
414AT_DATA([[input.y]],
415[[%destructor { destroy ($$); } <*>
416%type <tag> tagged
ec5479ce
JD
417
418%%
419
12e35840
JD
420start: end end tagged tagged { $<tag>1; $3; } ;
421end: { } ;
422tagged: { } ;
ec5479ce
JD
423]])
424
da730230 425AT_BISON_CHECK([input.y], [0], [],
73370a9d
VS
426[[input.y:6.8-45: warning: unused value: $4 [-Wother]
427input.y:8.9-11: warning: unset value: $$ [-Wother]
ec5479ce
JD
428]])
429
430AT_CLEANUP
431
432
b2a0b7ca
JD
433## ----------------------------------------- ##
434## Unused values with per-type %destructor. ##
435## ----------------------------------------- ##
436
437AT_SETUP([Unused values with per-type %destructor])
438
439AT_DATA([[input.y]],
440[[%destructor { destroy ($$); } <field1>
441%type <field1> start end
442
443%%
444
445start: end end { $1; } ;
446end: { } ;
447]])
448
da730230 449AT_BISON_CHECK([input.y], [0], [],
73370a9d
VS
450[[input.y:6.8-22: warning: unset value: $$ [-Wother]
451input.y:6.8-22: warning: unused value: $2 [-Wother]
452input.y:7.6-8: warning: unset value: $$ [-Wother]
b2a0b7ca
JD
453]])
454
455AT_CLEANUP
456
457
df09ef2e
AD
458## ---------------------- ##
459## Incompatible Aliases. ##
460## ---------------------- ##
461
462AT_SETUP([Incompatible Aliases])
463
464AT_DATA([input.y],
465[[%token foo "foo"
466
467%type <bar> foo
468%printer {bar} foo
469%destructor {bar} foo
470%left foo
471
472%type <baz> "foo"
473%printer {baz} "foo"
474%destructor {baz} "foo"
475%left "foo"
476
477%%
478exp: foo;
479]])
480
da730230 481AT_BISON_CHECK([input.y], [1], [],
df09ef2e 482[[input.y:8.7-11: %type redeclaration for foo
dd60572a 483input.y:3.7-11: previous declaration
df09ef2e 484input.y:10.13-17: %destructor redeclaration for foo
dd60572a 485input.y:5.13-17: previous declaration
e2a8c0f5 486input.y:9.10-14: %printer redeclaration for foo
dd60572a 487input.y:4.10-14: previous declaration
df09ef2e 488input.y:11.1-5: %left redeclaration for foo
dd60572a 489input.y:6.1-5: previous declaration
df09ef2e
AD
490]])
491
492AT_CLEANUP
493
494
5a08f1ce
AD
495
496## ----------------------- ##
497## Torturing the Scanner. ##
498## ----------------------- ##
499
500# Be sure to compile and run, so that the C compiler checks what
501# we do.
502
503AT_SETUP([Torturing the Scanner])
504
71c7e24f 505AT_BISON_OPTION_PUSHDEFS
0baf7c50 506AT_DATA([input.y], [])
da730230 507AT_BISON_CHECK([input.y], [1], [],
4a678af8 508[[input.y:1.1: syntax error, unexpected end of file
0baf7c50
PE
509]])
510
511
e9071366 512AT_DATA([input.y],
b2ddc3f3
AD
513[{}
514])
da730230 515AT_BISON_CHECK([input.y], [1], [],
4a678af8 516[[input.y:1.1-2: syntax error, unexpected {...}
b2ddc3f3
AD
517]])
518
519
9501dc6e 520AT_DATA_GRAMMAR([input.y],
5a08f1ce
AD
521[[%{
522/* This is seen in GCC: a %{ and %} in middle of a comment. */
523const char *foo = "So %{ and %} can be here too.";
524
dda7a53e
PE
525#if 0
526/* These examples test Bison while not stressing C compilers too much.
527 Many C compilers mishandle backslash-newlines, so this part of the
528 test is inside "#if 0". The comment and string are written so that
529 the "#endif" will be seen regardless of the C compiler bugs that we
530 know about, namely:
531
532 HP C (as of late 2002) mishandles *\[newline]\[newline]/ within a
533 comment.
534
535 The Apple Darwin compiler (as of late 2002) mishandles
536 \\[newline]' within a character constant.
537
538 */
539
206fe6a5 540/\
dda7a53e
PE
541* A comment with backslash-newlines in it. %} *\
542\
206fe6a5 543/
dda7a53e 544/* { Close the above comment, if the C compiler mishandled it. */
206fe6a5
PE
545
546char str[] = "\\
547" A string with backslash-newlines in it %{ %} \\
dda7a53e 548\
206fe6a5
PE
549"";
550
dda7a53e 551char apostrophe = '\'';
206fe6a5
PE
552#endif
553
5a08f1ce 554#include <stdio.h>
c4bd5bf7 555#include <stdlib.h>
77519a7d 556#include <assert.h>
5a08f1ce
AD
557%}
558/* %{ and %} can be here too. */
559
560%{
561/* Exercise pre-prologue dependency to %union. */
051ade83 562typedef int value;
5a08f1ce
AD
563%}
564
565/* Exercise M4 quoting: '@:>@@:>@', 0. */
566
567/* Also exercise %union. */
568%union
569{
051ade83 570 value ival; /* A comment to exercise an old bug. */
5a08f1ce
AD
571};
572
573
574/* Exercise post-prologue dependency to %union. */
575%{
051ade83 576static YYSTYPE value_as_yystype (value val);
5a08f1ce
AD
577
578/* Exercise quotes in declarations. */
579char quote[] = "@:>@@:>@,";
580%}
581
582%{
55f48c48
AD
583]AT_YYERROR_DECLARE[
584]AT_YYLEX_DECLARE[
5a08f1ce
AD
585%}
586
206fe6a5 587%type <ival> '@<:@'
5a08f1ce
AD
588
589/* Exercise quotes in strings. */
3dc4c5fa 590%token FAKE "fake @<:@@:>@ \a\b\f\n\r\t\v\"\'\?\\\u005B\U0000005c ??!??'??(??)??-??/??<??=??> \x1\1"
5a08f1ce
AD
591
592%%
206fe6a5 593/* Exercise M4 quoting: '@:>@@:>@', @<:@, 1. */
087b9fdf 594exp: '@<:@' '\1' two '$' '@' '{' oline output.or.oline.opt
5a08f1ce
AD
595 {
596 /* Exercise quotes in braces. */
597 char tmp[] = "@<:@%c@:>@,\n";
598 printf (tmp, $1);
599 }
600;
5b7f88c7
PE
601
602two: '\x000000000000000000000000000000000000000000000000000000000000000000002';
603oline: '@' 'o' 'l' 'i' 'n' 'e' '@' '_' '_' 'o' 'l' 'i' 'n' 'e' '_' '_';
087b9fdf 604output.or.oline.opt: ;|oline;;|output;;;
5b7f88c7 605output: '#' 'o' 'u' 't' 'p' 'u' 't' ' ';
5a08f1ce 606%%
206fe6a5 607/* Exercise M4 quoting: '@:>@@:>@', @<:@, 2. */
5a08f1ce
AD
608
609static YYSTYPE
051ade83 610value_as_yystype (value val)
5a08f1ce
AD
611{
612 YYSTYPE res;
613 res.ival = val;
614 return res;
615}
71c7e24f 616]AT_YYERROR_DEFINE[
7172e23e 617static int
5a08f1ce
AD
618yylex (void)
619{
cf806753 620 static char const input[] = "@<:@\1\2$@{@oline@__@&t@oline__\
5b7f88c7
PE
621#output "; /* "
622 */
cf806753 623 static size_t toknum;
77519a7d 624 assert (toknum < sizeof input);
cf806753
PE
625 yylval = value_as_yystype (input[toknum]);
626 return input[toknum++];
5a08f1ce 627}
5a08f1ce
AD
628]])
629
9501dc6e
AD
630# Pacify Emacs'font-lock-mode: "
631
5a08f1ce 632AT_DATA([main.c],
051ade83 633[[typedef int value;
5a08f1ce
AD
634#include "input.h"
635
636int yyparse (void);
637
638int
639main (void)
640{
641 return yyparse ();
642}
643]])
71c7e24f 644AT_BISON_OPTION_POPDEFS
5a08f1ce 645
da730230 646AT_BISON_CHECK([-d -v -o input.c input.y])
91ce0b3a
AD
647AT_COMPILE([input.o])
648AT_COMPILE([main.o])
efc6bf1b 649AT_COMPILE([input], [input.o main.o])
1154cced 650AT_PARSER_CHECK([./input], 0,
206fe6a5 651[[[@<:@],
5a08f1ce
AD
652]])
653
654AT_CLEANUP
e59adf8f
PE
655
656
657## ---------------------- ##
658## Typed symbol aliases. ##
659## ---------------------- ##
660
661AT_SETUP([Typed symbol aliases])
662
663# Bison 2.0 broke typed symbol aliases - ensure they work.
664
665AT_DATA_GRAMMAR([input.y],
666[[%union
667{
668 int val;
669};
670%token <val> MY_TOKEN "MY TOKEN"
671%type <val> exp
672%%
673exp: "MY TOKEN";
674%%
675]])
676
da730230 677AT_BISON_CHECK([-o input.c input.y])
e59adf8f
PE
678
679AT_CLEANUP
b50d2359
AD
680
681
682## --------- ##
683## Require. ##
684## --------- ##
685
686m4_define([AT_CHECK_REQUIRE],
687[AT_SETUP([Require $1])
688AT_DATA_GRAMMAR([input.y],
689[[%require "$1";
690%%
691empty_file:;
692]])
da730230 693AT_BISON_CHECK([-o input.c input.y], $2, [], ignore)
b50d2359
AD
694AT_CLEANUP
695])
696
697AT_CHECK_REQUIRE(1.0, 0)
698AT_CHECK_REQUIRE(AT_PACKAGE_VERSION, 0)
699## FIXME: Some day augment this version number.
9b8a5ce0 700AT_CHECK_REQUIRE(100.0, 63)
1f6b3679
JD
701
702
703## ------------------------------------- ##
704## String aliases for character tokens. ##
705## ------------------------------------- ##
706
707AT_SETUP([String aliases for character tokens])
708
dab244d5
AD
709# Bison once thought a character token and its alias were different
710# symbols with the same user token number.
1f6b3679
JD
711
712AT_DATA_GRAMMAR([input.y],
713[[%token 'a' "a"
714%%
715start: 'a';
716%%
717]])
718
da730230 719AT_BISON_CHECK([-o input.c input.y])
1f6b3679
JD
720
721AT_CLEANUP
47aee066
JD
722
723
746ee38c
AD
724## -------------- ##
725## Symbol names. ##
726## -------------- ##
727
728AT_SETUP([Symbols])
729
55f48c48 730AT_BISON_OPTION_PUSHDEFS
746ee38c
AD
731AT_DATA_GRAMMAR([input.y],
732[[%token WITH-DASH
733%token WITHOUT_DASH "WITHOUT-DASH"
734%token WITH.PERIOD
735%token WITHOUT_PERIOD "WITHOUT.PERIOD"
d521ee19 736%code {
55f48c48
AD
737 ]AT_YYERROR_DECLARE[
738 ]AT_YYLEX_DECLARE[
d521ee19 739}
746ee38c
AD
740%%
741start: with-dash without_dash with.period without_period;
742with-dash: WITH-DASH;
743without_dash: "WITHOUT-DASH";
744with.period: WITH.PERIOD;
745without_period: "WITHOUT.PERIOD";
746%%
55f48c48
AD
747]AT_YYERROR_DEFINE[
748]AT_YYLEX_DEFINE[
746ee38c 749]])
55f48c48 750AT_BISON_OPTION_POPDEFS
746ee38c
AD
751
752# POSIX Yacc accept periods, but not dashes.
753AT_BISON_CHECK([--yacc input.y], [1], [],
73370a9d
VS
754[[input.y:9.8-16: POSIX Yacc forbids dashes in symbol names: WITH-DASH [-Wyacc]
755input.y:18.8-16: POSIX Yacc forbids dashes in symbol names: with-dash [-Wyacc]
746ee38c
AD
756]])
757
758# So warn about them.
759AT_BISON_CHECK([-Wyacc input.y], [], [],
73370a9d
VS
760[[input.y:9.8-16: warning: POSIX Yacc forbids dashes in symbol names: WITH-DASH [-Wyacc]
761input.y:18.8-16: warning: POSIX Yacc forbids dashes in symbol names: with-dash [-Wyacc]
746ee38c
AD
762]])
763
764# Dashes are fine for GNU Bison.
765AT_BISON_CHECK([-o input.c input.y])
766
767# Make sure we don't export silly token identifiers with periods or dashes.
91ce0b3a 768AT_COMPILE([input.o])
746ee38c
AD
769
770
82f3355e
JD
771# Periods are genuine letters, they can start identifiers.
772# Digits and dashes cannot.
746ee38c 773AT_DATA_GRAMMAR([input.y],
cdf3f113 774[[%token .GOOD
84a1cb5a
AD
775 -GOOD
776 1NV4L1D
82f3355e 777 -123
746ee38c 778%%
82f3355e 779start: .GOOD GOOD
746ee38c
AD
780]])
781AT_BISON_CHECK([-o input.c input.y], [1], [],
ae93e4e4
JM
782[[input.y:10.10: invalid character: '-'
783input.y:11.10-16: invalid identifier: '1NV4L1D'
784input.y:12.10: invalid character: '-'
746ee38c
AD
785]])
786
787AT_CLEANUP
788
789
ab2a9f57
AD
790## ----------------- ##
791## Numbered tokens. ##
792## ----------------- ##
793
794AT_SETUP([Numbered tokens])
795
83b60c97
JD
796AT_DATA_GRAMMAR([redecl.y],
797[[%token DECIMAL_1 11259375
798 HEXADECIMAL_1 0xabcdef
799 HEXADECIMAL_2 0xFEDCBA
800 DECIMAL_2 16702650
ab2a9f57 801%%
83b60c97 802start: DECIMAL_1 HEXADECIMAL_2;
8893145a
AD
803]])
804
83b60c97
JD
805AT_BISON_CHECK([redecl.y], [1], [],
806[[redecl.y:10.10-22: user token number 11259375 redeclaration for HEXADECIMAL_1
807redecl.y:9.8-16: previous declaration for DECIMAL_1
808redecl.y:12.10-18: user token number 16702650 redeclaration for DECIMAL_2
809redecl.y:11.10-22: previous declaration for HEXADECIMAL_2
8893145a
AD
810]])
811
83b60c97 812AT_DATA_GRAMMAR([too-large.y],
ab2a9f57
AD
813[[%token TOO_LARGE_DEC 999999999999999999999
814 TOO_LARGE_HEX 0xFFFFFFFFFFFFFFFFFFF
815%%
816start: TOO_LARGE_DEC TOO_LARGE_HEX
817%%
818]])
819
83b60c97 820AT_BISON_CHECK([too-large.y], [1], [],
ae93e4e4
JM
821[[too-large.y:9.22-42: integer out of range: '999999999999999999999'
822too-large.y:10.24-44: integer out of range: '0xFFFFFFFFFFFFFFFFFFF'
ab2a9f57
AD
823]])
824
825AT_CLEANUP
826
827
47aee066
JD
828## --------------------- ##
829## Unclosed constructs. ##
830## --------------------- ##
831
832AT_SETUP([Unclosed constructs])
833
dab244d5
AD
834# Bison's scan-gram.l once forgot to STRING_FINISH some unclosed
835# constructs, so they were prepended to whatever it STRING_GROW'ed
836# next. It also threw them away rather than returning them to the
837# parser. The effect was confusing subsequent error messages.
47aee066
JD
838
839AT_DATA([input.y],
840[[%token A "a
841%token B "b"
842%token AB "ab" // Used to complain that "ab" was already used.
843%token C '1
844%token TWO "2"
845%token TICK_TWELVE "'12" // Used to complain that "'12" was already used.
846
847%%
848
849start: ;
850
851// Used to report a syntax error because it didn't see any kind of symbol
852// identifier.
853%type <f> 'a
854;
855%type <f> "a
856;
857// Used to report a syntax error because it didn't see braced code.
858%destructor { free ($$)
859]])
860
da730230 861AT_BISON_CHECK([-o input.c input.y], 1, [],
ae93e4e4 862[[input.y:1.10-2.0: missing '"' at end of line
4a9cd8f2
AD
863input.y:4.10-5.0: missing "'" at end of line
864input.y:14.11-15.0: missing "'" at end of line
ae93e4e4
JM
865input.y:16.11-17.0: missing '"' at end of line
866input.y:19.13-20.0: missing '}' at end of file
3be03b13 867input.y:20.1: syntax error, unexpected end of file
47aee066
JD
868]])
869
870AT_CLEANUP
4d7370cb
JD
871
872
873## ------------------------- ##
874## %start after first rule. ##
875## ------------------------- ##
876
877AT_SETUP([%start after first rule])
878
dab244d5
AD
879# Bison once complained that a %start after the first rule was a
880# redeclaration of the start symbol.
4d7370cb
JD
881
882AT_DATA([input.y],
883[[%%
884false_start: ;
885start: false_start ;
886%start start;
887]])
888
da730230 889AT_BISON_CHECK([-o input.c input.y])
4d7370cb
JD
890
891AT_CLEANUP
26b8a438
JD
892
893
894## --------------------- ##
895## %prec takes a token. ##
896## --------------------- ##
897
898AT_SETUP([%prec takes a token])
899
900# Bison once allowed %prec sym where sym was a nonterminal.
901
902AT_DATA([input.y],
903[[%%
904start: PREC %prec PREC ;
905PREC: ;
906]])
907
da730230 908AT_BISON_CHECK([input.y], [1], [],
26b8a438
JD
909[[input.y:3.1-4: rule given for PREC, which is a token
910]])
911
912AT_CLEANUP
8e0a5e9e
JD
913
914
8bb3a2e7
JD
915## ------------------------------- ##
916## %prec's token must be defined. ##
917## ------------------------------- ##
918
919AT_SETUP([[%prec's token must be defined]])
920
921# According to POSIX, a %prec token must be defined separately.
922
923AT_DATA([[input.y]],
924[[%%
925start: %prec PREC ;
926]])
927
02354690 928AT_BISON_CHECK([[input.y]], [[0]], [],
73370a9d 929[[input.y:2.8-17: warning: token for %prec is not defined: PREC [-Wother]
8bb3a2e7
JD
930]])
931
932AT_CLEANUP
933
934
6afc30cc
JD
935## -------------------------------- ##
936## Reject unused %code qualifiers. ##
937## -------------------------------- ##
8e0a5e9e 938
6afc30cc 939AT_SETUP([Reject unused %code qualifiers])
8e0a5e9e
JD
940
941AT_DATA([input-c.y],
16dc6a9e
JD
942[[%code q {}
943%code bad {}
944%code bad {}
8405b70c 945%code format {}
8e0a5e9e
JD
946%%
947start: ;
948]])
c6abeab1 949AT_BISON_CHECK([[input-c.y]], [[1]], [],
4aa9d1ff
JM
950[[input-c.y:1.7: %code qualifier 'q' is not used
951input-c.y:2.7-9: %code qualifier 'bad' is not used
952input-c.y:3.7-9: %code qualifier 'bad' is not used
953input-c.y:4.7-12: %code qualifier 'format' is not used
08af01c2 954]])
8e0a5e9e
JD
955
956AT_DATA([input-c-glr.y],
16dc6a9e
JD
957[[%code q {}
958%code bad {}
959 %code bad {}
8e0a5e9e
JD
960%%
961start: ;
962]])
c6abeab1 963AT_BISON_CHECK([[input-c-glr.y]], [[1]], [],
4aa9d1ff
JM
964[[input-c-glr.y:1.7: %code qualifier 'q' is not used
965input-c-glr.y:2.7-9: %code qualifier 'bad' is not used
966input-c-glr.y:3.8-10: %code qualifier 'bad' is not used
08af01c2 967]])
8e0a5e9e
JD
968
969AT_DATA([input-c++.y],
16dc6a9e
JD
970[[%code q {}
971%code bad {}
972 %code q {}
8e0a5e9e
JD
973%%
974start: ;
975]])
c6abeab1 976AT_BISON_CHECK([[input-c++.y]], [[1]], [],
4aa9d1ff
JM
977[[input-c++.y:1.7: %code qualifier 'q' is not used
978input-c++.y:2.7-9: %code qualifier 'bad' is not used
979input-c++.y:3.8: %code qualifier 'q' is not used
08af01c2 980]])
8e0a5e9e
JD
981
982AT_DATA([input-c++-glr.y],
16dc6a9e
JD
983[[%code bad {}
984%code q {}
985%code q {}
8e0a5e9e
JD
986%%
987start: ;
988]])
c6abeab1 989AT_BISON_CHECK([[input-c++-glr.y]], [[1]], [],
4aa9d1ff
JM
990[[input-c++-glr.y:1.7-9: %code qualifier 'bad' is not used
991input-c++-glr.y:2.7: %code qualifier 'q' is not used
992input-c++-glr.y:3.7: %code qualifier 'q' is not used
3fc65ead
JD
993]])
994
995AT_DATA([special-char-@@.y],
16dc6a9e
JD
996[[%code bad {}
997%code q {}
998%code q {}
3fc65ead
JD
999%%
1000start: ;
1001]])
c6abeab1 1002AT_BISON_CHECK([[special-char-@@.y]], [[1]], [],
4aa9d1ff
JM
1003[[special-char-@@.y:1.7-9: %code qualifier 'bad' is not used
1004special-char-@@.y:2.7: %code qualifier 'q' is not used
1005special-char-@@.y:3.7: %code qualifier 'q' is not used
3fc65ead
JD
1006]])
1007
1008AT_DATA([special-char-@:>@.y],
16dc6a9e
JD
1009[[%code bad {}
1010%code q {}
1011%code q {}
3fc65ead
JD
1012%%
1013start: ;
1014]])
c6abeab1 1015AT_BISON_CHECK([[special-char-@:>@.y]], [[1]], [],
4aa9d1ff
JM
1016[[special-char-@:>@.y:1.7-9: %code qualifier 'bad' is not used
1017special-char-@:>@.y:2.7: %code qualifier 'q' is not used
1018special-char-@:>@.y:3.7: %code qualifier 'q' is not used
08af01c2 1019]])
8e0a5e9e
JD
1020
1021AT_CLEANUP
7eb8a0bc
JD
1022
1023
1024## ---------------- ##
1025## %define errors. ##
1026## ---------------- ##
1027
1028AT_SETUP([%define errors])
1029
0b6d43c5 1030AT_DATA([input-redefined.y],
16dc6a9e
JD
1031[[%define var "value1"
1032%define var "value1"
1033 %define var "value2"
1034%define special1 "@:>@"
1035%define special2 "@<:@"
7eb8a0bc
JD
1036%%
1037start: ;
1038]])
1039
0b6d43c5 1040AT_BISON_CHECK([[input-redefined.y]], [[1]], [],
4aa9d1ff 1041[[input-redefined.y:2.9-11: %define variable 'var' redefined
0b6d43c5 1042input-redefined.y:1.9-11: previous definition
4aa9d1ff 1043input-redefined.y:3.10-12: %define variable 'var' redefined
0b6d43c5
JD
1044input-redefined.y:2.9-11: previous definition
1045]])
1046
1047AT_DATA([input-unused.y],
1048[[%define var "value"
1049%%
1050start: ;
1051]])
1052
c6abeab1 1053AT_BISON_CHECK([[input-unused.y]], [[1]], [],
4aa9d1ff 1054[[input-unused.y:1.9-11: %define variable 'var' is not used
7eb8a0bc
JD
1055]])
1056
1057AT_CLEANUP
c1d19e10 1058
58697c6d 1059
de5ab940
JD
1060## ----------------------------------- ##
1061## %define, --define, --force-define. ##
1062## ----------------------------------- ##
58697c6d 1063
c6abeab1 1064AT_SETUP([[%define, --define, --force-define]])
de5ab940 1065
c6abeab1 1066AT_DATA([[skel.c]],
de5ab940
JD
1067[[m4@&t@_divert_push(0)@
1068@output(b4_parser_file_name@)@
1069[var-dd: ]b4_percent_define_get([[var-dd]])[
1070var-ff: ]b4_percent_define_get([[var-ff]])[
de5ab940
JD
1071var-dfg: ]b4_percent_define_get([[var-dfg]])[
1072var-fd: ]b4_percent_define_get([[var-fd]])
1073m4@&t@_divert_pop(0)
1074]])
c6abeab1 1075AT_DATA([[input.y]],
0b6d43c5 1076[[%define var-dfg "gram"
58697c6d
AD
1077%%
1078start: ;
1079]])
de5ab940
JD
1080AT_BISON_CHECK([[-Dvar-dd=cmd-d1 -Dvar-dd=cmd-d2 \
1081 -Fvar-ff=cmd-f1 -Fvar-ff=cmd-f2 \
de5ab940
JD
1082 -Dvar-dfg=cmd-d -Fvar-dfg=cmd-f \
1083 -Fvar-fd=cmd-f -Dvar-fd=cmd-d \
c6abeab1 1084 --skeleton ./skel.c input.y]])
de5ab940
JD
1085AT_CHECK([[cat input.tab.c]], [[0]],
1086[[var-dd: cmd-d2
1087var-ff: cmd-f2
de5ab940
JD
1088var-dfg: cmd-f
1089var-fd: cmd-d
58697c6d
AD
1090]])
1091
c6abeab1 1092AT_DATA([[input-dg.y]],
0b6d43c5
JD
1093[[%define var "gram"
1094%%
1095start: ;
1096]])
0b6d43c5 1097AT_BISON_CHECK([[-Dvar=cmd-d input-dg.y]], [[1]], [],
4aa9d1ff 1098[[input-dg.y:1.9-11: %define variable 'var' redefined
0b6d43c5
JD
1099<command line>:2: previous definition
1100]])
1101
c6abeab1
JD
1102AT_DATA([[input-unused.y]],
1103[[%%
1104start: ;
1105]])
1106AT_BISON_CHECK([[-Dunused-d -Funused-f input-unused.y]], [[1]], [],
4aa9d1ff
JM
1107[[<command line>:2: %define variable 'unused-d' is not used
1108<command line>:3: %define variable 'unused-f' is not used
c6abeab1
JD
1109]])
1110
58697c6d
AD
1111AT_CLEANUP
1112
c1d19e10 1113## --------------------------- ##
d782395d 1114## %define Boolean variables. ##
c1d19e10
PB
1115## --------------------------- ##
1116
d782395d 1117AT_SETUP([[%define Boolean variables]])
c1d19e10
PB
1118
1119AT_DATA([Input.y],
1120[[%language "Java"
1121%define public "maybe"
1122%define parser_class_name "Input"
1123%%
1124start: ;
1125]])
1126
da730230 1127AT_BISON_CHECK([[Input.y]], [1], [],
4aa9d1ff 1128[[Input.y:2.9-14: invalid value for %define Boolean variable 'public'
c1d19e10
PB
1129]])
1130
1131AT_CLEANUP
d782395d 1132
f4909773
JD
1133## ------------------------ ##
1134## %define enum variables. ##
1135## ------------------------ ##
7254f6a8 1136
f4909773 1137AT_SETUP([[%define enum variables]])
7254f6a8 1138
f4909773 1139# Front-end.
7254f6a8 1140AT_DATA([[input.y]],
cf499cff 1141[[%define lr.default-reductions bogus
7254f6a8
JD
1142%%
1143start: ;
1144]])
7254f6a8 1145AT_BISON_CHECK([[input.y]], [[1]], [[]],
4aa9d1ff
JM
1146[[input.y:1.9-29: invalid value for %define variable 'lr.default-reductions': 'bogus'
1147input.y:1.9-29: accepted value: 'most'
1148input.y:1.9-29: accepted value: 'consistent'
1149input.y:1.9-29: accepted value: 'accepting'
7254f6a8
JD
1150]])
1151
f4909773 1152# Back-end.
67212941 1153AT_DATA([[input.y]],
cf499cff 1154[[%define api.push-pull neither
67212941
JD
1155%%
1156start: ;
1157]])
1158AT_BISON_CHECK([[input.y]], [1], [],
4aa9d1ff
JM
1159[[input.y:1.9-21: invalid value for %define variable 'api.push-pull': 'neither'
1160input.y:1.9-21: accepted value: 'pull'
1161input.y:1.9-21: accepted value: 'push'
1162input.y:1.9-21: accepted value: 'both'
67212941
JD
1163]])
1164
1165AT_CLEANUP
1166
1167## -------------------------------- ##
1168## %define backward compatibility. ##
1169## -------------------------------- ##
1170
1171AT_SETUP([[%define backward compatibility]])
1172
1173# The error messages tell us whether underscores in these variables are
1174# being converted to dashes.
1175
d782395d 1176AT_DATA([[input.y]],
c373bf8b 1177[[%define api.push_pull "neither"
d782395d
JD
1178%%
1179start: ;
1180]])
da730230 1181AT_BISON_CHECK([[input.y]], [1], [],
4aa9d1ff
JM
1182[[input.y:1.9-21: invalid value for %define variable 'api.push-pull': 'neither'
1183input.y:1.9-21: accepted value: 'pull'
1184input.y:1.9-21: accepted value: 'push'
1185input.y:1.9-21: accepted value: 'both'
d782395d
JD
1186]])
1187
67212941 1188AT_DATA([[input.y]],
cf499cff 1189[[%define lr.keep_unreachable_states maybe
67212941
JD
1190%%
1191start: ;
1192]])
1193AT_BISON_CHECK([[input.y]], [1], [],
4aa9d1ff 1194[[input.y:1.9-34: invalid value for %define Boolean variable 'lr.keep-unreachable-states'
67212941
JD
1195]])
1196
171ad99d
AD
1197AT_DATA([[input.y]],
1198[[%define namespace "foo"
1199%define api.namespace "foo"
1200%%
1201start: ;
1202]])
1203AT_BISON_CHECK([[input.y]], [1], [],
4aa9d1ff 1204[[input.y:2.9-21: %define variable 'api.namespace' redefined
171ad99d
AD
1205input.y:1.9-17: previous definition
1206]])
1207
67212941
JD
1208AT_DATA([[input.y]],
1209[[%define foo_bar "baz"
1210%%
1211start: ;
1212]])
c6abeab1 1213AT_BISON_CHECK([[input.y]], [[1]], [],
4aa9d1ff 1214[[input.y:1.9-15: %define variable 'foo_bar' is not used
67212941
JD
1215]])
1216
d782395d 1217AT_CLEANUP
793fbca5 1218
d9df47b6
JD
1219## ------------------------- ##
1220## Unused %define api.pure. ##
1221## ------------------------- ##
1222
1223AT_SETUP([[Unused %define api.pure]])
1224
1225# AT_CHECK_API_PURE(DECLS, VALUE)
1226# -------------------------------
1227# Make sure Bison reports that `%define api.pure VALUE' is unused when DECLS
1228# are specified.
1229m4_define([AT_CHECK_API_PURE],
1230[
1231AT_DATA([[input.y]],
1232[[%define api.pure ]$2[
1233]$1[
1234%%
1235start: ;
1236]])
1237
c6abeab1 1238AT_BISON_CHECK([[input.y]], [[1]], [],
4aa9d1ff 1239[[input.y:1.9-16: %define variable 'api.pure' is not used
d9df47b6
JD
1240]])
1241])
1242
1243AT_CHECK_API_PURE([[%language "c++" %defines]], [[]])
cf499cff 1244AT_CHECK_API_PURE([[%language "c++" %defines]], [[false]])
d9df47b6 1245AT_CHECK_API_PURE([[%language "c++" %defines %glr-parser]], [[""]])
cf499cff
JD
1246AT_CHECK_API_PURE([[%language "c++" %defines %glr-parser]], [[false]])
1247AT_CHECK_API_PURE([[%language "java"]], [[true]])
1248AT_CHECK_API_PURE([[%language "java"]], [[false]])
d9df47b6
JD
1249
1250AT_CLEANUP
1251
793fbca5
JD
1252## -------------------------------- ##
1253## C++ namespace reference errors. ##
1254## -------------------------------- ##
1255
1256AT_SETUP([[C++ namespace reference errors]])
1257
1258# AT_CHECK_NAMESPACE_ERROR(NAMESPACE-DECL, ERROR, [ERROR], ...)
1259# -------------------------------------------------------------
1260# Make sure Bison reports all ERROR's for %define namespace "NAMESPACE-DECL".
1261m4_define([AT_CHECK_NAMESPACE_ERROR],
1262[
1263AT_DATA([[input.y]],
1264[[%language "C++"
1265%defines
67501061 1266%define api.namespace "]$1["
793fbca5
JD
1267%%
1268start: ;
1269]])
1270
da730230 1271AT_BISON_CHECK([[input.y]], [1], [],
793fbca5 1272[m4_foreach([b4_arg], m4_dquote(m4_shift($@)),
67501061 1273[[input.y:3.9-21: ]b4_arg[
793fbca5
JD
1274]])])
1275])
1276
1277AT_CHECK_NAMESPACE_ERROR([[]],
1278 [[namespace reference is empty]])
1279AT_CHECK_NAMESPACE_ERROR([[ ]],
1280 [[namespace reference is empty]])
1281AT_CHECK_NAMESPACE_ERROR([[foo::::bar]],
1282 [[namespace reference has consecutive "::"]])
1283AT_CHECK_NAMESPACE_ERROR([[foo:: ::bar]],
1284 [[namespace reference has consecutive "::"]])
1285AT_CHECK_NAMESPACE_ERROR([[::::bar]],
1286 [[namespace reference has consecutive "::"]])
1287AT_CHECK_NAMESPACE_ERROR([[:: ::bar]],
1288 [[namespace reference has consecutive "::"]])
1289AT_CHECK_NAMESPACE_ERROR([[foo::bar:: ::]],
1290 [[namespace reference has consecutive "::"]],
1291 [[namespace reference has a trailing "::"]])
1292AT_CHECK_NAMESPACE_ERROR([[foo::bar::]],
1293 [[namespace reference has a trailing "::"]])
1294AT_CHECK_NAMESPACE_ERROR([[foo::bar:: ]],
1295 [[namespace reference has a trailing "::"]])
1296AT_CHECK_NAMESPACE_ERROR([[::]],
1297 [[namespace reference has a trailing "::"]])
1298
1299AT_CLEANUP
3208e3f4
JD
1300
1301## ------------------------ ##
1302## Bad character literals. ##
1303## ------------------------ ##
1304
1305# Bison used to accept character literals that were empty or contained
1306# too many characters.
1307
b70c7fb4
JD
1308# FIXME: AT_DATA or some variant of AT_DATA may eventually permit
1309# the final newline to be omitted. See the threads starting at
3208e3f4
JD
1310# <http://lists.gnu.org/archive/html/bison-patches/2009-07/msg00019.html>.
1311
1312AT_SETUP([[Bad character literals]])
1313
1314AT_DATA([empty.y],
1315[[%%
1316start: '';
1317start: '
1318]])
b70c7fb4 1319AT_CHECK([[perl -e "print 'start: \'';" >> empty.y || exit 77]])
3208e3f4
JD
1320
1321AT_BISON_CHECK([empty.y], [1], [],
73370a9d
VS
1322[[empty.y:2.8-9: warning: empty character literal [-Wother]
1323empty.y:3.8-4.0: warning: empty character literal [-Wother]
4a9cd8f2 1324empty.y:3.8-4.0: missing "'" at end of line
73370a9d 1325empty.y:4.8: warning: empty character literal [-Wother]
4a9cd8f2 1326empty.y:4.8: missing "'" at end of file
3208e3f4
JD
1327]])
1328
1329AT_DATA([two.y],
1330[[%%
1331start: 'ab';
1332start: 'ab
1333]])
b70c7fb4 1334AT_CHECK([[perl -e "print 'start: \'ab';" >> two.y || exit 77]])
3208e3f4
JD
1335
1336AT_BISON_CHECK([two.y], [1], [],
73370a9d
VS
1337[[two.y:2.8-11: warning: extra characters in character literal [-Wother]
1338two.y:3.8-4.0: warning: extra characters in character literal [-Wother]
4a9cd8f2 1339two.y:3.8-4.0: missing "'" at end of line
73370a9d 1340two.y:4.8-10: warning: extra characters in character literal [-Wother]
4a9cd8f2 1341two.y:4.8-10: missing "'" at end of file
3208e3f4
JD
1342]])
1343
1344AT_DATA([three.y],
1345[[%%
1346start: 'abc';
1347start: 'abc
1348]])
b70c7fb4 1349AT_CHECK([[perl -e "print 'start: \'abc';" >> three.y || exit 77]])
3208e3f4
JD
1350
1351AT_BISON_CHECK([three.y], [1], [],
73370a9d
VS
1352[[three.y:2.8-12: warning: extra characters in character literal [-Wother]
1353three.y:3.8-4.0: warning: extra characters in character literal [-Wother]
4a9cd8f2 1354three.y:3.8-4.0: missing "'" at end of line
73370a9d 1355three.y:4.8-11: warning: extra characters in character literal [-Wother]
4a9cd8f2 1356three.y:4.8-11: missing "'" at end of file
3208e3f4
JD
1357]])
1358
1359AT_CLEANUP
c2724603
JD
1360
1361## ------------------------- ##
1362## Bad escapes in literals. ##
1363## ------------------------- ##
1364
1365AT_SETUP([[Bad escapes in literals]])
1366
1367AT_DATA([input.y],
1368[[%%
1369start: '\777' '\0' '\xfff' '\x0'
1370 '\uffff' '\u0000' '\Uffffffff' '\U00000000'
1371 '\ ' '\A';
1372]])
3bed3a75 1373
b70c7fb4 1374# It is not easy to create special characters, we cannot even trust tr.
3bed3a75
AD
1375# Beside we cannot even expect "echo '\0'" to output two characters
1376# (well three with \n): at least Bash 3.2 converts the two-character
1377# sequence "\0" into a single NUL character.
b70c7fb4
JD
1378AT_CHECK([[perl -e 'print "start: \"\\\t\\\f\\\0\\\1\" ;";' >> input.y \
1379 || exit 77]])
c2724603
JD
1380
1381AT_BISON_CHECK([input.y], [1], [],
1382[[input.y:2.9-12: invalid number after \-escape: 777
73370a9d 1383input.y:2.8-13: warning: empty character literal [-Wother]
c2724603 1384input.y:2.16-17: invalid number after \-escape: 0
73370a9d 1385input.y:2.15-18: warning: empty character literal [-Wother]
c2724603 1386input.y:2.21-25: invalid number after \-escape: xfff
73370a9d 1387input.y:2.20-26: warning: empty character literal [-Wother]
c2724603 1388input.y:2.29-31: invalid number after \-escape: x0
73370a9d 1389input.y:2.28-32: warning: empty character literal [-Wother]
c2724603 1390input.y:3.9-14: invalid number after \-escape: uffff
73370a9d 1391input.y:3.8-15: warning: empty character literal [-Wother]
c2724603 1392input.y:3.18-23: invalid number after \-escape: u0000
73370a9d 1393input.y:3.17-24: warning: empty character literal [-Wother]
c2724603 1394input.y:3.27-36: invalid number after \-escape: Uffffffff
73370a9d 1395input.y:3.26-37: warning: empty character literal [-Wother]
c2724603 1396input.y:3.40-49: invalid number after \-escape: U00000000
73370a9d 1397input.y:3.39-50: warning: empty character literal [-Wother]
ae93e4e4 1398input.y:4.9-10: invalid character after \-escape: ' '
73370a9d 1399input.y:4.8-11: warning: empty character literal [-Wother]
c2724603 1400input.y:4.14-15: invalid character after \-escape: A
73370a9d 1401input.y:4.13-16: warning: empty character literal [-Wother]
c2724603
JD
1402input.y:5.9-16: invalid character after \-escape: \t
1403input.y:5.17: invalid character after \-escape: \f
1404input.y:5.18: invalid character after \-escape: \0
1405input.y:5.19: invalid character after \-escape: \001
1406]])
1407
1408AT_CLEANUP
bf35c71c
JD
1409
1410## ------------------------- ##
1411## LAC: Errors for %define. ##
1412## ------------------------- ##
1413
1414AT_SETUP([[LAC: Errors for %define]])
1415
1416AT_DATA([[input.y]],
1417[[%%
1418start: ;
1419]])
1420
1421# parse.lac.* options are useless if LAC isn't actually activated.
1422AT_BISON_CHECK([[-Dparse.lac.es-capacity-initial=1 input.y]],
1423 [[1]], [],
4aa9d1ff 1424[[<command line>:2: %define variable 'parse.lac.es-capacity-initial' is not used
bf35c71c 1425]])
107844a3
JD
1426AT_BISON_CHECK([[-Dparse.lac.memory-trace=full input.y]],
1427 [[1]], [],
4aa9d1ff 1428[[<command line>:2: %define variable 'parse.lac.memory-trace' is not used
107844a3 1429]])
bf35c71c
JD
1430
1431AT_CLEANUP
bf0e44e8
JD
1432
1433## --------------------------------------------- ##
1434## -Werror is not affected by -Wnone and -Wall. ##
1435## --------------------------------------------- ##
1436
1437AT_SETUP([[-Werror is not affected by -Wnone and -Wall]])
1438
1439AT_DATA([[input.y]],
1440[[%%
1441foo-bar: ;
1442]])
1443
1444# -Werror is not enabled by -Wall or equivalent.
1445AT_BISON_CHECK([[-Wall input.y]], [[0]], [[]],
73370a9d 1446[[input.y:2.1-7: warning: POSIX Yacc forbids dashes in symbol names: foo-bar [-Wyacc]
bf0e44e8
JD
1447]])
1448AT_BISON_CHECK([[-W input.y]], [[0]], [[]],
73370a9d 1449[[input.y:2.1-7: warning: POSIX Yacc forbids dashes in symbol names: foo-bar [-Wyacc]
bf0e44e8
JD
1450]])
1451AT_BISON_CHECK([[-Wno-none input.y]], [[0]], [[]],
73370a9d 1452[[input.y:2.1-7: warning: POSIX Yacc forbids dashes in symbol names: foo-bar [-Wyacc]
bf0e44e8
JD
1453]])
1454
1455# -Werror is not disabled by -Wnone or equivalent.
1456AT_BISON_CHECK([[-Werror,none,yacc input.y]], [[1]], [[]], [[stderr]])
1457AT_CHECK([[sed 's/^.*bison:/bison:/' stderr]], [[0]],
1458[[bison: warnings being treated as errors
73370a9d 1459input.y:2.1-7: warning: POSIX Yacc forbids dashes in symbol names: foo-bar [-Wyacc]
bf0e44e8
JD
1460]])
1461[mv stderr experr]
1462AT_BISON_CHECK([[-Werror,no-all,yacc input.y]], [[1]], [[]], [[experr]])
1463
1464AT_CLEANUP
32ae07ef
AD
1465
1466
1467## ------------------------------------------------------ ##
1468## %name-prefix and %define api.prefix are incompatible. ##
1469## ------------------------------------------------------ ##
1470
1471AT_SETUP([[%name-prefix and %define api.prefix are incompatible]])
1472
1473# AT_TEST(DIRECTIVES, OPTIONS, ERROR-LOCATION)
1474# --------------------------------------------
1475m4_pushdef([AT_TEST],
1476[AT_DATA([[input.y]],
1477[[$1
1478%%
1479exp:;
1480]])
1481AT_BISON_CHECK([[$2 input.y]], [[1]], [[]],
1482[[$3: '%name-prefix' and '%define api.prefix' cannot be used together
1483]])
1484])
1485
1486AT_TEST([%define api.prefix foo %name-prefix "bar"], [], [input.y:1.9-18])
1487AT_TEST([], [-Dapi.prefix=foo -p bar], [<command line>:2])
1488AT_TEST([%name-prefix "bar"], [-Dapi.prefix=foo], [<command line>:2])
1489AT_TEST([%define api.prefix foo], [-p bar], [input.y:1.9-18])
1490
1491m4_popdef([AT_TEST])
1492
1493AT_CLEANUP