2007-01-02 18:22:30 +01:00
|
|
|
# $NetBSD: help.awk,v 1.3 2007/01/02 17:22:30 rillig Exp $
|
|
|
|
#
|
|
|
|
|
|
|
|
# This program extracts the inline documentation from *.mk files.
|
|
|
|
#
|
|
|
|
# usage: env TOPIC="topic" awk help.awk file...
|
2006-10-23 16:40:14 +02:00
|
|
|
#
|
|
|
|
|
|
|
|
BEGIN {
|
2007-01-02 18:22:30 +01:00
|
|
|
no = 0; yes = 1; always = 1;
|
|
|
|
|
2006-10-23 16:40:14 +02:00
|
|
|
topic = ENVIRON["TOPIC"];
|
|
|
|
uctopic = toupper(topic);
|
2007-01-02 18:22:30 +01:00
|
|
|
lctopic = tolower(topic);
|
|
|
|
|
|
|
|
found_anything = no; # has some help text been found at all?
|
|
|
|
last_fname = "";
|
|
|
|
last_line_was_empty = yes;
|
|
|
|
last_line_was_rcsid = no;
|
|
|
|
ignore_next_empty_line = no;
|
|
|
|
|
|
|
|
delete lines; # the collected lines
|
|
|
|
relevant = no; # are the current lines relevant?
|
|
|
|
nlines = 0; # the number of lines collected so far
|
|
|
|
comment_lines = 0; # the number of comment lines so far
|
2006-10-23 16:40:14 +02:00
|
|
|
}
|
|
|
|
|
2007-01-02 18:22:30 +01:00
|
|
|
NF >= 1 {
|
2006-10-23 16:40:14 +02:00
|
|
|
if ($0 ~ /^#.*\$.*\$$/) {
|
|
|
|
last_line_was_rcsid = yes;
|
2007-01-02 18:22:30 +01:00
|
|
|
ignore_next_empty_line = yes;
|
2006-10-23 16:40:14 +02:00
|
|
|
} else {
|
2007-01-02 18:22:30 +01:00
|
|
|
if ($1 == "#" && $2 == "Keywords:") {
|
|
|
|
for (i = 3; i <= NF; i++) {
|
|
|
|
w = ($i == toupper($1)) ? tolower($i) : $i;
|
|
|
|
if (w == lctopic) {
|
|
|
|
relevant = yes;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
ignore_next_empty_line = yes;
|
|
|
|
} else if (ignore_next_empty_line && $0 == "#") {
|
|
|
|
ignore_next_empty_line = no;
|
2006-10-23 16:40:14 +02:00
|
|
|
} else {
|
2007-01-02 18:22:30 +01:00
|
|
|
lines[nlines++] = $0;
|
2006-10-23 16:40:14 +02:00
|
|
|
}
|
|
|
|
last_line_was_rcsid = no;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-01-02 18:22:30 +01:00
|
|
|
NF >= 2 {
|
2006-10-23 16:40:14 +02:00
|
|
|
# When looking for "configure", catch lines that contain
|
|
|
|
# "configure" and "CONFIGURE", but not "Configure".
|
|
|
|
w1 = ($1 == tolower($1)) ? toupper($1) : $1;
|
|
|
|
w2 = ($2 == tolower($2)) ? toupper($2) : $2;
|
|
|
|
|
|
|
|
if ((w1 == uctopic"?=") ||
|
2006-11-04 23:05:43 +01:00
|
|
|
(index(w1, "#"uctopic"=") == 1) ||
|
|
|
|
(index(w1, "#"uctopic"?=") == 1) ||
|
2006-10-23 16:40:14 +02:00
|
|
|
(w1 == "#" && last_line_was_empty &&
|
|
|
|
(w2 == uctopic || w2 == uctopic":"))) {
|
2007-01-02 18:22:30 +01:00
|
|
|
relevant = 1;
|
2006-10-23 16:40:14 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/^#/ {
|
2007-01-02 18:22:30 +01:00
|
|
|
comment_lines++;
|
2006-10-23 16:40:14 +02:00
|
|
|
}
|
|
|
|
|
2007-01-02 18:22:30 +01:00
|
|
|
/^$/ || last_fname != FILENAME {
|
|
|
|
if (relevant && comment_lines > 2) {
|
2006-10-23 16:40:14 +02:00
|
|
|
found = yes;
|
2007-01-02 18:22:30 +01:00
|
|
|
print "===> "last_fname":";
|
|
|
|
for (i = 0; i < nlines; i++) {
|
|
|
|
#print gensub(/^# ?/, "", "", lines[i]);
|
|
|
|
print lines[i];
|
|
|
|
}
|
2006-10-23 16:40:14 +02:00
|
|
|
}
|
2007-01-02 18:22:30 +01:00
|
|
|
relevant = no; comment_lines = 0; nlines = 0;
|
2006-10-23 16:40:14 +02:00
|
|
|
}
|
|
|
|
|
2007-01-02 18:22:30 +01:00
|
|
|
always {
|
|
|
|
last_line_was_empty = (/^#$/ || /^$/);
|
|
|
|
last_fname = FILENAME;
|
2006-10-23 16:40:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
END {
|
2007-01-02 18:22:30 +01:00
|
|
|
if (!found) {
|
2006-10-23 16:40:14 +02:00
|
|
|
print "No help found for "topic".";
|
|
|
|
}
|
|
|
|
}
|