#!/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";
}