| #!/usr/bin/perl |
| |
| use strict; |
| |
| ## Copyright (C) Michael Still (mikal@stillhq.com) |
| ## Released under the terms of the GNU GPL |
| ## |
| ## A script to make or install the manpages extracted by split-man |
| ## |
| ## Arguements: $1 -- the word "convert" or "install" |
| ## $2 -- the directory containing the SGML files for the manpages |
| ## $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, $tmpdir); |
| |
| if($ARGV[0] eq ""){ |
| die "Usage: makeman [convert | install] <dir> <file>\n"; |
| } |
| |
| 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>){ |
| s/<\/.*$//; |
| s/^.*>//; |
| s/\.sgml//; |
| s/struct //; |
| s/typedef //; |
| |
| chomp; |
| $filename = $_; |
| print "Processing $filename\n"; |
| |
| # Open the input file to extract the front matter, generate the man page, |
| # and open it, and the rearrange everything until it is happy |
| open INPUT, "< $ARGV[1]/$filename.sgml"; |
| $front = ""; |
| $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/<docinfo>//i; |
| s<\/docinfo>//i; |
| s/^[ \t]*//i; |
| } |
| |
| if($mode == 2){ |
| if(/<para>/i){ |
| } |
| elsif(/<\/para>/i){ |
| $front = "$front.\\\" \n"; |
| } |
| elsif(/<\/legalnotice>/i){ |
| $mode = 4; |
| } |
| elsif(/^[ \t]*$/){ |
| } |
| else{ |
| $front = "$front.\\\" $_"; |
| } |
| } |
| |
| if($mode == 1){ |
| 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>/i){ |
| $front = "$front.\\\" This documentation comes with the following legal notice:\n.\\\" \n"; |
| $mode = 2; |
| } |
| |
| elsif(/<author>/i){ |
| $front = "$front.\\\" Documentation by: "; |
| } |
| elsif(/<firstname>(.*)<\/firstname>/i){ |
| $front = "$front$1 "; |
| } |
| elsif(/<surname>(.*)<\/surname>/i){ |
| $front = "$front$1 "; |
| } |
| elsif(/<email>(.*)<\/email>/i){ |
| $front = "$front($1)"; |
| } |
| elsif(/\/author>/i){ |
| $front = "$front\n"; |
| } |
| |
| elsif(/<copyright>/i){ |
| $front = "$front.\\\" Documentation copyright: "; |
| } |
| elsif(/<holder>(.*)<\/holder>/i){ |
| $front = "$front$1 "; |
| } |
| elsif(/<year>(.*)<\/year>/i){ |
| $front = "$front$1 "; |
| } |
| elsif(/\/copyright>/i){ |
| $front = "$front\n"; |
| } |
| |
| elsif(/^[ \t]*$/ |
| || /<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($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 $tmpdir/$$.9\n"); |
| open GENERATED, "< $tmpdir/$$.9"; |
| open OUTPUT, "> $ARGV[1]/$filename.9"; |
| |
| print OUTPUT "$front"; |
| print OUTPUT ".\\\" For comments on the formatting of this manpage, please contact Michael Still <mikal\@stillhq.com>\n\n"; |
| while(<GENERATED>){ |
| print OUTPUT "$_"; |
| } |
| close OUTPUT; |
| close GENERATED; |
| |
| system("gzip -f $ARGV[1]/$filename.9\n"); |
| unlink("$tmpdir/$$.9"); |
| } |
| } |
| elsif($ARGV[0] eq "install"){ |
| system("mkdir -p /usr/local/man/man9/; install $ARGV[1]/*.9.gz /usr/local/man/man9/"); |
| } |
| else{ |
| die "Usage: makeman [convert | install] <dir> <file>\n"; |
| } |
| |
| print "Done\n"; |