1 # Exercising Bison Grammar Reduction. -*- Autotest -*-
2 # Copyright 2001 Free Software Foundation, Inc.
4 # This program is free software; you can redistribute it and/or modify
5 # it under the terms of the GNU General Public License as published by
6 # the Free Software Foundation; either version 2, or (at your option)
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
19 AT_BANNER([[Grammar Reduction.]])
22 ## ------------------- ##
23 ## Useless Terminals. ##
24 ## ------------------- ##
26 AT_SETUP([Useless Terminals])
47 AT_CHECK([[bison input.y]])
49 AT_CHECK([[sed -n '/^Grammar/q;/^$/!p' input.output]], 0,
50 [[Terminals which are not used:
66 ## ---------------------- ##
67 ## Useless Nonterminals. ##
68 ## ---------------------- ##
70 AT_SETUP([Useless Nonterminals])
91 AT_CHECK([[bison input.y]], 0, [],
92 [[input.y contains 9 useless nonterminals
95 AT_CHECK([[sed -n '/^Grammar/q;/^$/!p' input.output]], 0,
96 [[Useless nonterminals:
112 ## --------------- ##
114 ## --------------- ##
116 AT_SETUP([Useless Rules])
135 AT_CHECK([[bison input.y]], 0, [],
136 [[input.y contains 9 useless nonterminals and 9 useless rules
139 AT_CHECK([[sed -n '/^Grammar/q;/^$/!p' input.output]], 0,
140 [[Useless nonterminals:
150 Terminals which are not used:
176 ## ------------------- ##
177 ## Reduced Automaton. ##
178 ## ------------------- ##
180 # Check that the automaton is that as the for the grammar reduced by
183 AT_SETUP([Reduced Automaton])
185 # The non reduced grammar.
186 # ------------------------
187 AT_DATA([[not-reduced.y]],
188 [[/* A useless token. */
193 %output="not-reduced.c"
197 exp: useful { /* A useful action. */ }
198 | non_productive { /* A non productive action. */ }
201 not_reachable: useful { /* A not reachable action. */ }
204 non_productive: non_productive useless_token
205 { /* Another non productive action. */ }
210 AT_CHECK([[bison not-reduced.y]], 0, [],
211 [[not-reduced.y contains 2 useless nonterminals and 3 useless rules
214 AT_CHECK([[sed -n '/^Grammar/q;/^$/!p' not-reduced.output]], 0,
215 [[Useless nonterminals:
218 Terminals which are not used:
221 #2 exp: non_productive;
222 #3 not_reachable: useful;
223 #4 non_productive: non_productive useless_token;
226 # The reduced grammar.
227 # --------------------
228 AT_DATA([[reduced.y]],
229 [[/* A useless token. */
238 exp: useful { /* A useful action. */ }
239 // | non_productive { /* A non productive action. */ } */
242 //not_reachable: useful { /* A not reachable action. */ }
245 //non_productive: non_productive useless_token
246 // { /* Another non productive action. */ }
251 AT_CHECK([[bison reduced.y]])
253 # Comparing the parsers.
255 AT_CHECK([sed 's/not-reduced/reduced/g' not-reduced.c], 0, [expout])
261 ## ------------------- ##
262 ## Underivable Rules. ##
263 ## ------------------- ##
265 AT_SETUP([Underivable Rules])
272 exp: useful | underivable;
273 underivable: indirection;
274 indirection: underivable;
277 AT_CHECK([[bison input.y]], 0, [],
278 [[input.y contains 2 useless nonterminals and 3 useless rules
281 AT_CHECK([[sed -n '/^Grammar/q;/^$/!p' input.output]], 0,
282 [[Useless nonterminals:
287 #3 underivable: indirection;
288 #4 indirection: underivable;