version 1.163, 2017/01/29 13:07:14
|
version 1.176, 2024/11/01 00:08:03
|
Line 40 use Apache::lonlocal;
|
Line 40 use Apache::lonlocal;
|
use Apache::lonmsg(); |
use Apache::lonmsg(); |
use LONCAPA::Enrollment; |
use LONCAPA::Enrollment; |
use LONCAPA::Configuration; |
use LONCAPA::Configuration; |
|
use LONCAPA; |
|
use Archive::Zip qw( :ERROR_CODES ); |
|
|
use strict; |
use strict; |
|
|
Line 201 my $tableofindex = $env{'cgi.'.$identifi
|
Line 203 my $tableofindex = $env{'cgi.'.$identifi
|
my $advanced_role = $env{'cgi.'.$identifier.'.role'}; |
my $advanced_role = $env{'cgi.'.$identifier.'.role'}; |
my $number_of_files = $env{'cgi.'.$identifier.'.numberoffiles'}+1; |
my $number_of_files = $env{'cgi.'.$identifier.'.numberoffiles'}+1; |
my $student_names = $env{'cgi.'.$identifier.'.studentnames'}; |
my $student_names = $env{'cgi.'.$identifier.'.studentnames'}; |
my $backref = &Apache::lonnet::unescape($env{'cgi.'.$identifier.'.backref'}); |
my $backref = &unescape($env{'cgi.'.$identifier.'.backref'}); |
|
|
|
|
my @names_pack=(); |
my @names_pack=(); |
Line 209 if ($student_names=~/_END_/) {
|
Line 211 if ($student_names=~/_END_/) {
|
@names_pack=split(/_ENDPERSON_/,$student_names); |
@names_pack=split(/_ENDPERSON_/,$student_names); |
} |
} |
if ($backref) { |
if ($backref) { |
|
if ($backref =~ m{^(/uploaded/$LONCAPA::match_domain/$LONCAPA::match_courseid/default_\d+.page)}) { |
|
$backref = $1; |
|
} |
print('<p>'.&mt("[_1]Return[_2] to resource.", |
print('<p>'.&mt("[_1]Return[_2] to resource.", |
"<a href=\"$backref\"><b>","</b></a>").'</p>'); |
"<a href=\"$backref\"><b>","</b></a>").'</p>'); |
print('<p><a href="javascript:gopost(\'/adm/printout\',\''.$backref.'\');">'. |
print('<p><a href="javascript:gopost(\'/adm/printout\',\''.$backref.'\');">'. |
Line 442 foreach $texfile (@texfile) {
|
Line 447 foreach $texfile (@texfile) {
|
$new_name_file =~ s/\.dvi/\.ps/; |
$new_name_file =~ s/\.dvi/\.ps/; |
# Explicitly include a switch for papertype, otherwise dvips will default |
# Explicitly include a switch for papertype, otherwise dvips will default |
# to whatever is listed first in config.ps (which in most cases is a4). |
# to whatever is listed first in config.ps (which in most cases is a4). |
# Historically (since 2004) LON-CAPA printing expected to use the default, |
my $papera; |
# i.e., a papertype of a4, when the user selected letter [8 1/2 x 11 in] |
unless (($paper eq '') || (($laystyle eq 'album') && ($numberofcolumns eq '1'))) { |
# in the Layout options, so I follow that convention if $papera is letter. |
$papera='-t'.$paper; |
my $papera=$paper; |
} |
if ($papera eq 'letter') {$papera='a4';} |
|
if ($papera ne '') {$papera='-t'.$papera;} |
|
my $extra_ps_header = $perlvar{'lonLib'} .'/includepsheader.ps'; |
my $extra_ps_header = $perlvar{'lonLib'} .'/includepsheader.ps'; |
my $comma = "dvips $papera -h $extra_ps_header -Ppdf -G0 -o $new_name_file"; |
my $comma = "dvips $papera -h $extra_ps_header -Ppdf -G0 -o $new_name_file"; |
&busy_wait_command("$comma $name_file 1>/dev/null 2>/dev/null", |
&busy_wait_command("$comma $name_file 1>/dev/null 2>/dev/null", |
Line 502 foreach $texfile (@texfile) {
|
Line 505 foreach $texfile (@texfile) {
|
$new_name_file =~ m/^(.*)\./; |
$new_name_file =~ m/^(.*)\./; |
my $ps_file = my $tempo_file = $1.'temporar.ps'; |
my $ps_file = my $tempo_file = $1.'temporar.ps'; |
my $pdf_file = $1.'.pdf'; |
my $pdf_file = $1.'.pdf'; |
$papera=~s/t/p/; |
unless ($paper eq '') { |
|
$papera='-p'.$paper; |
|
} |
#---- |
#---- |
# The code below uses fixps to make pdf include in sequences work. |
# The code below uses fixps to make pdf include in sequences work. |
# |
# |
Line 517 foreach $texfile (@texfile) {
|
Line 522 foreach $texfile (@texfile) {
|
|
|
# Use gs to fix the postscript -> level 1.5 |
# Use gs to fix the postscript -> level 1.5 |
# .. if pdfs were included |
# .. if pdfs were included |
|
# |
|
# pswrite device was removed from ghostscript 9.09 and later, |
|
# (ps2write device is used instead). |
|
# check which device is available, and use as the value |
|
# passed via -sDEVICE= arg in gs call to fix the postscript. |
|
# |
|
|
if ($pdfs_converted > 0) { |
if ($pdfs_converted > 0) { |
$comma = "gs -sDEVICE=pswrite -dLanguageLevel=1.5 "; |
my @possdevices = qw(ps2write pswrite); |
&busy_wait_command("$comma -o $tempo_file $new_name_file 2>/dev/null 1>/dev/null", |
my $device; |
"for $status_statement now validating PS", |
foreach my $poss (@possdevices) { |
\%prog_state, $tempo_file); |
if (open(PIPE,"gs -h |grep ' $poss ' 2>&1 |")) { |
|
my $output = <PIPE>; |
|
close(PIPE); |
|
chomp($output); |
|
if ($output =~ /\Q $poss \E/) { |
|
$device = $poss; |
|
} |
|
} |
|
last if ($device ne ''); |
|
} |
|
if ($device ne '') { |
|
my ($major,$minor); |
|
if (open(PIPE,"gs -v |grep 'GPL Ghostscript' 2>&1 |")) { |
|
my $info = <PIPE>; |
|
close(PIPE); |
|
chomp($info); |
|
if ($info =~ /Ghostscript\s+(\d+)\.(\d+)/) { |
|
($major,$minor) = ($1,$2); |
|
} |
|
} |
|
$comma = "gs -sDEVICE=$device -dLanguageLevel=1.5 "; |
|
if (($major > 9) || (($major == 9) && ($minor >= 50))) { |
|
$comma .= '--permit-file-read=* '; |
|
} |
|
&busy_wait_command("$comma -o $tempo_file $new_name_file 2>/dev/null 1>/dev/null", |
|
"for $status_statement now validating PS", |
|
\%prog_state, $tempo_file); |
|
|
#--- |
#--- |
&busy_wait_command("mv $tempo_file $new_name_file", |
if (-e $tempo_file) { |
'File move', \%prog_state, $new_name_file); |
&busy_wait_command("mv $tempo_file $new_name_file", |
|
'File move', \%prog_state, $new_name_file); |
|
} |
|
} |
} |
} |
if ($laystyle eq 'album' and $numberofcolumns eq '2') { |
if ($laystyle eq 'album' and $numberofcolumns eq '2') { |
$comma = "psnup $papera -2 -s1.0 $new_name_file"; |
my $canscale; |
|
if (open(PIPE,"psnup --version 2>&1 |")) { |
|
while (<PIPE>) { |
|
chomp(); |
|
if (/^psnup\s+release\s+(\d+)/) { |
|
if ($1 < 2) { |
|
$canscale = 1; |
|
} |
|
last; |
|
} |
|
} |
|
close(PIPE); |
|
} |
|
if ($canscale) { |
|
$comma = "psnup $papera -2 -s1.0 $new_name_file"; |
|
} else { |
|
$comma = "psnup $papera -2 $new_name_file"; |
|
} |
&debug("PSNUP command: $comma"); |
&debug("PSNUP command: $comma"); |
&busy_wait_command("$comma $tempo_file 1>/dev/null 2>/dev/null", |
&busy_wait_command("$comma $tempo_file 1>/dev/null 2>/dev/null", |
"for $status_statement now Modifying PS layout", |
"for $status_statement now Modifying PS layout", |
Line 543 foreach $texfile (@texfile) {
|
Line 600 foreach $texfile (@texfile) {
|
} else { |
} else { |
$ps_file=$new_name_file; |
$ps_file=$new_name_file; |
} |
} |
my $addtoPSfile={'legal'=>'<< /PageSize [612 1008] >> setpagedevice', |
my $addtoPSfile={'letter'=>'<< /PageSize [612 792] >> setpagedevice', |
|
'legal'=>'<< /PageSize [612 1008] >> setpagedevice', |
'tabloid'=>'<< /PageSize [792 1224] >> setpagedevice', |
'tabloid'=>'<< /PageSize [792 1224] >> setpagedevice', |
'executive'=>,'<< /PageSize [540 720] >> setpagedevice', |
'executive'=>,'<< /PageSize [540 720] >> setpagedevice', |
'a2'=>'<< /PageSize [1195.02 1690.09] >> setpagedevice', |
'a2'=>'<< /PageSize [1195.02 1690.09] >> setpagedevice', |
Line 551 foreach $texfile (@texfile) {
|
Line 609 foreach $texfile (@texfile) {
|
'a4'=>'<< /PageSize [595.2 842] >> setpagedevice', |
'a4'=>'<< /PageSize [595.2 842] >> setpagedevice', |
'a5'=>'<< /PageSize [421.1 595.2] >> setpagedevice', |
'a5'=>'<< /PageSize [421.1 595.2] >> setpagedevice', |
'a6'=>'<< /PageSize [298.75 421.1] >> setpagedevice', |
'a6'=>'<< /PageSize [298.75 421.1] >> setpagedevice', |
}; |
}; |
if ($paper ne 'letter') { |
open(FFH,'<',$ps_file) || die "Couldn't open ps file $ps_file for reading: $!\n"; |
open(FFH,'<',$ps_file) || die "Couldn't open ps file $ps_file for reading: $!\n"; |
my $new_ps_file='new'.$ps_file; |
my $new_ps_file='new'.$ps_file; |
open(FFHS,'>',$new_ps_file) || die "Couldn't open new ps file $new_ps_file for reading: $!\n"; |
open(FFHS,'>',$new_ps_file) || die "Couldn't open new ps file $new_ps_file for reading: $!\n"; |
print FFHS $addtoPSfile->{$paper}."\n"; |
print FFHS $addtoPSfile->{$paper}."\n"; |
while (<FFH>) { |
while (<FFH>) { |
print FFHS $_; |
print FFHS $_; |
|
} |
|
close(FFH); |
|
close(FFHS); |
|
$ps_file=$new_ps_file; |
|
} |
} |
|
close(FFH); |
|
close(FFHS); |
|
$ps_file=$new_ps_file; |
&busy_wait_command("ps2pdf13 $ps_file $pdf_file 1>/dev/null 2>/dev/null", |
&busy_wait_command("ps2pdf13 $ps_file $pdf_file 1>/dev/null 2>/dev/null", |
"for $status_statement now Converting PS to PDF", |
"for $status_statement now Converting PS to PDF", |
\%prog_state,$pdf_file); |
\%prog_state,$pdf_file); |
Line 596 foreach $texfile (@texfile) {
|
Line 652 foreach $texfile (@texfile) {
|
.'</p>'; |
.'</p>'; |
} |
} |
} |
} |
|
if ($advanced_role) { &Apache::lonhtmlcommon::Close_PrgWin('',\%prog_state); } |
print "<br />"; |
print "<br />"; |
if ($number_of_files>1) { |
if ($number_of_files>1) { |
|
print('<p>'.&mt('Zip Output:')."\n"); |
|
my %zip_prog_state; |
|
if ($advanced_role) { %zip_prog_state=&Apache::lonhtmlcommon::Create_PrgWin('',$number_of_files); } |
my $zipfile=$texfile[0]; |
my $zipfile=$texfile[0]; |
$zipfile=~s/\.tex/\.zip/; |
$zipfile=~s/\.tex/\.zip/; |
my $statement="zip $zipfile"; |
my $zip = Archive::Zip->new(); |
|
my $counter = 0; |
foreach my $file (@texfile) { |
foreach my $file (@texfile) { |
$file=~s/\.tex/.\pdf/; |
$file=~s/\.tex/.\pdf/; |
$statement.=' '.$file; |
my $dest=$file; |
|
$dest=~s{^\Q$perlvar{'lonPrtDir'}\E}{prtspool}; |
|
$zip->addFile($file,$dest); |
|
$dest=~s/^prtspool//; |
|
$counter ++; |
|
if ($advanced_role) { |
|
&Apache::lonhtmlcommon::Update_PrgWin('',\%zip_prog_state, |
|
&mt('[_1] added to zip archive ([_2] of [_3]', |
|
$dest,$counter,$number_of_files)); |
|
} |
} |
} |
print('<p>'.&mt('Zip Output:')."\n<pre>\n"); |
if ($advanced_role) { |
system($statement); |
&Apache::lonhtmlcommon::Update_PrgWin('',\%zip_prog_state,&mt('Writing zip file')); |
print("</pre></p>\n"); |
} |
$zipfile=~s{^\Q$perlvar{'lonPrtDir'}\E}{/prtspool}; |
if ($zip->writeToFileNamed($zipfile) == AZ_OK) { |
print |
$zipfile=~s{^\Q$perlvar{'lonPrtDir'}\E}{/prtspool}; |
'<p>' |
print |
.&mt('A [_1]ZIP file[_2] of all the PDF files is ready for download.', |
'<p>' |
'<a href="'.$zipfile.'">','</a>') |
.&mt('A [_1]ZIP file[_2] of all the PDF files is ready for download.', |
.'</p>'; |
'<a href="'.$zipfile.'">','</a>') |
|
.'</p>'; |
|
} else { |
|
print '<p class="LC_error">'. |
|
&mt('An error occurred creating a ZIP file of all the PDF files'). |
|
'</p>'; |
|
} |
|
if ($advanced_role) { &Apache::lonhtmlcommon::Close_PrgWin('',\%zip_prog_state); } |
} |
} |
if ($advanced_role) { &Apache::lonhtmlcommon::Close_PrgWin('',\%prog_state); } |
|
print(&Apache::loncommon::end_page()); |
print(&Apache::loncommon::end_page()); |
my $done; |
my $done; |
|
|
Line 959 sub convert_figure {
|
Line 1035 sub convert_figure {
|
&File::Path::mkpath($path,0,0777); |
&File::Path::mkpath($path,0,0777); |
$not_eps =~ s/^\s+//; |
$not_eps =~ s/^\s+//; |
$not_eps =~ s/\s+$//; |
$not_eps =~ s/\s+$//; |
$not_eps =~ s/ /\\ /g; |
|
my $prettyname=$not_eps; |
my $prettyname=$not_eps; |
if ($advanced_role) { |
if ($advanced_role) { |
$prettyname=~s|$perlvar{'lonDocRoot'}/|/|; |
$prettyname=~s|$perlvar{'lonDocRoot'}/|/|; |
Line 979 sub convert_figure {
|
Line 1054 sub convert_figure {
|
$eps_f = $perlvar{'lonPrtDir'}.'/'.$eps_f; |
$eps_f = $perlvar{'lonPrtDir'}.'/'.$eps_f; |
|
|
&debug("Converting pdf $not_eps to postscript: $eps_f"); |
&debug("Converting pdf $not_eps to postscript: $eps_f"); |
system("pdftops $not_eps $eps_f"); |
my @args = ('pdftops',$not_eps,$eps_f); |
$pdfs_converted++; # Need to fix ps in last pass. |
system({$args[0]} @args); # Indirect object forces list processing mode. |
|
# See perlfunc documentation for exec(). |
|
if ($? and $advanced_role) { |
|
print '<p class="LC_warning">' |
|
.&mt('An error occurred during the conversion of [_1] to postscript.', |
|
'<span class="LC_filename">'.$prettyname.'</span>') |
|
.'</p>'; |
|
} else { |
|
$pdfs_converted++; # Need to fix ps in last pass. |
|
} |
} else { |
} else { |
system("convert $not_eps $eps_f"); |
my @args = ('convert',$not_eps,$eps_f); |
if($? and $advanced_role){ |
system({$args[0]} @args); # Indirect object forces list processing mode. |
print '<p class="LC_warning">' |
# See perlfunc documentation for exec(). |
.&mt('An error occurred during the conversion of [_1].', |
if ($? and $advanced_role) { |
|
print '<p class="LC_warning">' |
|
.&mt('An error occurred during the conversion of [_1].', |
'<span class="LC_filename">'.$prettyname.'</span>') |
'<span class="LC_filename">'.$prettyname.'</span>') |
.'<br />' |
.'<br />' |
.&mt('If possible try to save this image using different settings and republish it.') |
.&mt('If possible try to save this image using different settings and republish it.') |
.'</p>'; |
.'</p>'; |
} |
} |
} |
} |
|
|
if (not -e $eps_f) { |
if (not -e $eps_f) { |