mirror of
https://git.savannah.gnu.org/git/bison.git
synced 2026-03-09 20:33:03 +00:00
calc++: don't rely on Automake to compile a C++ parser.
Basically, revert commit 609b3d8096,
Automake 1.11.3 is not safe enough for C++ parser.
* examples/calc++/calc++-parser.hh: Remove.
* examples/calc++/local.mk (examples/calc++/calc++-parser.stamp):
New.
examples: factor the extractions into a single step
extexi had to be run in the extraction directory. Now, it can be
given the files with expected output directory. This allows to
use $(*_extracted) variables (before we had to list again their
members, but limited to their base names). In turn, this also
allows fusing the extraction recipes into a single one.
Also, it is currently too hard (or requires too much duplication,
since Make wants all the occurrences of the files to be prefixed with
$(srcdir)/, which is something Automake cannot support for *_SOURCES)
to work in the source tree. So extract, and compile scanners and parsers
in the build tree.
* examples/extexi (basename): New.
(BEGIN): Now "file_wanted" maps base name to extracted file name.
* examples/calc++/local.mk, examples/mfcalc/local.mk,
* examples/rpcalc/local.mk: Fuse extraction rules into...
* examples/local.mk: Here.
(extract, extracted): New.
142 lines
3.6 KiB
Awk
142 lines
3.6 KiB
Awk
# Extract all examples from the manual source. -*- AWK -*-
|
|
|
|
# This file is part of GNU Bison
|
|
|
|
# Copyright (C) 1992, 2000-2001, 2005-2006, 2009-2012 Free Software
|
|
# Foundation, Inc.
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
# This script is for use with any Awk that conforms to POSIX.
|
|
# It was derived from a similar script tests/generate.awk in GNU m4.
|
|
#
|
|
# Usage: extexi input-file.texi ... -- [FILES to extract]
|
|
BEGIN {
|
|
if (!output_dir)
|
|
output_dir = ".";
|
|
for (argc = 1; argc < ARGC; ++argc)
|
|
if (ARGV[argc] == "--")
|
|
break;
|
|
for (i = argc + 1; i < ARGC; ++i)
|
|
file_wanted[basename(ARGV[i])] = ARGV[i];
|
|
ARGC = argc;
|
|
}
|
|
|
|
/^@node / {
|
|
if (seq > 0)
|
|
print "AT_CLEANUP";
|
|
|
|
split ($0, tmp, ",");
|
|
node = substr(tmp[1], 7);
|
|
seq = 0;
|
|
}
|
|
|
|
/^@comment file: / {
|
|
if (file = file_wanted[$3])
|
|
message(" GEN " file);
|
|
else
|
|
message("SKIP " $3);
|
|
}
|
|
|
|
/^@(small)?example$/, /^@end (small)?example$/ {
|
|
if (!file)
|
|
next;
|
|
|
|
if ($0 ~ /^@(small)?example$/)
|
|
{
|
|
input = files_output[file] ? "\n" : "";
|
|
|
|
# FNR is starting at 0 instead of 1, and
|
|
# #line report the line number of the *next* line.
|
|
# => + 2.
|
|
# Note that recent Bison support it, but not Flex.
|
|
if (file ~ /\.[chy]*$/)
|
|
input = "#line " (FNR + 1) " \"" FILENAME "\"\n";
|
|
next;
|
|
}
|
|
|
|
if ($0 ~ /^@end (small)?example$/)
|
|
{
|
|
if (input == "")
|
|
fatal("no contents: " file);
|
|
|
|
input = normalize(input);
|
|
# No spurious end of line: use printf.
|
|
if (files_output[file])
|
|
# The parens around the output file seem to be required
|
|
# by awk on Mac OS X Tiger (darwin 8.4.6).
|
|
printf ("%s", input) >> (output_dir "/" file);
|
|
else
|
|
printf ("%s", input) > (output_dir "/" file);
|
|
close (output_dir "/" file);
|
|
files_output[file] = 1;
|
|
|
|
file = input = "";
|
|
next;
|
|
}
|
|
|
|
input = input $0 "\n";
|
|
}
|
|
|
|
|
|
# We have to handle CONTENTS line per line, since anchors in AWK are
|
|
# referring to the whole string, not the lines.
|
|
function normalize(contents, i, lines, n, line, res) {
|
|
# Remove the Texinfo tags.
|
|
n = split (contents, lines, "\n");
|
|
# We don't want the last field which empty: it's behind the last \n.
|
|
for (i = 1; i < n; ++i)
|
|
{
|
|
line = lines[i];
|
|
|
|
# Whole line commands.
|
|
if (line ~ /^@(c |comment|dots|end (ignore|group)|ignore|group)/)
|
|
# Gperf accepts empty lines as valid input!!!
|
|
if (file ~ /\.gperf$/)
|
|
continue;
|
|
else
|
|
line = "";
|
|
|
|
gsub (/"@value\{VERSION\}"/, "\"" VERSION "\"", line)
|
|
gsub (/^@result\{\}/, "", line);
|
|
gsub (/^@error\{\}/, "", line);
|
|
gsub ("@[{]", "{", line);
|
|
gsub ("@}", "}", line);
|
|
gsub ("@@", "@", line);
|
|
gsub ("@comment.*", "", line);
|
|
|
|
res = res line "\n";
|
|
}
|
|
return res;
|
|
}
|
|
|
|
|
|
function basename(name, a, n) {
|
|
n = split (name, a, "/");
|
|
return a[n];
|
|
}
|
|
|
|
function message(msg) {
|
|
if (! message_printed[msg])
|
|
{
|
|
print "extexi: " msg > "/dev/stderr";
|
|
message_printed[msg] = 1;
|
|
}
|
|
}
|
|
|
|
function fatal(msg) {
|
|
message(msg);
|
|
exit 1
|
|
}
|