diff options
author | rillig <rillig@pkgsrc.org> | 2007-01-02 17:22:30 +0000 |
---|---|---|
committer | rillig <rillig@pkgsrc.org> | 2007-01-02 17:22:30 +0000 |
commit | b96150340c501935c694064616319c21e22036d3 (patch) | |
tree | 4c5bcd94e0554a86e7148b8078bc07a52c5341a8 /mk/help/help.awk | |
parent | f099c6da906a0160f6cb400497ef8e99024a2976 (diff) | |
download | pkgsrc-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.awk | 80 |
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"."; } } |