186 lines
		
	
	
	
		
			4.3 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
		
		
			
		
	
	
			186 lines
		
	
	
	
		
			4.3 KiB
			
		
	
	
	
		
			Text
		
	
	
	
	
	
|   | #!/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"; |