 1da177e4c3
			
		
	
	
	1da177e4c3
	
	
	
		
			
			Initial git repository build. I'm not bothering with the full history, even though we have it. We can create a separate "historical" git archive of that later if we want to, and in the meantime it's about 3.2GB when imported into git - space that would just make the early git days unnecessarily complicated, when we don't have a lot of good infrastructure for it. Let it rip!
		
			
				
	
	
		
			185 lines
		
	
	
	
		
			4.3 KiB
			
		
	
	
	
		
			Perl
		
	
	
		
			Executable file
		
	
	
	
	
			
		
		
	
	
			185 lines
		
	
	
	
		
			4.3 KiB
			
		
	
	
	
		
			Perl
		
	
	
		
			Executable file
		
	
	
	
	
| #!/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";
 |