version 1.139, 2009/03/24 10:15:15
|
version 1.141, 2009/04/17 10:02:49
|
Line 45 use strict;
|
Line 45 use strict;
|
|
|
my $busy_wait_timeout = 30; |
my $busy_wait_timeout = 30; |
|
|
|
|
|
my $debugging = 0; |
|
|
sub debug { |
sub debug { |
my ($text) = @_; |
if ($debugging) { |
print "$text <br />\n"; |
my ($text) = @_; |
|
print "$text <br />\n"; |
|
} |
} |
} |
|
|
# Determine if a user is operating as a student for this course/domain. |
# Determine if a user is operating as a student for this course/domain. |
Line 118 sub send_error_mail {
|
Line 123 sub send_error_mail {
|
|
|
if (&is_student()) { |
if (&is_student()) { |
# build the subject and message body: |
# build the subject and message body: |
# print "sending message to course coordinators.<br />"; |
&debug("sending message to course coordinators."); |
|
|
# Todo: Convert badurl into a url from file path: |
# Todo: Convert badurl into a url from file path: |
|
|
Line 137 sub send_error_mail {
|
Line 142 sub send_error_mail {
|
} |
} |
my (undef, %receivers) = &Apache::lonmsg::decide_receiver(undef, 0, |
my (undef, %receivers) = &Apache::lonmsg::decide_receiver(undef, 0, |
1,1,1); |
1,1,1); |
# print "<br /> sending...section: $env{'request.course.sec'}"; |
&debug("sending...section: $env{'request.course.sec'}"); |
foreach my $dest (keys %receivers) { |
foreach my $dest (keys %receivers) { |
# print "<br /> dest is $dest"; |
&debug("dest is $dest"); |
my @destinfo = split(/:/,$dest); |
my @destinfo = split(/:/,$dest); |
my $user = $destinfo[0]; |
my $user = $destinfo[0]; |
my $dom = $destinfo[1]; |
my $dom = $destinfo[1]; |
Line 211 $duefile =~ s/^(.*_printout)_\d+_\d+_\d+
|
Line 216 $duefile =~ s/^(.*_printout)_\d+_\d+_\d+
|
# it contains the names of the files that need to be converted, one per line. |
# it contains the names of the files that need to be converted, one per line. |
# |
# |
|
|
|
&debug("Figure file is $figfile"); |
|
|
if (-e $figfile) { |
if (-e $figfile) { |
# print "$figfile exists\n"; |
&debug( "Figure file exists"); |
|
&debug("$figfile exists"); |
my %done_conversion; |
my %done_conversion; |
my $temporary_file=IO::File->new($figfile) || die "Couldn't open fig file $figfile for reading: $!\n"; |
my $temporary_file=IO::File->new($figfile) || die "Couldn't open fig file $figfile for reading: $!\n"; |
my @content_of_file = <$temporary_file>; |
my @content_of_file = <$temporary_file>; |
Line 223 if (-e $figfile) {
|
Line 231 if (-e $figfile) {
|
print('<br />'); |
print('<br />'); |
foreach my $not_eps (@content_of_file) { |
foreach my $not_eps (@content_of_file) { |
chomp($not_eps); |
chomp($not_eps); |
|
&debug( "Being asked to convert $not_eps"); |
if ($not_eps ne '') { |
if ($not_eps ne '') { |
$not_eps=~s|\/\.\/|\/|g; |
$not_eps=~s|\/\.\/|\/|g; |
if (!$done_conversion{$not_eps}) { # Only convert multiple includes once. |
if (!$done_conversion{$not_eps}) { # Only convert multiple includes once. |
Line 404 foreach $texfile (@texfile) {
|
Line 413 foreach $texfile (@texfile) {
|
if ($papera eq 'letter') {$papera='';} |
if ($papera eq 'letter') {$papera='';} |
if ($papera ne '') {$papera='-t'.$papera;} |
if ($papera ne '') {$papera='-t'.$papera;} |
my $extra_ps_header = $perlvar{'lonLib'} .'/includepsheader.ps'; |
my $extra_ps_header = $perlvar{'lonLib'} .'/includepsheader.ps'; |
&Apache::lonnet::logthis("Extra ps header: $extra_ps_header"); |
|
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"; |
&Apache::lonnet::logthis("dvips command: $comma"); |
|
&busy_wait_command("$comma $name_file 1>/dev/null 2>/dev/null", |
&busy_wait_command("$comma $name_file 1>/dev/null 2>/dev/null", |
"for $status_statement now Converting to PS", |
"for $status_statement now Converting to PS", |
\%prog_state,$new_name_file); |
\%prog_state,$new_name_file); |
Line 461 foreach $texfile (@texfile) {
|
Line 468 foreach $texfile (@texfile) {
|
my $pdf_file = $1.'.pdf'; |
my $pdf_file = $1.'.pdf'; |
$papera=~s/t/p/; |
$papera=~s/t/p/; |
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"; |
$comma = "fixps --force ".$new_name_file." | psnup $papera -2 -s1.0 "; |
&busy_wait_command("$comma $tempo_file 1>/dev/null 2>/dev/null", |
&debug("PSNUP command: $comma"); |
|
&busy_wait_command("$comma 1>$tempo_file 2>/dev/null", |
"for $status_statement now Modifying PS layout", |
"for $status_statement now Modifying PS layout", |
\%prog_state,$tempo_file); |
\%prog_state,$tempo_file); |
} elsif ($laystyle eq 'book' and $numberofcolumns eq '2') { |
} elsif ($laystyle eq 'book' and $numberofcolumns eq '2') { |
$comma = 'pstops '.$papera.' "2:0+1(0.48w,0)"'; |
$comma = 'fixps --force '.$new_name_file.' | pstops '.$papera.' "2:0+1(0.48w,0)"'; |
&busy_wait_command("$comma $new_name_file $tempo_file 1>/dev/null 2>/dev/null", |
&debug("PSTOPS command: $comma "); |
|
|
|
&busy_wait_command("$comma 1>$tempo_file 2>/dev/null", |
"for $status_statement now Modifying PS layout", |
"for $status_statement now Modifying PS layout", |
\%prog_state,$tempo_file); |
\%prog_state,$tempo_file); |
} else { |
} else { |
Line 494 foreach $texfile (@texfile) {
|
Line 504 foreach $texfile (@texfile) {
|
close(FFHS); |
close(FFHS); |
$ps_file=$new_ps_file; |
$ps_file=$new_ps_file; |
} |
} |
&busy_wait_command("ps2pdf $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 848 sub create_missing_fonts {
|
Line 858 sub create_missing_fonts {
|
# |
# |
sub convert_figure { |
sub convert_figure { |
my ($not_eps) = @_; |
my ($not_eps) = @_; |
|
&debug("in convert_figure"); |
|
|
my $status_statement='EPS picture for '.$not_eps; |
my $status_statement='EPS picture for '.$not_eps; |
my $eps_f = $not_eps; |
my $eps_f = $not_eps; |
Line 891 sub convert_figure {
|
Line 902 sub convert_figure {
|
&Apache::lonhtmlcommon::Update_PrgWin('',\%prog_state, |
&Apache::lonhtmlcommon::Update_PrgWin('',\%prog_state, |
'Converting to EPS '.$prettyname); |
'Converting to EPS '.$prettyname); |
} |
} |
system("convert $not_eps $eps_f"); |
# |
|
# If the file is a PDF, need to use pdftops to convert it to a ps file. |
|
# otherwise use imagemagik: |
|
# |
|
if($not_eps =~/\.(pdf|PDF)$/) { |
|
|
|
# |
|
# For whatever reason, pure postscript conversions have to be |
|
# in the same dir as the base file: |
|
# |
|
$eps_f = &basename($eps_f); |
|
$eps_f = $perlvar{'lonPrtDir'}.'/'.$eps_f; |
|
|
|
&debug("Converting pdf $not_eps to postscript: $eps_f"); |
|
system("pdftops $not_eps $eps_f"); |
|
} else { |
|
system("convert $not_eps $eps_f"); |
|
} |
|
|
if (not -e $eps_f) { |
if (not -e $eps_f) { |
# converting an animated gif creates either: |
# converting an animated gif creates either: |