]> git.donarmstrong.com Git - debbugs.git/commitdiff
[project @ 2000-10-07 14:26:47 by joy]
authorjoy <>
Sat, 7 Oct 2000 21:26:47 +0000 (13:26 -0800)
committerjoy <>
Sat, 7 Oct 2000 21:26:47 +0000 (13:26 -0800)
changed to use more variables and functions, added functionality of debbugs-maketxt

debian/debbugsconfig

index 4165878c1736a3881f0d871507cb91808ee53072..8819962d939b4bb4a82d18f728eade520e456fd5 100755 (executable)
@@ -1,59 +1,84 @@
 #!/usr/bin/perl
+# debbugsconfig: copies debbugs configuration files from templates, and
+#                creates documentation in HTML and text
 
-@file_flag = stat( '/etc/debbugs/config');
-if ( !@file_flag ) 
-{
-       system( '/bin/cp', '/usr/share/doc/debbugs/examples/config', '/etc/debbugs/config' );
-       print( "copying config file" );
-} else { print( "skipping config file" ); }
-
-@file_flag = stat( '/etc/debbugs/text');
-if ( !@file_flag ) 
-{
-       system( '/bin/cp', '/usr/share/doc/debbugs/examples/text', '/etc/debbugs/text' );
-       print( "copying text file" );
-} else { print( "skipping text file" ); }
-
-@file_flag = stat( '/var/lib/debbugs/spool/nextnumber');
-if ( !@file_flag ) 
-{
-       system( '/bin/cp', '/usr/share/doc/debbugs/examples/nextnumber', '/var/lib/debbugs/spool/nextnumber' );
-       print( "copying next file" );
-} else { print( "skipping next file" ); }
-
-require('/etc/debbugs/config');
-require('/etc/debbugs/text');
-
-chop($dtime=`date -u '+%H:%M:%S GMT %a %d %h'`);
+use POSIX qw(strftime);
+
+if (@ARGV) {
+  print STDOUT <<EOF;
+Usage: $0
+
+debbugsconfig will copy basic debbugs configuration files from templates
+if they don't exist.
+
+It will also create BTS user documentation in HTML and text.
+
+EOF
+  exit(0);
+}
+
+$gConfigDir = "/etc/debbugs" if (!defined($gConfigDir));
+&template("config");
+require "$gConfigDir/config";
+unshift @INC, $gConfigDir;
+
+&template("text");
+require "text";
+
+&template("nextnumber");
+
+my $dtime = strftime "%a, %e %b %Y %T UTC", localtime;
 $gHTMLTail =~ s/SUBSTITUTE_DTIME/$dtime/;
 
-require('/etc/debbugs/html/Access.html');
-require('/etc/debbugs/html/Developer.html');
-require('/etc/debbugs/html/Reporting.html');
-require('/etc/debbugs/html/index.html');
-require('/etc/debbugs/html/server-control.html');
-require('/etc/debbugs/html/server-refcard.html');
-require('/etc/debbugs/html/server-request.html');
-
-&file( 'Access.html', 'bug-log-access.txt', $gAccessHtml );
-&file( 'Developer.html', 'bug-maint-info.txt', $gDeveloperHtml );
-&file( 'Reporting.html', 'bug-reporting.txt', $gReportingHtml );
-&file( 'index.html', '', $gIndexHtml );
-&file( 'server-control.html', 'bug-maint-mailcontrol.txt', $gControlHtml );
-&file( 'server-refcard.html', 'bug-mailserver-refcard.txt', $gRefcardHtml );
-&file( 'server-request.html', 'bug-log-mailserver.txt', $gRequestHtml );
-
-exec( '/usr/sbin/debbugs-maketxt' );
-quit(0);
-
-sub file {
-    local ($name,$txtname,$file)= @_;
-    unlink( "$gWebDir/$name" );
-    if( open( ORIG, ">$gWebDir/$name" ) ) {
-       print ORIG $file;
-               close( ORIG );
-               print "wrote $gWebDir/$name\n";
-    } else {
-       print "unable to write $gWebDir/$name\n";
-    }
+require('html/index.html.in');
+&writefiles ('index', '', $gIndexHtml );
+require('html/Access.html.in');
+&writefiles ('Access', 'bug-log-access', $gAccessHtml );
+require('html/Developer.html.in');
+&writefiles ('Developer', 'bug-maint-info', $gDeveloperHtml );
+require('html/Reporting.html.in');
+&writefiles ('Reporting', 'bug-reporting', $gReportingHtml );
+require('html/server-control.html.in');
+&writefiles ('server-control', 'bug-maint-mailcontrol', $gControlHtml );
+require('html/server-refcard.html.in');
+&writefiles ('server-refcard', 'bug-mailserver-refcard', $gRefcardHtml );
+require('html/server-request.html.in');
+&writefiles ('server-request', 'bug-log-mailserver', $gRequestHtml );
+
+exit(0);
+
+# -------------------------------------------------------------------------- #
+
+sub template {
+  my ($name) = @_;
+  if (! -f "$gConfigDir/$name") {
+  system("cp /usr/share/doc/debbugs/examples/$name $gConfigDir/$name") == 0 ||
+       die "$!";
+  print "created $gConfigDir/$name from template.";
+  }
+} 
+
+sub writefiles {
+  local ($html, $text, $name) = @_;
+# first HTML
+  unlink("$gWebDir/$html.html");
+  open(DEST, ">$gWebDir/$html.html") || die "$gWebDir/$html.html: $!";
+  print DEST $name;
+  close(DEST);
+  print "wrote $gWebDir/$html.html\n";
+# now text
+  return if ($text eq ""); # for index.html
+# This should be done with pipes instead of a temporary files, but lynx
+# doesn't read HTML from stdin :/
+  open(DEST, ">$gDocDir/$text.html") || die "$gDocDir/$text.html: $!";
+  $name =~ s,\nOther pages:\n.*?<hr>,,si;
+  print DEST $name;
+  close(DEST);
+  unlink("$gDocDir/$text.txt");
+  $ENV{'HOME'} = "/dev/null";
+  $ENV{'TERM'} = "linux";
+  system ("lynx -nolist -dump -cfg=$gConfigDir/html/lynx-cfg $gDocDir/$text.html > $gDocDir/$text.txt") == 0 ||
+    die "unable to write $gDocDir/$text.txt\n";
+  unlink("$gDocDir/$text.html") || die "can't remove temporary file $gDocDir/$text.html: $!";
+  print "wrote $gDocDir/$text.txt\n";
 }