--- loncom/interface/printout.pl 2004/09/09 20:41:04 1.61.2.1 +++ loncom/interface/printout.pl 2004/08/04 18:19:11 1.62 @@ -1,7 +1,7 @@ #!/usr/bin/perl # CGI-script to run LaTeX, dvips, ps2ps, ps2pdf etc. # -# $Id: printout.pl,v 1.61.2.1 2004/09/09 20:41:04 albertel Exp $ +# $Id: printout.pl,v 1.62 2004/08/04 18:19:11 sakharuk Exp $ # # Copyright Michigan State University Board of Trustees # @@ -60,6 +60,7 @@ END my $texfile = $ENV{'cgi.'.$identifier.'.file'}; my $laystyle = $ENV{'cgi.'.$identifier.'.layout'}; my $numberofcolumns = $ENV{'cgi.'.$identifier.'.numcol'}; + my $paper = $ENV{'cgi.'.$identifier.'.paper'}; my $selectionmade = $ENV{'cgi.'.$identifier.'.selection'}; my $tableofcontents = $ENV{'cgi.'.$identifier.'tableofcontents'}; my $tableofindex = $ENV{'cgi.'.$identifier.'tableofindex'}; @@ -68,6 +69,7 @@ END my $student_names = $ENV{'cgi.'.$identifier.'studentnames'}; my $backref = $ENV{'cgi.'.$identifier.'backref'}; + my $adv = $ENV{'request.role.adv'}; my @names_pack=(); @@ -266,7 +268,11 @@ foreach $texfile (@texfile) { $name_file =~ s/\.tex/\.dvi/; my $new_name_file = $name_file; $new_name_file =~ s/\.dvi/\.ps/; - my $comma = "dvips -Ppdf -G0 -o $new_name_file"; + my @papers=('letter','legal','tabloid','executive','','a3','a4','a5',''); + my $papera=$papers[$paper]; + if ($papera eq 'letter') {$papera='';} + if ($papera ne '') {$papera='-t'.$papera;} + my $comma = "dvips $papera -Ppdf -G0 -o $new_name_file"; &busy_wait_command("$comma $name_file 1>/dev/null 2>/dev/null", "for $status_statement now Converting to PS", \%prog_state,$new_name_file); @@ -281,10 +287,12 @@ foreach $texfile (@texfile) { "for $status_statement now Modifying PS layout", \%prog_state,$tempo_file); } elsif ($laystyle eq 'book' and $numberofcolumns eq '2') { - $comma = 'pstops -pletter "2:0+1(0.48w,0)"'; - &busy_wait_command("$comma $new_name_file $tempo_file 1>/dev/null 2>/dev/null", - "for $status_statement now Modifying PS layout", - \%prog_state,$tempo_file); + my @papers=('letter','legal','tabloid','executive','','a3','a4','a5',''); + my $papera=$papers[$paper]; + if ($papera ne '') {$papera='-p'.$papera;} + $comma = 'pstops '.$papera.' "2:0+1(0.48w,0)"'; + system("$comma $new_name_file $tempo_file 1>/dev/null 2>/dev/null"); + system("ps2pdf $tempo_file $name_file 1>/dev/null 2>/dev/null"); } else { $ps_file=$new_name_file; } @@ -330,7 +338,11 @@ foreach $texfile (@texfile) { $name_file =~ s/\.tex/\.dvi/; my $new_name_file = $name_file; $new_name_file =~ s/\.dvi/\.ps/; - my $comma = "dvips -Ppdf -G0 -o $new_name_file"; + my @papers=('letter','legal','tabloid','executive','','a3','a4','a5',''); + my $papera=$papers[$paper]; + if ($papera eq 'letter') {$papera='';} + if ($papera ne '') {$papera='-t'.$papera;} + my $comma = "dvips $papera -Ppdf -G0 -o $new_name_file"; &busy_wait_command("$comma $name_file 1>/dev/null 2>/dev/null", "for $status_statement now Converting to PS", \%prog_state,$new_name_file); @@ -345,13 +357,28 @@ foreach $texfile (@texfile) { "for $status_statement now Modifying PS layout", \%prog_state,$tempo_file); } elsif ($laystyle eq 'book' and $numberofcolumns eq '2') { - $comma = 'pstops -pletter "2:0+1(0.48w,0)"'; + my @papers=('letter','legal','tabloid','executive','','a3','a4','a5',''); + my $papera=$papers[$paper]; + if ($papera ne '') {$papera='-p'.$papera;} + $comma = 'pstops -pa4 "2:0+1(0.48w,0)"'; &busy_wait_command("$comma $new_name_file $tempo_file 1>/dev/null 2>/dev/null", "for $status_statement now Modifying PS layout", \%prog_state,$tempo_file); } else { $ps_file=$new_name_file; } + if ($paper eq '6') { + open(FFH,'<',$ps_file) || die "Couldn't open file for reading: $!\n"; + my @content_of_file = ; + close(FFH); + open(FFH,'>',$ps_file) || die "Couldn't open file for writing: $!\n"; + print FFH '<< /PageSize [595.2 842] >> setpagedevice'."\n"; + for (my $i=0;$i<=$#content_of_file;$i++) { + print FFH $content_of_file[$i]; + print "
$i
"; + } + close(FFH); + } &busy_wait_command("ps2pdf $ps_file $pdf_file 1>/dev/null 2>/dev/null", "for $status_statement now Converting PS to PDF", \%prog_state,$pdf_file); @@ -367,7 +394,7 @@ foreach $texfile (@texfile) { my @garb = ($texlog,$texaux,$texdvi,$texps); # unlink @garb; unlink $duefile; - print "$link_text - click here to download pdf"; + print "$link_text"; print "\n"; } }