summaryrefslogtreecommitdiff
path: root/mk/help/help.awk
diff options
context:
space:
mode:
authorrillig <rillig@pkgsrc.org>2007-01-02 17:22:30 +0000
committerrillig <rillig@pkgsrc.org>2007-01-02 17:22:30 +0000
commitb96150340c501935c694064616319c21e22036d3 (patch)
tree4c5bcd94e0554a86e7148b8078bc07a52c5341a8 /mk/help/help.awk
parentf099c6da906a0160f6cb400497ef8e99024a2976 (diff)
downloadpkgsrc-b96150340c501935c694064616319c21e22036d3.tar.gz
Rewrote the integrated help to show the complete pathname, not only the
RCS Id, of the file containing the documentation. When the documentation contains lines starting with "Keywords:", these lines are not shown by "make help", but all following words are checked for the topic.
Diffstat (limited to 'mk/help/help.awk')
-rw-r--r--mk/help/help.awk80
1 files changed, 48 insertions, 32 deletions
diff --git a/mk/help/help.awk b/mk/help/help.awk
index 181bc20ef23..528229fa88b 100644
--- a/mk/help/help.awk
+++ b/mk/help/help.awk
@@ -1,35 +1,53 @@
-# $NetBSD: help.awk,v 1.2 2006/11/04 22:05:43 rillig Exp $
+# $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...
#
BEGIN {
- no = 0; yes = 1;
- hline = "===============";
- hline = hline hline hline hline hline;
- found = no; var = no; comment = no; n = 0;
- rcsid = "";
- last_line_was_rcsid = no;
- last_line_was_empty = yes;
+ no = 0; yes = 1; always = 1;
+
topic = ENVIRON["TOPIC"];
uctopic = toupper(topic);
+ 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
}
-/.*/ {
+NF >= 1 {
if ($0 ~ /^#.*\$.*\$$/) {
- rcsid = $0;
last_line_was_rcsid = yes;
+ ignore_next_empty_line = yes;
} else {
- if (last_line_was_rcsid && $0 == "#") {
- # Skip this line
- } else if ($0 == "") {
- # Skip completely empty lines, too.
+ 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;
} else {
- lines[n++] = $0;
+ lines[nlines++] = $0;
}
last_line_was_rcsid = no;
}
}
-/./ {
+NF >= 2 {
# When looking for "configure", catch lines that contain
# "configure" and "CONFIGURE", but not "Configure".
w1 = ($1 == tolower($1)) ? toupper($1) : $1;
@@ -40,35 +58,33 @@ BEGIN {
(index(w1, "#"uctopic"?=") == 1) ||
(w1 == "#" && last_line_was_empty &&
(w2 == uctopic || w2 == uctopic":"))) {
- var = 1;
+ relevant = 1;
}
}
/^#/ {
- comment = 1;
+ comment_lines++;
}
-/^$/ {
- if (var && comment) {
+/^$/ || last_fname != FILENAME {
+ if (relevant && comment_lines > 2) {
found = yes;
- print hline;
- if (rcsid != "") { print rcsid; print "#"; }
- for (i = 0; i < n; i++) { print lines[i]; }
+ print "===> "last_fname":";
+ for (i = 0; i < nlines; i++) {
+ #print gensub(/^# ?/, "", "", lines[i]);
+ print lines[i];
+ }
}
- var = no; comment = no; n = 0;
+ relevant = no; comment_lines = 0; nlines = 0;
}
-/./ {
- last_line_was_empty = no;
-}
-/^#$/ || /^$/ {
- last_line_was_empty = yes;
+always {
+ last_line_was_empty = (/^#$/ || /^$/);
+ last_fname = FILENAME;
}
END {
- if (found) {
- print hline;
- } else {
+ if (!found) {
print "No help found for "topic".";
}
}