]> git.saurik.com Git - bison.git/blame - tests/input.at
doc: use @group to improve page breaking
[bison.git] / tests / input.at
CommitLineData
087b9fdf 1# Checking the Bison scanner. -*- Autotest -*-
7d424de1 2
7d6bad19 3# Copyright (C) 2002-2013 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
baf0bd61
AD
23## ---------------- ##
24## Invalid inputs. ##
25## ---------------- ##
26
27AT_SETUP([Invalid inputs])
28
29AT_DATA([input.y],
95066e92
AD
30[[\000\001\002\377?
31%%
baf0bd61
AD
32?
33default: 'a' }
34%&
35%a-does-not-exist
36%-
37%{
38]])
95066e92 39AT_CHECK([[$PERL -pi -e 's/\\(\d{3})/chr(oct($1))/ge' input.y || exit 77]])
baf0bd61
AD
40
41AT_BISON_CHECK([input.y], [1], [],
68ac70bc 42[[input.y:1.1-2: error: invalid characters: '\0\001\002\377?'
04901623
AD
43input.y:3.1: error: invalid character: '?'
44input.y:4.14: error: invalid character: '}'
45input.y:5.1: error: invalid character: '%'
46input.y:5.2: error: invalid character: '&'
47input.y:6.1-17: error: invalid directive: '%a-does-not-exist'
48input.y:7.1: error: invalid character: '%'
49input.y:7.2: error: invalid character: '-'
50input.y:8.1-9.0: error: missing '%}' at end of file
51input.y:8.1-9.0: error: syntax error, unexpected %{...%}
baf0bd61
AD
52]])
53
54AT_CLEANUP
55
56
57AT_SETUP([Invalid inputs with {}])
58
59# We used to SEGV here. See
60# http://lists.gnu.org/archive/html/bug-bison/2005-07/msg00053.html
61
62AT_DATA([input.y],
63[[
64%destructor
65%initial-action
66%lex-param
67%parse-param
68%printer
69%union
70]])
71
72AT_BISON_CHECK([input.y], [1], [],
04901623 73[[input.y:3.1-15: error: syntax error, unexpected %initial-action, expecting {...}
baf0bd61
AD
74]])
75
76AT_CLEANUP
77
78
79
9b2d0677
AD
80## ------------ ##
81## Invalid $n. ##
82## ------------ ##
83
287b314e 84AT_SETUP([Invalid $n and @n])
9b2d0677
AD
85
86AT_DATA([input.y],
87[[%%
bfcf1f3a 88exp: { $$ = $1 ; };
bfcf1f3a 89exp: { @$ = @1 ; };
9b2d0677
AD
90]])
91
0242bf04 92AT_BISON_CHECK([-fcaret input.y], [1], [],
b8e7ad58 93[[input.y:2.13-14: error: integer out of range: '$1'
0242bf04
TR
94 exp: { $$ = $1 ; };
95 ^^
b8e7ad58 96input.y:3.13-14: error: integer out of range: '@1'
0242bf04
TR
97 exp: { @$ = @1 ; };
98 ^^
9b2d0677
AD
99]])
100
101AT_CLEANUP
9af3fbce
AD
102
103
104## -------------- ##
e776192e 105## Type Clashes. ##
9af3fbce
AD
106## -------------- ##
107
e776192e 108AT_SETUP([Type Clashes])
9af3fbce
AD
109
110AT_DATA([input.y],
ffa4ba3a
JD
111[[%union { int bar; }
112%token foo
9af3fbce
AD
113%type <bar> exp
114%%
ffa4ba3a 115exp: foo { $$; } foo { $2; } foo
9af3fbce 116 | foo
c7442984 117 | /* empty. */
9af3fbce
AD
118 ;
119]])
120
0242bf04 121AT_BISON_CHECK([-fcaret input.y], [1], [],
b8e7ad58 122[[input.y:5.12-13: error: $$ for the midrule at $2 of 'exp' has no declared type
0242bf04
TR
123 exp: foo { $$; } foo { $2; } foo
124 ^^
b8e7ad58 125input.y:5.24-25: error: $2 of 'exp' has no declared type
0242bf04
TR
126 exp: foo { $$; } foo { $2; } foo
127 ^^
73370a9d 128input.y:5.6-32: warning: type clash on default action: <bar> != <> [-Wother]
0242bf04
TR
129 exp: foo { $$; } foo { $2; } foo
130 ^^^^^^^^^^^^^^^^^^^^^^^^^^^
73370a9d 131input.y:6.6-8: warning: type clash on default action: <bar> != <> [-Wother]
0242bf04
TR
132 | foo
133 ^^^
73370a9d 134input.y:7.5: warning: empty rule for typed nonterminal, and no action [-Wother]
c7442984 135 | /* empty. */
0242bf04 136 ^
9af3fbce
AD
137]])
138
139AT_CLEANUP
5a08f1ce
AD
140
141
ffa4ba3a 142# _AT_UNUSED_VALUES_DECLARATIONS()
dab244d5 143# --------------------------------
ffa4ba3a
JD
144# Generate the token, type, and destructor
145# declarations for the unused values tests.
ffa4ba3a
JD
146m4_define([_AT_UNUSED_VALUES_DECLARATIONS],
147[[[%token <integer> INT;
148%type <integer> a b c d e f g h i j k l;
149%destructor { destroy ($$); } INT a b c d e f g h i j k l;]]])
378f4bd8 150
ffa4ba3a 151
17bd8a73 152# AT_CHECK_UNUSED_VALUES(DECLARATIONS_AFTER, CHECK_MIDRULE_VALUES)
dab244d5
AD
153# ----------------------------------------------------------------
154# Generate a grammar to test unused values, compile it, run it. If
155# DECLARATIONS_AFTER is set, then the token, type, and destructor
156# declarations are generated after the rules rather than before. If
157# CHECK_MIDRULE_VALUES is set, then --warnings=midrule-values is set.
ffa4ba3a
JD
158m4_define([AT_CHECK_UNUSED_VALUES],
159[AT_DATA([input.y],
160m4_ifval($1, [
161
162
163], [_AT_UNUSED_VALUES_DECLARATIONS
164])[[%%
27622431 165start:
e8cd1ad6
DJ
166 'a' a { $]2[; } | 'b' b { $]2[; } | 'c' c { $]2[; } | 'd' d { $]2[; }
167| 'e' e { $]2[; } | 'f' f { $]2[; } | 'g' g { $]2[; } | 'h' h { $]2[; }
168| 'i' i { $]2[; } | 'j' j { $]2[; } | 'k' k { $]2[; } | 'l' l { $]2[; }
378f4bd8 169;
27622431
PE
170
171a: INT | INT { } INT { } INT { };
172b: INT | /* empty */;
e8cd1ad6
DJ
173c: INT | INT { $]1[; } INT { $<integer>2; } INT { $<integer>4; };
174d: INT | INT { } INT { $]1[; } INT { $<integer>2; };
175e: INT | INT { } INT { } INT { $]1[; };
ffa4ba3a 176f: INT | INT { } INT { } INT { $]$[ = $]1[ + $]3[ + $]5[; };
ddc8ede1
PE
177g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
178h: INT | INT { $<integer>$; } INT { $<integer>$ = $<integer>2; } INT { };
ffa4ba3a
JD
179i: INT | INT INT { } { $]$[ = $]1[ + $]2[; };
180j: INT | INT INT { $<integer>$ = 1; } { $]$[ = $]1[ + $]2[; };
ddc8ede1
PE
181k: INT | INT INT { $<integer>$; } { $<integer>$ = $<integer>3; } { };
182l: INT | INT { $<integer>$ = $<integer>1; } INT { $<integer>$ = $<integer>2 + $<integer>3; } INT { $<integer>$ = $<integer>4 + $<integer>5; };]]m4_ifval($1, [
ffa4ba3a
JD
183_AT_UNUSED_VALUES_DECLARATIONS])
184)
185
23589235
AD
186AT_BISON_CHECK(m4_ifval($2, [--warnings=midrule-values ])[-fcaret input.y],
187 [0], [],
0906b12c 188[[input.y:11.10-32: warning: unset value: $][$ [-Wother]
23589235
AD
189 a: INT | INT { } INT { } INT { };
190 ^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 191input.y:11.10-12: warning: unused value: $][1 [-Wother]
23589235
AD
192 a: INT | INT { } INT { } INT { };
193 ^^^
0906b12c 194input.y:11.18-20: warning: unused value: $][3 [-Wother]
23589235
AD
195 a: INT | INT { } INT { } INT { };
196 ^^^
0906b12c 197input.y:11.26-28: warning: unused value: $][5 [-Wother]
23589235
AD
198 a: INT | INT { } INT { } INT { };
199 ^^^
73370a9d 200input.y:12.9: warning: empty rule for typed nonterminal, and no action [-Wother]
23589235
AD
201 b: INT | /* empty */;
202 ^
0906b12c 203]]m4_ifval($2, [[[input.y:13.14-20: warning: unset value: $][$ [-Wmidrule-values]
23589235
AD
204 c: INT | INT { $][1; } INT { $<integer>2; } INT { $<integer>4; };
205 ^^^^^^^
0906b12c 206input.y:13.26-41: warning: unset value: $][$ [-Wmidrule-values]
23589235
AD
207 c: INT | INT { $][1; } INT { $<integer>2; } INT { $<integer>4; };
208 ^^^^^^^^^^^^^^^^
0906b12c 209]]])[[input.y:13.10-62: warning: unset value: $][$ [-Wother]
23589235
AD
210 c: INT | INT { $][1; } INT { $<integer>2; } INT { $<integer>4; };
211 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 212input.y:13.22-24: warning: unused value: $][3 [-Wother]
23589235
AD
213 c: INT | INT { $][1; } INT { $<integer>2; } INT { $<integer>4; };
214 ^^^
0906b12c 215input.y:13.43-45: warning: unused value: $][5 [-Wother]
23589235
AD
216 c: INT | INT { $][1; } INT { $<integer>2; } INT { $<integer>4; };
217 ^^^
0906b12c 218]]m4_ifval($2, [[[input.y:14.14-16: warning: unset value: $][$ [-Wmidrule-values]
23589235
AD
219 d: INT | INT { } INT { $][1; } INT { $<integer>2; };
220 ^^^
0906b12c 221]]])[[input.y:14.10-49: warning: unset value: $][$ [-Wother]
23589235
AD
222 d: INT | INT { } INT { $][1; } INT { $<integer>2; };
223 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 224input.y:14.18-20: warning: unused value: $][3 [-Wother]
23589235
AD
225 d: INT | INT { } INT { $][1; } INT { $<integer>2; };
226 ^^^
0906b12c 227input.y:14.30-32: warning: unused value: $][5 [-Wother]
23589235
AD
228 d: INT | INT { } INT { $][1; } INT { $<integer>2; };
229 ^^^
0906b12c 230input.y:15.10-37: warning: unset value: $][$ [-Wother]
23589235
AD
231 e: INT | INT { } INT { } INT { $][1; };
232 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 233input.y:15.18-20: warning: unused value: $][3 [-Wother]
23589235
AD
234 e: INT | INT { } INT { } INT { $][1; };
235 ^^^
0906b12c 236input.y:15.27-29: warning: unused value: $][5 [-Wother]
23589235
AD
237 e: INT | INT { } INT { } INT { $][1; };
238 ^^^
0906b12c 239input.y:17.10-58: warning: unset value: $][$ [-Wother]
23589235
AD
240 g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
241 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 242input.y:17.10-12: warning: unused value: $][1 [-Wother]
23589235
AD
243 g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
244 ^^^
0906b12c 245]]m4_ifval($2, [[[input.y:17.14-29: warning: unused value: $][2 [-Wmidrule-values]
23589235
AD
246 g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
247 ^^^^^^^^^^^^^^^^
0906b12c 248]]])[[input.y:17.31-33: warning: unused value: $][3 [-Wother]
23589235
AD
249 g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
250 ^^^
0906b12c 251]]m4_ifval($2, [[[input.y:17.35-50: warning: unused value: $][4 [-Wmidrule-values]
23589235
AD
252 g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
253 ^^^^^^^^^^^^^^^^
0906b12c 254]]])[[input.y:17.52-54: warning: unused value: $][5 [-Wother]
23589235
AD
255 g: INT | INT { $<integer>$; } INT { $<integer>$; } INT { };
256 ^^^
0906b12c 257input.y:18.10-72: warning: unset value: $][$ [-Wother]
23589235
AD
258 h: INT | INT { $<integer>$; } INT { $<integer>$ = $<integer>2; } INT { };
259 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 260input.y:18.10-12: warning: unused value: $][1 [-Wother]
23589235
AD
261 h: INT | INT { $<integer>$; } INT { $<integer>$ = $<integer>2; } INT { };
262 ^^^
0906b12c 263input.y:18.31-33: warning: unused value: $][3 [-Wother]
23589235
AD
264 h: INT | INT { $<integer>$; } INT { $<integer>$ = $<integer>2; } INT { };
265 ^^^
0906b12c 266]]m4_ifval($2, [[[input.y:18.35-64: warning: unused value: $][4 [-Wmidrule-values]
23589235
AD
267 h: INT | INT { $<integer>$; } INT { $<integer>$ = $<integer>2; } INT { };
268 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 269]]])[[input.y:18.66-68: warning: unused value: $][5 [-Wother]
23589235
AD
270 h: INT | INT { $<integer>$; } INT { $<integer>$ = $<integer>2; } INT { };
271 ^^^
0906b12c 272]]m4_ifval($2, [[[input.y:20.18-37: warning: unused value: $][3 [-Wmidrule-values]
23589235
AD
273 j: INT | INT INT { $<integer>$ = 1; } { $][$ = $][1 + $][2; };
274 ^^^^^^^^^^^^^^^^^^^^
0906b12c 275]]])[[input.y:21.10-68: warning: unset value: $][$ [-Wother]
23589235
AD
276 k: INT | INT INT { $<integer>$; } { $<integer>$ = $<integer>3; } { };
277 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 278input.y:21.10-12: warning: unused value: $][1 [-Wother]
23589235
AD
279 k: INT | INT INT { $<integer>$; } { $<integer>$ = $<integer>3; } { };
280 ^^^
0906b12c 281input.y:21.14-16: warning: unused value: $][2 [-Wother]
23589235
AD
282 k: INT | INT INT { $<integer>$; } { $<integer>$ = $<integer>3; } { };
283 ^^^
0906b12c 284]]m4_ifval($2, [[[input.y:21.35-64: warning: unused value: $][4 [-Wmidrule-values]
23589235
AD
285 k: INT | INT INT { $<integer>$; } { $<integer>$ = $<integer>3; } { };
286 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
287]]]))
288])
378f4bd8 289
ffa4ba3a
JD
290## --------------- ##
291## Unused values. ##
292## --------------- ##
293
294AT_SETUP([Unused values])
295AT_CHECK_UNUSED_VALUES
17bd8a73 296AT_CHECK_UNUSED_VALUES(, [1])
ffa4ba3a
JD
297AT_CLEANUP
298
299
300## ------------------------------------------ ##
301## Unused values before symbol declarations. ##
302## ------------------------------------------ ##
84866159 303
ffa4ba3a
JD
304AT_SETUP([Unused values before symbol declarations])
305AT_CHECK_UNUSED_VALUES([1])
17bd8a73 306AT_CHECK_UNUSED_VALUES([1], [1])
84866159 307AT_CLEANUP
378f4bd8
AD
308
309
ec5479ce
JD
310## --------------------------------------------- ##
311## Default %printer and %destructor redeclared. ##
312## --------------------------------------------- ##
313
314AT_SETUP([Default %printer and %destructor redeclared])
315
316AT_DATA([[input.y]],
12e35840 317[[%destructor { destroy ($$); } <*> <*>
abcd36ca 318%printer { print ($$); } <*> <*>
ec5479ce 319
12e35840 320%destructor { destroy ($$); } <*>
abcd36ca 321%printer { print ($$); } <*>
12e35840 322
3ebecc24 323%destructor { destroy ($$); } <> <>
abcd36ca 324%printer { print ($$); } <> <>
12e35840 325
3ebecc24 326%destructor { destroy ($$); } <>
abcd36ca 327%printer { print ($$); } <>
ec5479ce
JD
328
329%%
330
331start: ;
332
12e35840 333%destructor { destroy ($$); } <*>;
abcd36ca 334%printer { print ($$); } <*>;
12e35840 335
3ebecc24 336%destructor { destroy ($$); } <>;
abcd36ca 337%printer { print ($$); } <>;
ec5479ce
JD
338]])
339
0242bf04 340AT_BISON_CHECK([-fcaret input.y], [1], [],
11b19212 341[[input.y:1.13-29: error: %destructor redeclaration for <*>
0242bf04
TR
342 %destructor { destroy ($$); } <*> <*>
343 ^^^^^^^^^^^^^^^^^
cbaea010 344input.y:1.13-29: previous declaration
0242bf04
TR
345 %destructor { destroy ($$); } <*> <*>
346 ^^^^^^^^^^^^^^^^^
11b19212 347input.y:2.10-24: error: %printer redeclaration for <*>
0242bf04
TR
348 %printer { print ($$); } <*> <*>
349 ^^^^^^^^^^^^^^^
cbaea010 350input.y:2.10-24: previous declaration
0242bf04
TR
351 %printer { print ($$); } <*> <*>
352 ^^^^^^^^^^^^^^^
11b19212 353input.y:4.13-29: error: %destructor redeclaration for <*>
0242bf04
TR
354 %destructor { destroy ($$); } <*>
355 ^^^^^^^^^^^^^^^^^
cbaea010 356input.y:1.13-29: previous declaration
0242bf04
TR
357 %destructor { destroy ($$); } <*> <*>
358 ^^^^^^^^^^^^^^^^^
11b19212 359input.y:5.10-24: error: %printer redeclaration for <*>
0242bf04
TR
360 %printer { print ($$); } <*>
361 ^^^^^^^^^^^^^^^
cbaea010 362input.y:2.10-24: previous declaration
0242bf04
TR
363 %printer { print ($$); } <*> <*>
364 ^^^^^^^^^^^^^^^
11b19212 365input.y:7.13-29: error: %destructor redeclaration for <>
0242bf04
TR
366 %destructor { destroy ($$); } <> <>
367 ^^^^^^^^^^^^^^^^^
cbaea010 368input.y:7.13-29: previous declaration
0242bf04
TR
369 %destructor { destroy ($$); } <> <>
370 ^^^^^^^^^^^^^^^^^
11b19212 371input.y:8.10-24: error: %printer redeclaration for <>
0242bf04
TR
372 %printer { print ($$); } <> <>
373 ^^^^^^^^^^^^^^^
cbaea010 374input.y:8.10-24: previous declaration
0242bf04
TR
375 %printer { print ($$); } <> <>
376 ^^^^^^^^^^^^^^^
11b19212 377input.y:10.13-29: error: %destructor redeclaration for <>
0242bf04
TR
378 %destructor { destroy ($$); } <>
379 ^^^^^^^^^^^^^^^^^
cbaea010 380input.y:7.13-29: previous declaration
0242bf04
TR
381 %destructor { destroy ($$); } <> <>
382 ^^^^^^^^^^^^^^^^^
11b19212 383input.y:11.10-24: error: %printer redeclaration for <>
0242bf04
TR
384 %printer { print ($$); } <>
385 ^^^^^^^^^^^^^^^
cbaea010 386input.y:8.10-24: previous declaration
0242bf04
TR
387 %printer { print ($$); } <> <>
388 ^^^^^^^^^^^^^^^
11b19212 389input.y:17.13-29: error: %destructor redeclaration for <*>
0242bf04
TR
390 %destructor { destroy ($$); } <*>;
391 ^^^^^^^^^^^^^^^^^
cbaea010 392input.y:4.13-29: previous declaration
0242bf04
TR
393 %destructor { destroy ($$); } <*>
394 ^^^^^^^^^^^^^^^^^
11b19212 395input.y:18.10-24: error: %printer redeclaration for <*>
0242bf04
TR
396 %printer { print ($$); } <*>;
397 ^^^^^^^^^^^^^^^
cbaea010 398input.y:5.10-24: previous declaration
0242bf04
TR
399 %printer { print ($$); } <*>
400 ^^^^^^^^^^^^^^^
11b19212 401input.y:20.13-29: error: %destructor redeclaration for <>
0242bf04
TR
402 %destructor { destroy ($$); } <>;
403 ^^^^^^^^^^^^^^^^^
cbaea010 404input.y:10.13-29: previous declaration
0242bf04
TR
405 %destructor { destroy ($$); } <>
406 ^^^^^^^^^^^^^^^^^
11b19212 407input.y:21.10-24: error: %printer redeclaration for <>
0242bf04
TR
408 %printer { print ($$); } <>;
409 ^^^^^^^^^^^^^^^
cbaea010 410input.y:11.10-24: previous declaration
0242bf04
TR
411 %printer { print ($$); } <>
412 ^^^^^^^^^^^^^^^
ec5479ce
JD
413]])
414
415AT_CLEANUP
416
417
b2a0b7ca
JD
418## ---------------------------------------------- ##
419## Per-type %printer and %destructor redeclared. ##
420## ---------------------------------------------- ##
421
422AT_SETUP([Per-type %printer and %destructor redeclared])
423
424AT_DATA([[input.y]],
425[[%destructor { destroy ($$); } <field1> <field2>
abcd36ca 426%printer { print ($$); } <field1> <field2>
b2a0b7ca
JD
427
428%destructor { destroy ($$); } <field1> <field1>
abcd36ca 429%printer { print ($$); } <field2> <field2>
b2a0b7ca
JD
430
431%%
432
433start: ;
434
435%destructor { destroy ($$); } <field2> <field1>;
abcd36ca 436%printer { print ($$); } <field2> <field1>;
b2a0b7ca
JD
437]])
438
da730230 439AT_BISON_CHECK([input.y], [1], [],
b8e7ad58 440[[input.y:4.13-29: error: %destructor redeclaration for <field1>
cbaea010 441input.y:1.13-29: previous declaration
b8e7ad58 442input.y:4.13-29: error: %destructor redeclaration for <field1>
cbaea010 443input.y:4.13-29: previous declaration
b8e7ad58 444input.y:5.10-24: error: %printer redeclaration for <field2>
cbaea010 445input.y:2.10-24: previous declaration
b8e7ad58 446input.y:5.10-24: error: %printer redeclaration for <field2>
cbaea010 447input.y:5.10-24: previous declaration
b8e7ad58 448input.y:11.13-29: error: %destructor redeclaration for <field2>
cbaea010 449input.y:1.13-29: previous declaration
93561c21
VT
450input.y:11.13-29: error: %destructor redeclaration for <field1>
451input.y:4.13-29: previous declaration
b8e7ad58 452input.y:12.10-24: error: %printer redeclaration for <field2>
cbaea010 453input.y:5.10-24: previous declaration
93561c21
VT
454input.y:12.10-24: error: %printer redeclaration for <field1>
455input.y:2.10-24: previous declaration
b2a0b7ca
JD
456]])
457
458AT_CLEANUP
459
31557b9e
AD
460## ------------------- ##
461## Undefined symbols. ##
462## ------------------- ##
b921d92f 463
31557b9e 464AT_SETUP([Undefined symbols])
b921d92f
VS
465
466AT_DATA([[input.y]],
3b0b682f
AD
467[[%printer {} foo baz
468%destructor {} bar
31557b9e 469%type <foo> qux
b921d92f 470%%
3b0b682f 471exp: bar;
b921d92f
VS
472]])
473
0242bf04 474AT_BISON_CHECK([-fcaret input.y], [1], [],
11b19212 475[[input.y:2.16-18: error: symbol bar is used, but is not defined as a token and has no rules
0242bf04
TR
476 %destructor {} bar
477 ^^^
73370a9d 478input.y:1.17-19: warning: symbol baz is used, but is not defined as a token and has no rules [-Wother]
0242bf04
TR
479 %printer {} foo baz
480 ^^^
73370a9d 481input.y:1.13-15: warning: symbol foo is used, but is not defined as a token and has no rules [-Wother]
0242bf04
TR
482 %printer {} foo baz
483 ^^^
31557b9e 484input.y:3.13-15: warning: symbol qux is used, but is not defined as a token and has no rules [-Wother]
0242bf04
TR
485 %type <foo> qux
486 ^^^
b921d92f
VS
487]])
488
489AT_CLEANUP
490
b2a0b7ca 491
9641b918
VS
492## ----------------------------------------------------- ##
493## Unassociated types used for a printer or destructor. ##
494## ----------------------------------------------------- ##
495
496AT_SETUP([Unassociated types used for a printer or destructor])
497
498AT_DATA([[input.y]],
499[[%token <type1> tag1
500%type <type2> tag2
501
502%printer { } <type1> <type3>
503%destructor { } <type2> <type4>
504
505%%
506
507exp: tag1 { $1; }
508 | tag2 { $1; }
509
510tag2: "a" { $$; }
511]])
512
513AT_BISON_CHECK([input.y], [0], [],
73370a9d
VS
514[[input.y:4.22-28: warning: type <type3> is used, but is not associated to any symbol [-Wother]
515input.y:5.25-31: warning: type <type4> is used, but is not associated to any symbol [-Wother]
9641b918
VS
516]])
517
518AT_CLEANUP
519
520
ea9a35c6
VS
521## --------------------------------- ##
522## Useless printers or destructors. ##
523## --------------------------------- ##
524
525AT_SETUP([Useless printers or destructors])
526
9534d2be
AD
527# AT_TEST([INPUT], [STDERR])
528# --------------------------
529m4_pushdef([AT_TEST],
530[AT_DATA([[input.y]],
531[$1
532])
533AT_BISON_CHECK([input.y], [0], [], [$2
534])])
535
536AT_TEST([[%token <type1> token1
ea9a35c6
VS
537%token <type2> token2
538%token <type3> token3
539%token <type4> token4
540%token <type5> token51 token52
541%token <type6> token61 token62
542%token <type7> token7
543
544%printer {} token1
545%destructor {} token2
546%printer {} token51
547%destructor {} token61
548
549%printer {} token7
550
551%printer {} <type1>
552%destructor {} <type2>
553%printer {} <type3>
554%destructor {} <type4>
555
556%printer {} <type5>
557%destructor {} <type6>
558
559%destructor {} <type7>
560
561%%
9534d2be 562exp: "a";]],
73370a9d 563[[input.y:16.13-19: warning: useless %printer for type <type1> [-Wother]
9534d2be
AD
564input.y:17.16-22: warning: useless %destructor for type <type2> [-Wother]]])
565
566# If everybody is typed, <> is useless.
567AT_TEST([[%type <type> exp
568%token <type> a
569%printer {} <> <*>
570%%
571exp: a;]],
572[[input.y:3.13-14: warning: useless %printer for type <> [-Wother]]])
573
84271837 574# If nobody is typed, <*> is useless.
9534d2be
AD
575AT_TEST([[%token a
576%printer {} <> <*>
577%%
578exp: a;]],
579[[input.y:2.16-18: warning: useless %printer for type <*> [-Wother]]])
ea9a35c6 580
9534d2be 581m4_popdef([AT_TEST])
ea9a35c6
VS
582
583AT_CLEANUP
584
585
ec5479ce
JD
586## ---------------------------------------- ##
587## Unused values with default %destructor. ##
588## ---------------------------------------- ##
589
590AT_SETUP([Unused values with default %destructor])
591
592AT_DATA([[input.y]],
3ebecc24 593[[%destructor { destroy ($$); } <>
12e35840
JD
594%type <tag> tagged
595
596%%
597
598start: end end tagged tagged { $<tag>1; $3; } ;
599end: { } ;
600tagged: { } ;
601]])
602
0242bf04 603AT_BISON_CHECK([-fcaret input.y], [0], [],
73370a9d 604[[input.y:6.8-45: warning: unset value: $$ [-Wother]
0242bf04
TR
605 start: end end tagged tagged { $<tag>1; $3; } ;
606 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
0906b12c 607input.y:6.12-14: warning: unused value: $2 [-Wother]
0242bf04
TR
608 start: end end tagged tagged { $<tag>1; $3; } ;
609 ^^^
73370a9d 610input.y:7.6-8: warning: unset value: $$ [-Wother]
0242bf04
TR
611 end: { } ;
612 ^^^
12e35840
JD
613]])
614
615AT_DATA([[input.y]],
616[[%destructor { destroy ($$); } <*>
617%type <tag> tagged
ec5479ce
JD
618
619%%
620
12e35840
JD
621start: end end tagged tagged { $<tag>1; $3; } ;
622end: { } ;
623tagged: { } ;
ec5479ce
JD
624]])
625
da730230 626AT_BISON_CHECK([input.y], [0], [],
0906b12c 627[[input.y:6.23-28: warning: unused value: $4 [-Wother]
73370a9d 628input.y:8.9-11: warning: unset value: $$ [-Wother]
ec5479ce
JD
629]])
630
631AT_CLEANUP
632
633
b2a0b7ca
JD
634## ----------------------------------------- ##
635## Unused values with per-type %destructor. ##
636## ----------------------------------------- ##
637
638AT_SETUP([Unused values with per-type %destructor])
639
640AT_DATA([[input.y]],
641[[%destructor { destroy ($$); } <field1>
642%type <field1> start end
643
644%%
645
646start: end end { $1; } ;
647end: { } ;
648]])
649
0242bf04 650AT_BISON_CHECK([-fcaret input.y], [0], [],
73370a9d 651[[input.y:6.8-22: warning: unset value: $$ [-Wother]
0242bf04
TR
652 start: end end { $1; } ;
653 ^^^^^^^^^^^^^^^
0906b12c 654input.y:6.12-14: warning: unused value: $2 [-Wother]
0242bf04
TR
655 start: end end { $1; } ;
656 ^^^
73370a9d 657input.y:7.6-8: warning: unset value: $$ [-Wother]
0242bf04
TR
658 end: { } ;
659 ^^^
b2a0b7ca
JD
660]])
661
662AT_CLEANUP
663
664
df09ef2e
AD
665## ---------------------- ##
666## Incompatible Aliases. ##
667## ---------------------- ##
668
669AT_SETUP([Incompatible Aliases])
670
671AT_DATA([input.y],
672[[%token foo "foo"
673
674%type <bar> foo
675%printer {bar} foo
676%destructor {bar} foo
677%left foo
678
679%type <baz> "foo"
680%printer {baz} "foo"
681%destructor {baz} "foo"
682%left "foo"
683
684%%
685exp: foo;
686]])
687
0242bf04 688AT_BISON_CHECK([-fcaret input.y], [1], [],
b8e7ad58 689[[input.y:8.7-11: error: %type redeclaration for foo
0242bf04
TR
690 %type <baz> "foo"
691 ^^^^^
cbaea010 692input.y:3.7-11: previous declaration
0242bf04
TR
693 %type <bar> foo
694 ^^^^^
b8e7ad58 695input.y:10.13-17: error: %destructor redeclaration for foo
0242bf04
TR
696 %destructor {baz} "foo"
697 ^^^^^
cbaea010 698input.y:5.13-17: previous declaration
0242bf04
TR
699 %destructor {bar} foo
700 ^^^^^
b8e7ad58 701input.y:9.10-14: error: %printer redeclaration for foo
0242bf04
TR
702 %printer {baz} "foo"
703 ^^^^^
cbaea010 704input.y:4.10-14: previous declaration
0242bf04
TR
705 %printer {bar} foo
706 ^^^^^
b8e7ad58 707input.y:11.1-5: error: %left redeclaration for foo
0242bf04
TR
708 %left "foo"
709 ^^^^^
cbaea010 710input.y:6.1-5: previous declaration
0242bf04
TR
711 %left foo
712 ^^^^^
df09ef2e
AD
713]])
714
715AT_CLEANUP
716
717
5a08f1ce
AD
718
719## ----------------------- ##
720## Torturing the Scanner. ##
721## ----------------------- ##
722
723# Be sure to compile and run, so that the C compiler checks what
724# we do.
725
726AT_SETUP([Torturing the Scanner])
727
71c7e24f 728AT_BISON_OPTION_PUSHDEFS
0baf7c50 729AT_DATA([input.y], [])
da730230 730AT_BISON_CHECK([input.y], [1], [],
b8e7ad58 731[[input.y:1.1: error: syntax error, unexpected end of file
0baf7c50
PE
732]])
733
734
e9071366 735AT_DATA([input.y],
b2ddc3f3
AD
736[{}
737])
0242bf04 738AT_BISON_CHECK([-fcaret input.y], [1], [],
b8e7ad58 739[[input.y:1.1-2: error: syntax error, unexpected {...}
0242bf04
TR
740 {}
741 ^^
b2ddc3f3
AD
742]])
743
744
9501dc6e 745AT_DATA_GRAMMAR([input.y],
5a08f1ce
AD
746[[%{
747/* This is seen in GCC: a %{ and %} in middle of a comment. */
748const char *foo = "So %{ and %} can be here too.";
749
dda7a53e
PE
750#if 0
751/* These examples test Bison while not stressing C compilers too much.
752 Many C compilers mishandle backslash-newlines, so this part of the
753 test is inside "#if 0". The comment and string are written so that
754 the "#endif" will be seen regardless of the C compiler bugs that we
755 know about, namely:
756
757 HP C (as of late 2002) mishandles *\[newline]\[newline]/ within a
758 comment.
759
760 The Apple Darwin compiler (as of late 2002) mishandles
761 \\[newline]' within a character constant.
762
763 */
764
206fe6a5 765/\
dda7a53e
PE
766* A comment with backslash-newlines in it. %} *\
767\
206fe6a5 768/
dda7a53e 769/* { Close the above comment, if the C compiler mishandled it. */
206fe6a5
PE
770
771char str[] = "\\
772" A string with backslash-newlines in it %{ %} \\
dda7a53e 773\
206fe6a5
PE
774"";
775
dda7a53e 776char apostrophe = '\'';
206fe6a5
PE
777#endif
778
5a08f1ce 779#include <stdio.h>
c4bd5bf7 780#include <stdlib.h>
77519a7d 781#include <assert.h>
5a08f1ce
AD
782%}
783/* %{ and %} can be here too. */
784
785%{
786/* Exercise pre-prologue dependency to %union. */
051ade83 787typedef int value;
5a08f1ce
AD
788%}
789
790/* Exercise M4 quoting: '@:>@@:>@', 0. */
791
792/* Also exercise %union. */
793%union
794{
051ade83 795 value ival; /* A comment to exercise an old bug. */
5a08f1ce
AD
796};
797
798
799/* Exercise post-prologue dependency to %union. */
800%{
051ade83 801static YYSTYPE value_as_yystype (value val);
5a08f1ce
AD
802
803/* Exercise quotes in declarations. */
804char quote[] = "@:>@@:>@,";
805%}
806
807%{
55f48c48
AD
808]AT_YYERROR_DECLARE[
809]AT_YYLEX_DECLARE[
5a08f1ce
AD
810%}
811
206fe6a5 812%type <ival> '@<:@'
5a08f1ce
AD
813
814/* Exercise quotes in strings. */
3dc4c5fa 815%token FAKE "fake @<:@@:>@ \a\b\f\n\r\t\v\"\'\?\\\u005B\U0000005c ??!??'??(??)??-??/??<??=??> \x1\1"
5a08f1ce
AD
816
817%%
206fe6a5 818/* Exercise M4 quoting: '@:>@@:>@', @<:@, 1. */
087b9fdf 819exp: '@<:@' '\1' two '$' '@' '{' oline output.or.oline.opt
5a08f1ce
AD
820 {
821 /* Exercise quotes in braces. */
822 char tmp[] = "@<:@%c@:>@,\n";
823 printf (tmp, $1);
824 }
825;
5b7f88c7
PE
826
827two: '\x000000000000000000000000000000000000000000000000000000000000000000002';
828oline: '@' 'o' 'l' 'i' 'n' 'e' '@' '_' '_' 'o' 'l' 'i' 'n' 'e' '_' '_';
087b9fdf 829output.or.oline.opt: ;|oline;;|output;;;
5b7f88c7 830output: '#' 'o' 'u' 't' 'p' 'u' 't' ' ';
5a08f1ce 831%%
206fe6a5 832/* Exercise M4 quoting: '@:>@@:>@', @<:@, 2. */
5a08f1ce
AD
833
834static YYSTYPE
051ade83 835value_as_yystype (value val)
5a08f1ce
AD
836{
837 YYSTYPE res;
838 res.ival = val;
839 return res;
840}
71c7e24f 841]AT_YYERROR_DEFINE[
7172e23e 842static int
5a08f1ce
AD
843yylex (void)
844{
cf806753 845 static char const input[] = "@<:@\1\2$@{@oline@__@&t@oline__\
5b7f88c7
PE
846#output "; /* "
847 */
cf806753 848 static size_t toknum;
77519a7d 849 assert (toknum < sizeof input);
cf806753
PE
850 yylval = value_as_yystype (input[toknum]);
851 return input[toknum++];
5a08f1ce 852}
5a08f1ce
AD
853]])
854
9501dc6e
AD
855# Pacify Emacs'font-lock-mode: "
856
5a08f1ce 857AT_DATA([main.c],
051ade83 858[[typedef int value;
5a08f1ce
AD
859#include "input.h"
860
861int yyparse (void);
3ef9fa8f 862]AT_MAIN_DEFINE[
5a08f1ce 863]])
71c7e24f 864AT_BISON_OPTION_POPDEFS
5a08f1ce 865
da730230 866AT_BISON_CHECK([-d -v -o input.c input.y])
91ce0b3a
AD
867AT_COMPILE([input.o])
868AT_COMPILE([main.o])
efc6bf1b 869AT_COMPILE([input], [input.o main.o])
1154cced 870AT_PARSER_CHECK([./input], 0,
206fe6a5 871[[[@<:@],
5a08f1ce
AD
872]])
873
874AT_CLEANUP
e59adf8f
PE
875
876
877## ---------------------- ##
878## Typed symbol aliases. ##
879## ---------------------- ##
880
881AT_SETUP([Typed symbol aliases])
882
883# Bison 2.0 broke typed symbol aliases - ensure they work.
884
885AT_DATA_GRAMMAR([input.y],
886[[%union
887{
888 int val;
889};
890%token <val> MY_TOKEN "MY TOKEN"
891%type <val> exp
892%%
893exp: "MY TOKEN";
894%%
895]])
896
da730230 897AT_BISON_CHECK([-o input.c input.y])
e59adf8f
PE
898
899AT_CLEANUP
b50d2359
AD
900
901
902## --------- ##
903## Require. ##
904## --------- ##
905
906m4_define([AT_CHECK_REQUIRE],
907[AT_SETUP([Require $1])
908AT_DATA_GRAMMAR([input.y],
909[[%require "$1";
910%%
c7442984 911empty_file: /* empty */;
b50d2359 912]])
da730230 913AT_BISON_CHECK([-o input.c input.y], $2, [], ignore)
b50d2359
AD
914AT_CLEANUP
915])
916
917AT_CHECK_REQUIRE(1.0, 0)
918AT_CHECK_REQUIRE(AT_PACKAGE_VERSION, 0)
919## FIXME: Some day augment this version number.
9b8a5ce0 920AT_CHECK_REQUIRE(100.0, 63)
1f6b3679
JD
921
922
923## ------------------------------------- ##
924## String aliases for character tokens. ##
925## ------------------------------------- ##
926
927AT_SETUP([String aliases for character tokens])
928
dab244d5
AD
929# Bison once thought a character token and its alias were different
930# symbols with the same user token number.
1f6b3679
JD
931
932AT_DATA_GRAMMAR([input.y],
933[[%token 'a' "a"
934%%
935start: 'a';
936%%
937]])
938
da730230 939AT_BISON_CHECK([-o input.c input.y])
1f6b3679
JD
940
941AT_CLEANUP
47aee066
JD
942
943
746ee38c
AD
944## -------------- ##
945## Symbol names. ##
946## -------------- ##
947
948AT_SETUP([Symbols])
949
55f48c48 950AT_BISON_OPTION_PUSHDEFS
746ee38c
AD
951AT_DATA_GRAMMAR([input.y],
952[[%token WITH-DASH
953%token WITHOUT_DASH "WITHOUT-DASH"
954%token WITH.PERIOD
955%token WITHOUT_PERIOD "WITHOUT.PERIOD"
d521ee19 956%code {
55f48c48
AD
957 ]AT_YYERROR_DECLARE[
958 ]AT_YYLEX_DECLARE[
d521ee19 959}
746ee38c
AD
960%%
961start: with-dash without_dash with.period without_period;
962with-dash: WITH-DASH;
963without_dash: "WITHOUT-DASH";
964with.period: WITH.PERIOD;
965without_period: "WITHOUT.PERIOD";
966%%
55f48c48
AD
967]AT_YYERROR_DEFINE[
968]AT_YYLEX_DEFINE[
746ee38c 969]])
55f48c48 970AT_BISON_OPTION_POPDEFS
746ee38c
AD
971
972# POSIX Yacc accept periods, but not dashes.
1048a1c9
AD
973AT_BISON_CHECK([--yacc -Wno-error input.y], [], [],
974[[input.y:9.8-16: warning: POSIX Yacc forbids dashes in symbol names: WITH-DASH [-Wyacc]
f0f95a50 975input.y:20.8-16: warning: POSIX Yacc forbids dashes in symbol names: with-dash [-Wyacc]
746ee38c
AD
976]])
977
978# So warn about them.
979AT_BISON_CHECK([-Wyacc input.y], [], [],
73370a9d 980[[input.y:9.8-16: warning: POSIX Yacc forbids dashes in symbol names: WITH-DASH [-Wyacc]
f0f95a50 981input.y:20.8-16: warning: POSIX Yacc forbids dashes in symbol names: with-dash [-Wyacc]
746ee38c
AD
982]])
983
984# Dashes are fine for GNU Bison.
985AT_BISON_CHECK([-o input.c input.y])
986
987# Make sure we don't export silly token identifiers with periods or dashes.
91ce0b3a 988AT_COMPILE([input.o])
746ee38c
AD
989
990
82f3355e
JD
991# Periods are genuine letters, they can start identifiers.
992# Digits and dashes cannot.
746ee38c 993AT_DATA_GRAMMAR([input.y],
cdf3f113 994[[%token .GOOD
84a1cb5a
AD
995 -GOOD
996 1NV4L1D
82f3355e 997 -123
746ee38c 998%%
82f3355e 999start: .GOOD GOOD
746ee38c
AD
1000]])
1001AT_BISON_CHECK([-o input.c input.y], [1], [],
b8e7ad58
TR
1002[[input.y:10.10: error: invalid character: '-'
1003input.y:11.10-16: error: invalid identifier: '1NV4L1D'
1004input.y:12.10: error: invalid character: '-'
746ee38c
AD
1005]])
1006
1007AT_CLEANUP
1008
1009
ab2a9f57
AD
1010## ----------------- ##
1011## Numbered tokens. ##
1012## ----------------- ##
1013
1014AT_SETUP([Numbered tokens])
1015
83b60c97
JD
1016AT_DATA_GRAMMAR([redecl.y],
1017[[%token DECIMAL_1 11259375
1018 HEXADECIMAL_1 0xabcdef
1019 HEXADECIMAL_2 0xFEDCBA
1020 DECIMAL_2 16702650
ab2a9f57 1021%%
83b60c97 1022start: DECIMAL_1 HEXADECIMAL_2;
8893145a
AD
1023]])
1024
83b60c97 1025AT_BISON_CHECK([redecl.y], [1], [],
b8e7ad58 1026[[redecl.y:10.10-22: error: user token number 11259375 redeclaration for HEXADECIMAL_1
b506d9bf 1027redecl.y:9.8-16: previous declaration for DECIMAL_1
b8e7ad58 1028redecl.y:12.10-18: error: user token number 16702650 redeclaration for DECIMAL_2
b506d9bf 1029redecl.y:11.10-22: previous declaration for HEXADECIMAL_2
8893145a
AD
1030]])
1031
83b60c97 1032AT_DATA_GRAMMAR([too-large.y],
ab2a9f57
AD
1033[[%token TOO_LARGE_DEC 999999999999999999999
1034 TOO_LARGE_HEX 0xFFFFFFFFFFFFFFFFFFF
1035%%
1036start: TOO_LARGE_DEC TOO_LARGE_HEX
1037%%
1038]])
1039
83b60c97 1040AT_BISON_CHECK([too-large.y], [1], [],
b8e7ad58
TR
1041[[too-large.y:9.22-42: error: integer out of range: '999999999999999999999'
1042too-large.y:10.24-44: error: integer out of range: '0xFFFFFFFFFFFFFFFFFFF'
ab2a9f57
AD
1043]])
1044
1045AT_CLEANUP
1046
1047
47aee066
JD
1048## --------------------- ##
1049## Unclosed constructs. ##
1050## --------------------- ##
1051
1052AT_SETUP([Unclosed constructs])
1053
dab244d5
AD
1054# Bison's scan-gram.l once forgot to STRING_FINISH some unclosed
1055# constructs, so they were prepended to whatever it STRING_GROW'ed
1056# next. It also threw them away rather than returning them to the
1057# parser. The effect was confusing subsequent error messages.
47aee066
JD
1058
1059AT_DATA([input.y],
1060[[%token A "a
1061%token B "b"
1062%token AB "ab" // Used to complain that "ab" was already used.
1063%token C '1
1064%token TWO "2"
1065%token TICK_TWELVE "'12" // Used to complain that "'12" was already used.
1066
1067%%
1068
1069start: ;
1070
1071// Used to report a syntax error because it didn't see any kind of symbol
1072// identifier.
1073%type <f> 'a
1074;
1075%type <f> "a
1076;
1077// Used to report a syntax error because it didn't see braced code.
1078%destructor { free ($$)
1079]])
1080
505ece51
TR
1081AT_BISON_CHECK([-fcaret -o input.c input.y], 1, [],
1082[[input.y:1.10-2.0: error: missing '"' at end of line
1083 %token A "a
1084 ^^
1085input.y:4.10-5.0: error: missing "'" at end of line
1086 %token C '1
1087 ^^
1088input.y:14.11-15.0: error: missing "'" at end of line
1089 %type <f> 'a
1090 ^^
1091input.y:16.11-17.0: error: missing '"' at end of line
1092 %type <f> "a
1093 ^^
1094input.y:19.13-20.0: error: missing '}' at end of file
1095 %destructor { free ($$)
1096 ^^^^^^^^^^^
1097input.y:20.1: error: syntax error, unexpected end of file
1098]])
1099
47aee066 1100AT_CLEANUP
4d7370cb
JD
1101
1102
1103## ------------------------- ##
1104## %start after first rule. ##
1105## ------------------------- ##
1106
1107AT_SETUP([%start after first rule])
1108
dab244d5
AD
1109# Bison once complained that a %start after the first rule was a
1110# redeclaration of the start symbol.
4d7370cb
JD
1111
1112AT_DATA([input.y],
1113[[%%
1114false_start: ;
1115start: false_start ;
1116%start start;
1117]])
1118
da730230 1119AT_BISON_CHECK([-o input.c input.y])
4d7370cb
JD
1120
1121AT_CLEANUP
26b8a438
JD
1122
1123
1124## --------------------- ##
1125## %prec takes a token. ##
1126## --------------------- ##
1127
1128AT_SETUP([%prec takes a token])
1129
1130# Bison once allowed %prec sym where sym was a nonterminal.
1131
1132AT_DATA([input.y],
1133[[%%
1134start: PREC %prec PREC ;
1135PREC: ;
1136]])
1137
da730230 1138AT_BISON_CHECK([input.y], [1], [],
b8e7ad58 1139[[input.y:3.1-4: error: rule given for PREC, which is a token
26b8a438
JD
1140]])
1141
1142AT_CLEANUP
8e0a5e9e
JD
1143
1144
8bb3a2e7
JD
1145## ------------------------------- ##
1146## %prec's token must be defined. ##
1147## ------------------------------- ##
1148
1149AT_SETUP([[%prec's token must be defined]])
1150
1151# According to POSIX, a %prec token must be defined separately.
1152
1153AT_DATA([[input.y]],
1154[[%%
1155start: %prec PREC ;
1156]])
1157
02354690 1158AT_BISON_CHECK([[input.y]], [[0]], [],
73370a9d 1159[[input.y:2.8-17: warning: token for %prec is not defined: PREC [-Wother]
8bb3a2e7
JD
1160]])
1161
1162AT_CLEANUP
1163
1164
6afc30cc
JD
1165## -------------------------------- ##
1166## Reject unused %code qualifiers. ##
1167## -------------------------------- ##
8e0a5e9e 1168
6afc30cc 1169AT_SETUP([Reject unused %code qualifiers])
8e0a5e9e
JD
1170
1171AT_DATA([input-c.y],
16dc6a9e
JD
1172[[%code q {}
1173%code bad {}
1174%code bad {}
8405b70c 1175%code format {}
8e0a5e9e
JD
1176%%
1177start: ;
1178]])
c6abeab1 1179AT_BISON_CHECK([[input-c.y]], [[1]], [],
b8e7ad58
TR
1180[[input-c.y:1.7: error: %code qualifier 'q' is not used
1181input-c.y:2.7-9: error: %code qualifier 'bad' is not used
1182input-c.y:3.7-9: error: %code qualifier 'bad' is not used
1183input-c.y:4.7-12: error: %code qualifier 'format' is not used
08af01c2 1184]])
8e0a5e9e
JD
1185
1186AT_DATA([input-c-glr.y],
16dc6a9e
JD
1187[[%code q {}
1188%code bad {}
1189 %code bad {}
8e0a5e9e
JD
1190%%
1191start: ;
1192]])
c6abeab1 1193AT_BISON_CHECK([[input-c-glr.y]], [[1]], [],
b8e7ad58
TR
1194[[input-c-glr.y:1.7: error: %code qualifier 'q' is not used
1195input-c-glr.y:2.7-9: error: %code qualifier 'bad' is not used
1196input-c-glr.y:3.8-10: error: %code qualifier 'bad' is not used
08af01c2 1197]])
8e0a5e9e
JD
1198
1199AT_DATA([input-c++.y],
16dc6a9e
JD
1200[[%code q {}
1201%code bad {}
1202 %code q {}
8e0a5e9e
JD
1203%%
1204start: ;
1205]])
c6abeab1 1206AT_BISON_CHECK([[input-c++.y]], [[1]], [],
b8e7ad58
TR
1207[[input-c++.y:1.7: error: %code qualifier 'q' is not used
1208input-c++.y:2.7-9: error: %code qualifier 'bad' is not used
1209input-c++.y:3.8: error: %code qualifier 'q' is not used
08af01c2 1210]])
8e0a5e9e
JD
1211
1212AT_DATA([input-c++-glr.y],
16dc6a9e
JD
1213[[%code bad {}
1214%code q {}
1215%code q {}
8e0a5e9e
JD
1216%%
1217start: ;
1218]])
c6abeab1 1219AT_BISON_CHECK([[input-c++-glr.y]], [[1]], [],
b8e7ad58
TR
1220[[input-c++-glr.y:1.7-9: error: %code qualifier 'bad' is not used
1221input-c++-glr.y:2.7: error: %code qualifier 'q' is not used
1222input-c++-glr.y:3.7: error: %code qualifier 'q' is not used
3fc65ead
JD
1223]])
1224
1225AT_DATA([special-char-@@.y],
16dc6a9e
JD
1226[[%code bad {}
1227%code q {}
1228%code q {}
3fc65ead
JD
1229%%
1230start: ;
1231]])
c6abeab1 1232AT_BISON_CHECK([[special-char-@@.y]], [[1]], [],
b8e7ad58
TR
1233[[special-char-@@.y:1.7-9: error: %code qualifier 'bad' is not used
1234special-char-@@.y:2.7: error: %code qualifier 'q' is not used
1235special-char-@@.y:3.7: error: %code qualifier 'q' is not used
3fc65ead
JD
1236]])
1237
1238AT_DATA([special-char-@:>@.y],
16dc6a9e
JD
1239[[%code bad {}
1240%code q {}
1241%code q {}
3fc65ead
JD
1242%%
1243start: ;
1244]])
c6abeab1 1245AT_BISON_CHECK([[special-char-@:>@.y]], [[1]], [],
b8e7ad58
TR
1246[[special-char-@:>@.y:1.7-9: error: %code qualifier 'bad' is not used
1247special-char-@:>@.y:2.7: error: %code qualifier 'q' is not used
1248special-char-@:>@.y:3.7: error: %code qualifier 'q' is not used
08af01c2 1249]])
8e0a5e9e
JD
1250
1251AT_CLEANUP
7eb8a0bc
JD
1252
1253
1254## ---------------- ##
1255## %define errors. ##
1256## ---------------- ##
1257
1258AT_SETUP([%define errors])
1259
0b6d43c5 1260AT_DATA([input-redefined.y],
16dc6a9e
JD
1261[[%define var "value1"
1262%define var "value1"
1263 %define var "value2"
1264%define special1 "@:>@"
1265%define special2 "@<:@"
7eb8a0bc
JD
1266%%
1267start: ;
1268]])
1269
0b6d43c5 1270AT_BISON_CHECK([[input-redefined.y]], [[1]], [],
b8e7ad58 1271[[input-redefined.y:2.9-11: error: %define variable 'var' redefined
6b1e1872 1272input-redefined.y:1.9-11: previous definition
b8e7ad58 1273input-redefined.y:3.10-12: error: %define variable 'var' redefined
6b1e1872 1274input-redefined.y:2.9-11: previous definition
0b6d43c5
JD
1275]])
1276
1277AT_DATA([input-unused.y],
1278[[%define var "value"
1279%%
1280start: ;
1281]])
1282
c6abeab1 1283AT_BISON_CHECK([[input-unused.y]], [[1]], [],
b8e7ad58 1284[[input-unused.y:1.9-11: error: %define variable 'var' is not used
7eb8a0bc
JD
1285]])
1286
1287AT_CLEANUP
c1d19e10 1288
58697c6d 1289
de5ab940
JD
1290## ----------------------------------- ##
1291## %define, --define, --force-define. ##
1292## ----------------------------------- ##
58697c6d 1293
c6abeab1 1294AT_SETUP([[%define, --define, --force-define]])
de5ab940 1295
c6abeab1 1296AT_DATA([[skel.c]],
de5ab940
JD
1297[[m4@&t@_divert_push(0)@
1298@output(b4_parser_file_name@)@
1299[var-dd: ]b4_percent_define_get([[var-dd]])[
1300var-ff: ]b4_percent_define_get([[var-ff]])[
de5ab940
JD
1301var-dfg: ]b4_percent_define_get([[var-dfg]])[
1302var-fd: ]b4_percent_define_get([[var-fd]])
1303m4@&t@_divert_pop(0)
1304]])
c6abeab1 1305AT_DATA([[input.y]],
0b6d43c5 1306[[%define var-dfg "gram"
58697c6d
AD
1307%%
1308start: ;
1309]])
de5ab940
JD
1310AT_BISON_CHECK([[-Dvar-dd=cmd-d1 -Dvar-dd=cmd-d2 \
1311 -Fvar-ff=cmd-f1 -Fvar-ff=cmd-f2 \
de5ab940
JD
1312 -Dvar-dfg=cmd-d -Fvar-dfg=cmd-f \
1313 -Fvar-fd=cmd-f -Dvar-fd=cmd-d \
c6abeab1 1314 --skeleton ./skel.c input.y]])
de5ab940
JD
1315AT_CHECK([[cat input.tab.c]], [[0]],
1316[[var-dd: cmd-d2
1317var-ff: cmd-f2
de5ab940
JD
1318var-dfg: cmd-f
1319var-fd: cmd-d
58697c6d
AD
1320]])
1321
c6abeab1 1322AT_DATA([[input-dg.y]],
0b6d43c5
JD
1323[[%define var "gram"
1324%%
1325start: ;
1326]])
0b6d43c5 1327AT_BISON_CHECK([[-Dvar=cmd-d input-dg.y]], [[1]], [],
b8e7ad58 1328[[input-dg.y:1.9-11: error: %define variable 'var' redefined
9c4788b7 1329<command line>:2: previous definition
0b6d43c5
JD
1330]])
1331
505ece51
TR
1332AT_DATA([[input-dg.y]],
1333[[%define var "gram"
1334%%
1335start: ;
1336]])
1337AT_BISON_CHECK([[-fcaret -Dvar=cmd-d input-dg.y]], [[1]], [],
1338[[input-dg.y:1.9-11: error: %define variable 'var' redefined
1339 %define var "gram"
1340 ^^^
9c4788b7 1341<command line>:3: previous definition
505ece51
TR
1342]])
1343
c6abeab1
JD
1344AT_DATA([[input-unused.y]],
1345[[%%
1346start: ;
1347]])
1348AT_BISON_CHECK([[-Dunused-d -Funused-f input-unused.y]], [[1]], [],
9c4788b7
TR
1349[[<command line>:2: error: %define variable 'unused-d' is not used
1350<command line>:3: error: %define variable 'unused-f' is not used
c6abeab1
JD
1351]])
1352
58697c6d
AD
1353AT_CLEANUP
1354
c1d19e10 1355## --------------------------- ##
d782395d 1356## %define Boolean variables. ##
c1d19e10
PB
1357## --------------------------- ##
1358
1a06f28e 1359AT_SETUP([["%define" Boolean variables]])
c1d19e10
PB
1360
1361AT_DATA([Input.y],
1362[[%language "Java"
1363%define public "maybe"
1364%define parser_class_name "Input"
1365%%
1366start: ;
1367]])
1368
da730230 1369AT_BISON_CHECK([[Input.y]], [1], [],
b8e7ad58 1370[[Input.y:2.9-14: error: invalid value for %define Boolean variable 'public'
c1d19e10
PB
1371]])
1372
1373AT_CLEANUP
d782395d 1374
f4909773
JD
1375## ------------------------ ##
1376## %define enum variables. ##
1377## ------------------------ ##
7254f6a8 1378
1a06f28e
AD
1379AT_SETUP([["%define" enum variables]])
1380
1381# Check errors from the front-end, and the back-end. Since the
1382# front-end quits before calling the back-end, these tests cannot be
1383# fused.
7254f6a8 1384
f4909773 1385# Front-end.
7254f6a8 1386AT_DATA([[input.y]],
f3bc3386 1387[[%define lr.default-reduction bogus
7254f6a8
JD
1388%%
1389start: ;
1390]])
1a06f28e 1391AT_BISON_CHECK([[-fcaret input.y]], [[1]], [[]],
f3bc3386 1392[[input.y:1.9-28: error: invalid value for %define variable 'lr.default-reduction': 'bogus'
1a06f28e
AD
1393 %define lr.default-reduction bogus
1394 ^^^^^^^^^^^^^^^^^^^^
f3bc3386
AD
1395input.y:1.9-28: accepted value: 'most'
1396input.y:1.9-28: accepted value: 'consistent'
1397input.y:1.9-28: accepted value: 'accepting'
7254f6a8
JD
1398]])
1399
f4909773 1400# Back-end.
67212941 1401AT_DATA([[input.y]],
cf499cff 1402[[%define api.push-pull neither
67212941
JD
1403%%
1404start: ;
1405]])
1a06f28e 1406AT_BISON_CHECK([[-fcaret input.y]], [[1]], [[]],
b8e7ad58 1407[[input.y:1.9-21: error: invalid value for %define variable 'api.push-pull': 'neither'
1a06f28e
AD
1408 %define api.push-pull neither
1409 ^^^^^^^^^^^^^
c6c8de16
TR
1410input.y:1.9-21: accepted value: 'pull'
1411input.y:1.9-21: accepted value: 'push'
1412input.y:1.9-21: accepted value: 'both'
67212941
JD
1413]])
1414
1415AT_CLEANUP
1416
1417## -------------------------------- ##
1418## %define backward compatibility. ##
1419## -------------------------------- ##
1420
1a06f28e 1421AT_SETUP([["%define" backward compatibility]])
67212941 1422
1a06f28e 1423# The error messages tell us whether the variables are properly updated.
d782395d 1424AT_DATA([[input.y]],
1a06f28e
AD
1425[[%define api.push_pull both
1426%define lr.keep_unreachable_states maybe
1427%define namespace "foo"
1428%define api.namespace "foo"
1429%define variant
d782395d
JD
1430%%
1431start: ;
1432]])
ea9e670d 1433AT_BISON_CHECK([[-fcaret input.y]], [1], [],
1a06f28e
AD
1434[[input.y:1.9-21: warning: deprecated directive, use '%define api.push-pull both' [-Wdeprecated]
1435 %define api.push_pull both
ea9e670d 1436 ^^^^^^^^^^^^^
1a06f28e
AD
1437input.y:2.9-34: warning: deprecated directive, use '%define lr.keep-unreachable-state maybe' [-Wdeprecated]
1438 %define lr.keep_unreachable_states maybe
1439 ^^^^^^^^^^^^^^^^^^^^^^^^^^
1440input.y:3.9-17: warning: deprecated directive, use '%define api.namespace foo' [-Wdeprecated]
1441 %define namespace "foo"
1442 ^^^^^^^^^
1443input.y:4.9-21: error: %define variable 'api.namespace' redefined
1444 %define api.namespace "foo"
ea9e670d 1445 ^^^^^^^^^^^^^
1a06f28e
AD
1446input.y:3.9-17: previous definition
1447 %define namespace "foo"
1448 ^^^^^^^^^
1449input.y:5.9-15: warning: deprecated directive, use '%define api.value.type variant' [-Wdeprecated]
1450 %define variant
1451 ^^^^^^^
67212941
JD
1452]])
1453
d782395d 1454AT_CLEANUP
793fbca5 1455
d9df47b6
JD
1456## ------------------------- ##
1457## Unused %define api.pure. ##
1458## ------------------------- ##
1459
1460AT_SETUP([[Unused %define api.pure]])
1461
1462# AT_CHECK_API_PURE(DECLS, VALUE)
1463# -------------------------------
1464# Make sure Bison reports that `%define api.pure VALUE' is unused when DECLS
1465# are specified.
1466m4_define([AT_CHECK_API_PURE],
1467[
1468AT_DATA([[input.y]],
1469[[%define api.pure ]$2[
1470]$1[
1471%%
1472start: ;
1473]])
1474
c6abeab1 1475AT_BISON_CHECK([[input.y]], [[1]], [],
b8e7ad58 1476[[input.y:1.9-16: error: %define variable 'api.pure' is not used
d9df47b6
JD
1477]])
1478])
1479
66fb016e
AD
1480AT_CHECK_API_PURE([[%language "c++"]], [[]])
1481AT_CHECK_API_PURE([[%language "c++"]], [[false]])
1482AT_CHECK_API_PURE([[%language "c++" %glr-parser]], [[""]])
1483AT_CHECK_API_PURE([[%language "c++" %glr-parser]], [[false]])
cf499cff
JD
1484AT_CHECK_API_PURE([[%language "java"]], [[true]])
1485AT_CHECK_API_PURE([[%language "java"]], [[false]])
d9df47b6
JD
1486
1487AT_CLEANUP
1488
793fbca5
JD
1489## -------------------------------- ##
1490## C++ namespace reference errors. ##
1491## -------------------------------- ##
1492
1493AT_SETUP([[C++ namespace reference errors]])
1494
1495# AT_CHECK_NAMESPACE_ERROR(NAMESPACE-DECL, ERROR, [ERROR], ...)
1496# -------------------------------------------------------------
1497# Make sure Bison reports all ERROR's for %define namespace "NAMESPACE-DECL".
1498m4_define([AT_CHECK_NAMESPACE_ERROR],
1499[
1500AT_DATA([[input.y]],
1501[[%language "C++"
1502%defines
67501061 1503%define api.namespace "]$1["
793fbca5
JD
1504%%
1505start: ;
1506]])
1507
da730230 1508AT_BISON_CHECK([[input.y]], [1], [],
793fbca5 1509[m4_foreach([b4_arg], m4_dquote(m4_shift($@)),
11b19212 1510[[input.y:3.9-21: error: ]b4_arg[
793fbca5
JD
1511]])])
1512])
1513
1514AT_CHECK_NAMESPACE_ERROR([[]],
1515 [[namespace reference is empty]])
bb1c50d8 1516AT_CHECK_NAMESPACE_ERROR([[ @tb@@tb@ @tb@ @tb@]],
793fbca5
JD
1517 [[namespace reference is empty]])
1518AT_CHECK_NAMESPACE_ERROR([[foo::::bar]],
1519 [[namespace reference has consecutive "::"]])
bb1c50d8 1520AT_CHECK_NAMESPACE_ERROR([[foo:: @tb@::bar]],
793fbca5
JD
1521 [[namespace reference has consecutive "::"]])
1522AT_CHECK_NAMESPACE_ERROR([[::::bar]],
1523 [[namespace reference has consecutive "::"]])
1524AT_CHECK_NAMESPACE_ERROR([[:: ::bar]],
1525 [[namespace reference has consecutive "::"]])
bb1c50d8 1526AT_CHECK_NAMESPACE_ERROR([[foo::bar::@tb@::]],
793fbca5
JD
1527 [[namespace reference has consecutive "::"]],
1528 [[namespace reference has a trailing "::"]])
1529AT_CHECK_NAMESPACE_ERROR([[foo::bar::]],
1530 [[namespace reference has a trailing "::"]])
bb1c50d8 1531AT_CHECK_NAMESPACE_ERROR([[foo::bar:: @tb@]],
793fbca5
JD
1532 [[namespace reference has a trailing "::"]])
1533AT_CHECK_NAMESPACE_ERROR([[::]],
1534 [[namespace reference has a trailing "::"]])
1535
1536AT_CLEANUP
3208e3f4
JD
1537
1538## ------------------------ ##
1539## Bad character literals. ##
1540## ------------------------ ##
1541
1542# Bison used to accept character literals that were empty or contained
1543# too many characters.
1544
b70c7fb4
JD
1545# FIXME: AT_DATA or some variant of AT_DATA may eventually permit
1546# the final newline to be omitted. See the threads starting at
3208e3f4
JD
1547# <http://lists.gnu.org/archive/html/bison-patches/2009-07/msg00019.html>.
1548
1549AT_SETUP([[Bad character literals]])
1550
1551AT_DATA([empty.y],
1552[[%%
1553start: '';
1554start: '
1555]])
ff020c30 1556AT_CHECK([[$PERL -e "print 'start: \'';" >> empty.y || exit 77]])
3208e3f4 1557
c1b2677a 1558AT_BISON_CHECK([-fcaret empty.y], [1], [],
73370a9d 1559[[empty.y:2.8-9: warning: empty character literal [-Wother]
c1b2677a
TR
1560 start: '';
1561 ^^
b8e7ad58 1562empty.y:3.8-4.0: error: missing "'" at end of line
c1b2677a
TR
1563 start: '
1564 ^
1565empty.y:3.8-4.0: warning: empty character literal [-Wother]
1566 start: '
1567 ^
b8e7ad58 1568empty.y:4.8: error: missing "'" at end of file
c1b2677a
TR
1569 start: '
1570 ^
1571empty.y:4.8: warning: empty character literal [-Wother]
1572 start: '
1573 ^
3208e3f4
JD
1574]])
1575
1576AT_DATA([two.y],
1577[[%%
1578start: 'ab';
1579start: 'ab
1580]])
ff020c30 1581AT_CHECK([[$PERL -e "print 'start: \'ab';" >> two.y || exit 77]])
3208e3f4
JD
1582
1583AT_BISON_CHECK([two.y], [1], [],
73370a9d 1584[[two.y:2.8-11: warning: extra characters in character literal [-Wother]
b8e7ad58 1585two.y:3.8-4.0: error: missing "'" at end of line
c1b2677a 1586two.y:3.8-4.0: warning: extra characters in character literal [-Wother]
b8e7ad58 1587two.y:4.8-10: error: missing "'" at end of file
c1b2677a 1588two.y:4.8-10: warning: extra characters in character literal [-Wother]
3208e3f4
JD
1589]])
1590
1591AT_DATA([three.y],
1592[[%%
1593start: 'abc';
1594start: 'abc
1595]])
ff020c30 1596AT_CHECK([[$PERL -e "print 'start: \'abc';" >> three.y || exit 77]])
3208e3f4
JD
1597
1598AT_BISON_CHECK([three.y], [1], [],
73370a9d 1599[[three.y:2.8-12: warning: extra characters in character literal [-Wother]
b8e7ad58 1600three.y:3.8-4.0: error: missing "'" at end of line
c1b2677a 1601three.y:3.8-4.0: warning: extra characters in character literal [-Wother]
b8e7ad58 1602three.y:4.8-11: error: missing "'" at end of file
c1b2677a 1603three.y:4.8-11: warning: extra characters in character literal [-Wother]
3208e3f4
JD
1604]])
1605
1606AT_CLEANUP
c2724603
JD
1607
1608## ------------------------- ##
1609## Bad escapes in literals. ##
1610## ------------------------- ##
1611
1612AT_SETUP([[Bad escapes in literals]])
1613
1614AT_DATA([input.y],
1615[[%%
1616start: '\777' '\0' '\xfff' '\x0'
1617 '\uffff' '\u0000' '\Uffffffff' '\U00000000'
1618 '\ ' '\A';
1619]])
3bed3a75 1620
b70c7fb4 1621# It is not easy to create special characters, we cannot even trust tr.
3bed3a75
AD
1622# Beside we cannot even expect "echo '\0'" to output two characters
1623# (well three with \n): at least Bash 3.2 converts the two-character
1624# sequence "\0" into a single NUL character.
ff020c30 1625AT_CHECK([[$PERL -e 'print "start: \"\\\t\\\f\\\0\\\1\" ;";' >> input.y \
b70c7fb4 1626 || exit 77]])
c2724603
JD
1627
1628AT_BISON_CHECK([input.y], [1], [],
b8e7ad58 1629[[input.y:2.9-12: error: invalid number after \-escape: 777
73370a9d 1630input.y:2.8-13: warning: empty character literal [-Wother]
b8e7ad58 1631input.y:2.16-17: error: invalid number after \-escape: 0
73370a9d 1632input.y:2.15-18: warning: empty character literal [-Wother]
b8e7ad58 1633input.y:2.21-25: error: invalid number after \-escape: xfff
73370a9d 1634input.y:2.20-26: warning: empty character literal [-Wother]
b8e7ad58 1635input.y:2.29-31: error: invalid number after \-escape: x0
73370a9d 1636input.y:2.28-32: warning: empty character literal [-Wother]
b8e7ad58 1637input.y:3.9-14: error: invalid number after \-escape: uffff
73370a9d 1638input.y:3.8-15: warning: empty character literal [-Wother]
b8e7ad58 1639input.y:3.18-23: error: invalid number after \-escape: u0000
73370a9d 1640input.y:3.17-24: warning: empty character literal [-Wother]
b8e7ad58 1641input.y:3.27-36: error: invalid number after \-escape: Uffffffff
73370a9d 1642input.y:3.26-37: warning: empty character literal [-Wother]
b8e7ad58 1643input.y:3.40-49: error: invalid number after \-escape: U00000000
73370a9d 1644input.y:3.39-50: warning: empty character literal [-Wother]
b8e7ad58 1645input.y:4.9-10: error: invalid character after \-escape: ' '
73370a9d 1646input.y:4.8-11: warning: empty character literal [-Wother]
b8e7ad58 1647input.y:4.14-15: error: invalid character after \-escape: A
73370a9d 1648input.y:4.13-16: warning: empty character literal [-Wother]
b8e7ad58
TR
1649input.y:5.9-16: error: invalid character after \-escape: \t
1650input.y:5.17: error: invalid character after \-escape: \f
1651input.y:5.18: error: invalid character after \-escape: \0
1652input.y:5.19: error: invalid character after \-escape: \001
c2724603
JD
1653]])
1654
1655AT_CLEANUP
bf35c71c
JD
1656
1657## ------------------------- ##
1658## LAC: Errors for %define. ##
1659## ------------------------- ##
1660
1661AT_SETUP([[LAC: Errors for %define]])
1662
1663AT_DATA([[input.y]],
1664[[%%
1665start: ;
1666]])
1667
1668# parse.lac.* options are useless if LAC isn't actually activated.
1669AT_BISON_CHECK([[-Dparse.lac.es-capacity-initial=1 input.y]],
1670 [[1]], [],
9c4788b7 1671[[<command line>:2: error: %define variable 'parse.lac.es-capacity-initial' is not used
bf35c71c 1672]])
107844a3
JD
1673AT_BISON_CHECK([[-Dparse.lac.memory-trace=full input.y]],
1674 [[1]], [],
9c4788b7 1675[[<command line>:2: error: %define variable 'parse.lac.memory-trace' is not used
107844a3 1676]])
bf35c71c
JD
1677
1678AT_CLEANUP
bf0e44e8
JD
1679
1680## --------------------------------------------- ##
1681## -Werror is not affected by -Wnone and -Wall. ##
1682## --------------------------------------------- ##
1683
1684AT_SETUP([[-Werror is not affected by -Wnone and -Wall]])
1685
1686AT_DATA([[input.y]],
1687[[%%
1688foo-bar: ;
1689]])
1690
1691# -Werror is not enabled by -Wall or equivalent.
1692AT_BISON_CHECK([[-Wall input.y]], [[0]], [[]],
73370a9d 1693[[input.y:2.1-7: warning: POSIX Yacc forbids dashes in symbol names: foo-bar [-Wyacc]
bf0e44e8
JD
1694]])
1695AT_BISON_CHECK([[-W input.y]], [[0]], [[]],
73370a9d 1696[[input.y:2.1-7: warning: POSIX Yacc forbids dashes in symbol names: foo-bar [-Wyacc]
bf0e44e8
JD
1697]])
1698AT_BISON_CHECK([[-Wno-none input.y]], [[0]], [[]],
73370a9d 1699[[input.y:2.1-7: warning: POSIX Yacc forbids dashes in symbol names: foo-bar [-Wyacc]
bf0e44e8
JD
1700]])
1701
1702# -Werror is not disabled by -Wnone or equivalent.
1703AT_BISON_CHECK([[-Werror,none,yacc input.y]], [[1]], [[]], [[stderr]])
1704AT_CHECK([[sed 's/^.*bison:/bison:/' stderr]], [[0]],
46bdb8ec 1705[[input.y:2.1-7: error: POSIX Yacc forbids dashes in symbol names: foo-bar [-Werror=yacc]
bf0e44e8
JD
1706]])
1707[mv stderr experr]
1708AT_BISON_CHECK([[-Werror,no-all,yacc input.y]], [[1]], [[]], [[experr]])
1709
1710AT_CLEANUP
32ae07ef
AD
1711
1712
1713## ------------------------------------------------------ ##
1714## %name-prefix and %define api.prefix are incompatible. ##
1715## ------------------------------------------------------ ##
1716
1a06f28e 1717AT_SETUP([[%name-prefix and api.prefix are incompatible]])
32ae07ef
AD
1718
1719# AT_TEST(DIRECTIVES, OPTIONS, ERROR-LOCATION)
1720# --------------------------------------------
1721m4_pushdef([AT_TEST],
1722[AT_DATA([[input.y]],
1723[[$1
1724%%
c7442984 1725exp: /* empty */;
32ae07ef
AD
1726]])
1727AT_BISON_CHECK([[$2 input.y]], [[1]], [[]],
b8e7ad58 1728[[$3: error: '%name-prefix' and '%define api.prefix' cannot be used together
32ae07ef
AD
1729]])
1730])
1731
1732AT_TEST([%define api.prefix foo %name-prefix "bar"], [], [input.y:1.9-18])
9c4788b7
TR
1733AT_TEST([], [-Dapi.prefix=foo -p bar], [<command line>:2])
1734AT_TEST([%name-prefix "bar"], [-Dapi.prefix=foo], [<command line>:2])
32ae07ef
AD
1735AT_TEST([%define api.prefix foo], [-p bar], [input.y:1.9-18])
1736
1737m4_popdef([AT_TEST])
1738
1739AT_CLEANUP
8617d87e
AD
1740
1741
26313726
AD
1742## -------------- ##
1743## Stray $ or @. ##
1744## -------------- ##
1745
1746AT_SETUP([[Stray $ or @]])
1747
1c292035
AD
1748# Give %printer and %destructor "<*> exp TOK" instead of "<*>" to
1749# check that the warnings are reported once, not three times.
1750
26313726 1751AT_DATA_GRAMMAR([[input.y]],
4323e0da
AD
1752[[%type <TYPE> exp
1753%token <TYPE> TOK TOK2
1c292035 1754%destructor { $%; @%; } <*> exp TOK;
26313726 1755%initial-action { $%; @%; };
1c292035 1756%printer { $%; @%; } <*> exp TOK;
b8a8cc42 1757%{ $ @ %} // Should not warn.
26313726 1758%%
1c292035 1759exp: TOK { $%; @%; $$ = $1; };
b8a8cc42
AD
1760%%
1761$ @ // Should not warn.
26313726
AD
1762]])
1763
b8a8cc42 1764AT_BISON_CHECK([[-Wall input.y]], 0, [],
4323e0da
AD
1765[[input.y:11.19: warning: stray '$' [-Wother]
1766input.y:11.23: warning: stray '@' [-Wother]
1767input.y:12.19: warning: stray '$' [-Wother]
1768input.y:12.23: warning: stray '@' [-Wother]
1769input.y:13.19: warning: stray '$' [-Wother]
1770input.y:13.23: warning: stray '@' [-Wother]
b8a8cc42
AD
1771input.y:16.19: warning: stray '$' [-Wother]
1772input.y:16.23: warning: stray '@' [-Wother]
26313726
AD
1773]])
1774
1775AT_CLEANUP
1776
1777
1778
8617d87e
AD
1779## ---------------- ##
1780## Code injection. ##
1781## ---------------- ##
1782
1783
1784AT_SETUP([[Code injection]])
1785
1786m4_pattern_allow([^m4_errprintn$])
1787
1788# AT_TEST([MACRO])
1789# ----------------
1790# Try to have MACRO be run by bison.
1791m4_pushdef([AT_TEST],
1792[AT_DATA([[input.y]],
1793[[%type <$1(DEAD %type)> exp
1794%token <$1(DEAD %token)> a
4323e0da 1795%token b
8617d87e
AD
1796%initial-action
1797{
1798 $$;
1799 $<$1(DEAD %initial-action)>$
1800};
9a86ee60
AD
1801%printer
1802{
1803 $$
1804 $<$1(DEAD %printer)>$
1805} <> <*>;
1806%lex-param
1807{
1808 $1(DEAD %lex-param)
1809};
1810%parse-param
1811{
1812 $1(DEAD %parse-param)
1813};
8617d87e
AD
1814%%
1815exp:
4323e0da 1816 a a[name] b
8617d87e
AD
1817 {
1818 $$;
1819 $][1;
1820 $<$1(DEAD action 1)>$
1821 $<$1(DEAD action 2)>1
4323e0da 1822 $<$1(DEAD action 3)>name
8617d87e
AD
1823 $<$1(DEAD action 4)>0
1824 ;
1825 };
1826]])
1827
1828# FIXME: Provide a means to iterate over all the skeletons.
1829AT_BISON_CHECK([[-d input.y]])
1830AT_BISON_CHECK([[-d -S glr.c input.y]])
1831AT_BISON_CHECK([[-d -S lalr1.cc input.y]])
1832AT_BISON_CHECK([[-d -S glr.cc input.y]])
1833AT_BISON_CHECK([[ -S lalr1.java input.y]])
1834])
1835
1836AT_TEST([m4_errprintn])
1837AT_TEST([@:>@m4_errprintn])
1838
1839m4_popdef([AT_TEST])
1840
1841AT_CLEANUP
0f92546f
TR
1842
1843##----------------------- ##
1844## Deprecated directives. ##
1845## ---------------------- ##
1846
1847AT_SETUP([[Deprecated directives]])
1848
1849AT_KEYWORDS([[deprec]])
1850
1851AT_DATA_GRAMMAR([[input.y]],
1852[[
1853%default_prec
1854%error_verbose
ed91d427 1855%expect_rr 0
0f92546f
TR
1856%file-prefix = "foo"
1857%file-prefix
1858 =
1859"bar"
1860%fixed-output_files
1861%fixed_output-files
1862%fixed-output-files
1863%name-prefix= "foo"
1864%no-default_prec
1865%no_default-prec
1866%no_lines
1867%output = "foo"
1868%pure_parser
1869%token_table
ed91d427 1870%glr-parser
0f92546f
TR
1871%% exp : '0'
1872]])
1873
1874AT_BISON_CHECK([[input.y]], [[0]], [[]],
1875[[input.y:10.1-13: warning: deprecated directive: '%default_prec', use '%default-prec' [-Wdeprecated]
1876input.y:11.1-14: warning: deprecated directive: '%error_verbose', use '%define parse.error verbose' [-Wdeprecated]
1877input.y:12.1-10: warning: deprecated directive: '%expect_rr', use '%expect-rr' [-Wdeprecated]
1878input.y:13.1-14: warning: deprecated directive: '%file-prefix =', use '%file-prefix' [-Wdeprecated]
1879input.y:14.1-15.2: warning: deprecated directive: '%file-prefix\n =', use '%file-prefix' [-Wdeprecated]
1880input.y:17.1-19: warning: deprecated directive: '%fixed-output_files', use '%fixed-output-files' [-Wdeprecated]
1881input.y:18.1-19: warning: deprecated directive: '%fixed_output-files', use '%fixed-output-files' [-Wdeprecated]
1882input.y:20.1-13: warning: deprecated directive: '%name-prefix=', use '%name-prefix' [-Wdeprecated]
1883input.y:21.1-16: warning: deprecated directive: '%no-default_prec', use '%no-default-prec' [-Wdeprecated]
1884input.y:22.1-16: warning: deprecated directive: '%no_default-prec', use '%no-default-prec' [-Wdeprecated]
1885input.y:23.1-9: warning: deprecated directive: '%no_lines', use '%no-lines' [-Wdeprecated]
1886input.y:24.1-9: warning: deprecated directive: '%output =', use '%output' [-Wdeprecated]
1887input.y:25.1-12: warning: deprecated directive: '%pure_parser', use '%pure-parser' [-Wdeprecated]
1888input.y:26.1-12: warning: deprecated directive: '%token_table', use '%token-table' [-Wdeprecated]
0f92546f
TR
1889]])
1890
1891AT_CLEANUP
1892
1893## ---------------------------- ##
1894## Unput's effect on locations. ##
1895## ---------------------------- ##
1896dnl When the scanner detects a deprecated construct, it unputs the correct
1897dnl version, but it should *not* have any impact on the scanner cursor. If it
1898dnl does, the locations of directives on the same line become erroneous.
1899
1900AT_SETUP([[Unput's effect on locations]])
1901
1902AT_KEYWORDS([[deprec]])
1903
1904AT_DATA_GRAMMAR([[input.y]],
1905[[
1906%glr-parser
1907%expect_rr 42 %expect_rr 42
1908 %expect_rr 42
1909%error_verbose %error_verbose
1910 %error_verbose
1911%% exp: '0'
1912]])
1913
1914AT_BISON_CHECK([[input.y]], [[1]], [[]],
1915[[input.y:11.1-10: warning: deprecated directive: '%expect_rr', use '%expect-rr' [-Wdeprecated]
1916input.y:11.15-24: warning: deprecated directive: '%expect_rr', use '%expect-rr' [-Wdeprecated]
1917input.y:12.15-24: warning: deprecated directive: '%expect_rr', use '%expect-rr' [-Wdeprecated]
1918input.y:13.1-14: warning: deprecated directive: '%error_verbose', use '%define parse.error verbose' [-Wdeprecated]
1919input.y:13.16-29: warning: deprecated directive: '%error_verbose', use '%define parse.error verbose' [-Wdeprecated]
1920input.y:13.11-21: error: %define variable 'parse.error' redefined
1921input.y:13-6: previous definition
1922input.y:14.16-29: warning: deprecated directive: '%error_verbose', use '%define parse.error verbose' [-Wdeprecated]
1923input.y:14.11-21: error: %define variable 'parse.error' redefined
1924input.y:13.11-21: previous definition
1925]])
1926
1927AT_CLEANUP
1928
1929##--------------------------- ##
1930## Non-deprecated directives. ##
1931## -------------------------- ##
1932
1933AT_SETUP([[Non-deprecated directives]])
1934
1935AT_KEYWORDS([[deprec]])
1936
1937AT_DATA_GRAMMAR([[input.y]],
1938[[
1939%default-prec
1940%error-verbose
1941%expect-rr 42
1942%file-prefix "foo"
1943%file-prefix
1944"bar"
1945%fixed-output-files
1946%name-prefix "foo"
1947%no-default-prec
1948%no-lines
1949%output "foo"
1950%pure-parser
1951%token-table
1952%% exp : '0'
1953]])
1954
1955AT_BISON_CHECK([[input.y]], [[0]], [[]],
1956[[input.y: warning: %expect-rr applies only to GLR parsers [-Wother]
1957]])
1958
1959AT_CLEANUP