aboutsummaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorAndrew Morton <akpm@osdl.org>2003-10-15 17:30:48 -0700
committerLinus Torvalds <torvalds@home.osdl.org>2003-10-15 17:30:48 -0700
commitab642d48be6a70a691d64dcc99cd0b52bc87a430 (patch)
treea11a9832fea56d6743de838bd0f86efd94ea20f9 /scripts
parentaa9a90bf00d9d80a21eb906afdb590b765246f61 (diff)
downloadhistory-ab642d48be6a70a691d64dcc99cd0b52bc87a430.tar.gz
[PATCH] Correct case sensitivity in make mandocs
From: Michael Still <mikal@stillhq.com> The attached patch corrects case sensitivity in the mandocs make target. XML is case insensitive, and a bunch of the kernel-doc assumes this. The makeman and splitman scripts incorrectly cared about case. This patch also updates the Docbook DTD version which the script generates.
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/makeman108
-rwxr-xr-xscripts/split-man2
2 files changed, 68 insertions, 42 deletions
diff --git a/scripts/makeman b/scripts/makeman
index 07b96e25ebc01..db3af647ee17f 100755
--- a/scripts/makeman
+++ b/scripts/makeman
@@ -12,7 +12,7 @@ use strict;
## $3 -- the filename which contained the sgmldoc output
## (I need this so I know which manpages to convert)
-my($LISTING, $GENERATED, $INPUT, $OUTPUT, $front, $mode, $filename);
+my($LISTING, $GENERATED, $INPUT, $OUTPUT, $front, $mode, $filename, $tmpdir);
if($ARGV[0] eq ""){
die "Usage: makeman [convert | install] <dir> <file>\n";
@@ -22,6 +22,13 @@ if( ! -d "$ARGV[1]" ){
die "Output directory \"$ARGV[1]\" does not exist\n";
}
+if($ENV{"TMPDIR"} ne ""){
+ $tmpdir = $ENV{"TMPDIR"};
+}
+else{
+ $tmpdir = "/tmp";
+}
+
if($ARGV[0] eq "convert"){
open LISTING, "grep \"<refentrytitle>\" $ARGV[2] |";
while(<LISTING>){
@@ -40,29 +47,38 @@ if($ARGV[0] eq "convert"){
open INPUT, "< $ARGV[1]/$filename.sgml";
$front = "";
$mode = 0;
- while(<INPUT>){
- if(/.*ENDFRONTTAG.*/){
- $mode = 0;
- }
+ # The modes used here are:
+ # mode = 0
+ # <!-- BEGINFRONTTAG -->
+ # <!-- <bookinfo> mode = 1
+ # <!-- <legalnotice> mode = 2
+ # <!-- ...GPL or whatever...
+ # <!-- </legalnotice> mode = 4
+ # <!-- </bookinfo> mode = 3
+ # <!-- ENDFRONTTAG -->
+ #
+ # ...doco...
+
+ # I know that some of the if statements in this while loop are in a funny
+ # order, but that is deliberate...
+ while(<INPUT>){
if($mode > 0){
s/<!-- //;
s/ -->//;
- s/<bookinfo>//;
- s/<\/bookinfo>//;
- s/<docinfo>//;
- s<\/docinfo>//;
- s/^[ \t]*//;
+ s/<docinfo>//i;
+ s<\/docinfo>//i;
+ s/^[ \t]*//i;
}
if($mode == 2){
- if(/<para>/){
+ if(/<para>/i){
}
- elsif(/<\/para>/){
+ elsif(/<\/para>/i){
$front = "$front.\\\" \n";
}
- elsif(/<\/legalnotice>/){
- $mode = 1;
+ elsif(/<\/legalnotice>/i){
+ $mode = 4;
}
elsif(/^[ \t]*$/){
}
@@ -72,69 +88,79 @@ if($ARGV[0] eq "convert"){
}
if($mode == 1){
- if(/<title>(.*)<\/title>/){
+ if(/<title>(.*)<\/title>/i){
$front = "$front.\\\" This documentation was generated from the book titled \"$1\", which is part of the Linux kernel source.\n.\\\" \n";
}
- elsif(/<legalnotice>/){
+ elsif(/<legalnotice>/i){
$front = "$front.\\\" This documentation comes with the following legal notice:\n.\\\" \n";
$mode = 2;
}
- elsif(/<author>/){
+ elsif(/<author>/i){
$front = "$front.\\\" Documentation by: ";
}
- elsif(/<firstname>(.*)<\/firstname>/){
+ elsif(/<firstname>(.*)<\/firstname>/i){
$front = "$front$1 ";
}
- elsif(/<surname>(.*)<\/surname>/){
+ elsif(/<surname>(.*)<\/surname>/i){
$front = "$front$1 ";
}
- elsif(/<email>(.*)<\/email>/){
+ elsif(/<email>(.*)<\/email>/i){
$front = "$front($1)";
}
- elsif(/\/author>/){
+ elsif(/\/author>/i){
$front = "$front\n";
}
- elsif(/<copyright>/){
+ elsif(/<copyright>/i){
$front = "$front.\\\" Documentation copyright: ";
}
- elsif(/<holder>(.*)<\/holder>/){
+ elsif(/<holder>(.*)<\/holder>/i){
$front = "$front$1 ";
}
- elsif(/<year>(.*)<\/year>/){
+ elsif(/<year>(.*)<\/year>/i){
$front = "$front$1 ";
}
- elsif(/\/copyright>/){
+ elsif(/\/copyright>/i){
$front = "$front\n";
}
elsif(/^[ \t]*$/
- || /<affiliation>/
- || /<\/affiliation>/
- || /<address>/
- || /<\/address>/
- || /<authorgroup>/
- || /<\/authorgroup>/
- || /<\/legalnotice>/
- || /<date>/
- || /<\/date>/
- || /<edition>/
- || /<\/edition>/){
+ || /<affiliation>/i
+ || /<\/affiliation>/i
+ || /<address>/i
+ || /<\/address>/i
+ || /<authorgroup>/i
+ || /<\/authorgroup>/i
+ || /<\/legalnotice>/i
+ || /<date>/i
+ || /<\/date>/i
+ || /<edition>/i
+ || /<\/edition>/i
+ || /<pubdate>/i
+ || /<\/pubdate>/i){
}
else{
print "Unknown tag in manpage conversion: $_";
}
}
- if(/.*BEGINFRONTTAG.*/){
- $mode = 1;
+ if($mode == 0){
+ if(/<bookinfo>/i){
+ $mode = 1;
+ }
+ }
+
+ if($mode == 4){
+ if(/<\/bookinfo>/i){
+ $mode = 3;
+ }
}
}
close INPUT;
- system("cd $ARGV[1]; docbook2man $filename.sgml; mv $filename.9 /tmp/$$.9\n");
- open GENERATED, "< /tmp/$$.9";
+ system("cd $ARGV[1]; docbook2man $filename.sgml; mv $filename.9 $tmpdir/$$.9\n");
+ open GENERATED, "< $tmpdir/$$.9";
open OUTPUT, "> $ARGV[1]/$filename.9";
print OUTPUT "$front";
@@ -146,7 +172,7 @@ if($ARGV[0] eq "convert"){
close GENERATED;
system("gzip -f $ARGV[1]/$filename.9\n");
- unlink("/tmp/$filename.9");
+ unlink("$tmpdir/$$.9");
}
}
elsif($ARGV[0] eq "install"){
diff --git a/scripts/split-man b/scripts/split-man
index 7970935a1dee1..03897fe6a75d7 100755
--- a/scripts/split-man
+++ b/scripts/split-man
@@ -52,7 +52,7 @@ while(<SGML>){
open REF, "> $ARGV[1]/$filename.sgml" or
die "Couldn't open output file \"$ARGV[1]/$filename.sgml\": $!\n";
print REF <<EOF;
-<!DOCTYPE refentry PUBLIC "-//Davenport//DTD DocBook V3.0//EN">
+<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook V4.1//EN">
<!-- BEGINFRONTTAG: The following is front matter for the parent book -->
$front