1 # Extract all examples from the manual source. -*- AWK -*-
3 # This file is part of GNU Bison
5 # Copyright (C) 1992, 2000-2001, 2005-2006, 2009-2012 Free Software
8 # This program is free software: you can redistribute it and/or modify
9 # it under the terms of the GNU General Public License as published by
10 # the Free Software Foundation, either version 3 of the License, or
11 # (at your option) any later version.
13 # This program is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 # GNU General Public License for more details.
18 # You should have received a copy of the GNU General Public License
19 # along with this program. If not, see <http://www.gnu.org/licenses/>.
21 # This script is for use with any Awk that conforms to POSIX.
22 # It was derived from a similar script tests/generate.awk in GNU m4.
24 # Usage: extexi input-file.texi ... -- [FILES to extract]
28 for (argc = 1; argc < ARGC; ++argc)
29 if (ARGV[argc] == "--")
31 for (i = argc + 1; i < ARGC; ++i)
32 file_wanted[basename(ARGV[i])] = ARGV[i];
41 node = substr(tmp[1], 7);
46 if (file = file_wanted[$3])
47 message(" GEN " file);
52 /^@(small)?example$/, /^@end (small)?example$/ {
56 if ($0 ~ /^@(small)?example$/)
58 input = files_output[file] ? "\n" : "";
60 # FNR is starting at 0 instead of 1, and
61 # #line report the line number of the *next* line.
63 # Note that recent Bison support it, but not Flex.
64 if (file ~ /\.[chy]*$/)
65 input = "#line " (FNR + 1) " \"" FILENAME "\"\n";
69 if ($0 ~ /^@end (small)?example$/)
72 fatal("no contents: " file);
74 input = normalize(input);
75 # No spurious end of line: use printf.
76 if (files_output[file])
77 # The parens around the output file seem to be required
78 # by awk on Mac OS X Tiger (darwin 8.4.6).
79 printf ("%s", input) >> (output_dir "/" file);
81 printf ("%s", input) > (output_dir "/" file);
82 close (output_dir "/" file);
83 files_output[file] = 1;
89 input = input $0 "\n";
93 # We have to handle CONTENTS line per line, since anchors in AWK are
94 # referring to the whole string, not the lines.
95 function normalize(contents, i, lines, n, line, res) {
96 # Remove the Texinfo tags.
97 n = split (contents, lines, "\n");
98 # We don't want the last field which empty: it's behind the last \n.
99 for (i = 1; i < n; ++i)
103 # Whole line commands.
104 if (line ~ /^@(c |comment|dots|end (ignore|group)|ignore|group)/)
105 # Gperf accepts empty lines as valid input!!!
106 if (file ~ /\.gperf$/)
111 gsub (/"@value\{VERSION\}"/, "\"" VERSION "\"", line)
112 gsub (/^@result\{\}/, "", line);
113 gsub (/^@error\{\}/, "", line);
114 gsub ("@[{]", "{", line);
115 gsub ("@}", "}", line);
116 gsub ("@@", "@", line);
117 gsub ("@comment.*", "", line);
125 function basename(name, a, n) {
126 n = split (name, a, "/");
130 function message(msg) {
131 if (! message_printed[msg])
133 print "extexi: " msg > "/dev/stderr";
134 message_printed[msg] = 1;
138 function fatal(msg) {