--- loncom/interface/lonprintout.pm 2002/05/17 21:53:50 1.28 +++ loncom/interface/lonprintout.pm 2002/06/21 19:52:13 1.33 @@ -1,7 +1,7 @@ # The LearningOnline Network # Printout # -# $Id: lonprintout.pm,v 1.28 2002/05/17 21:53:50 sakharuk Exp $ +# $Id: lonprintout.pm,v 1.33 2002/06/21 19:52:13 sakharuk Exp $ # # Copyright Michigan State University Board of Trustees # @@ -75,12 +75,14 @@ sub menu_for_output { All problems from the top level sequence

ENDMENUOUT1 - if ($ENV{'user.adv'} eq '1') { + my $subdirtoprint = &Apache::lonnet::filelocation("",$ENV{'form.url'}); + $subdirtoprint =~ s/\/[^\/]+$//; + if (&Apache::lonnet::allowed('bre',$subdirtoprint) eq 'F') { $r->print(< All problems from particular subdirectory
+ All problems from current subdirectory (where this particular problem is)
ENDMENUOUT2 - } - $r->print(<print(<

And what page format do you prefer?

Two columns landscape
@@ -108,25 +110,19 @@ ENDPART my $choice = $ENV{'form.choice'}; my $layout = $ENV{'form.layout'}; - my $subdirtoprint = $ENV{'form.subdirect'}; my $laystyle = 'book'; my $result = ''; - my %mystyle; - my $filename; if ($choice eq 'Standard LaTeX output for current document') { my %moreenv; - my $currequest=$ENV{'request.filename'}; $moreenv{'form.grade_target'}='tex'; $moreenv{'request.filename'}=$ENV{'form.url'}; &Apache::lonnet::appenv(%moreenv); my $texversion=&Apache::lonnet::ssi($ENV{'form.url'}); &Apache::lonnet::delenv('form.grade_target'); - %moreenv = (); - $moreenv{'request.filename'}=$currequest; - &Apache::lonnet::appenv(%moreenv); $result .= $texversion; - + $result = &additional_cleanup($result); + if ($ENV{'form.url'}=~m/\.page\s*$/) {$result = &page_cleanup($result);} } elsif ($choice eq 'Standard LaTeX output for the primary sequence' or $choice eq 'Standard LaTeX output for whole primary sequence') { #-- where is the primary sequence containing file? my %moreenv; @@ -201,43 +197,38 @@ ENDPART } } $result = &additional_cleanup($result); - } elsif ($choice eq 'Subdirectory print') { - if (&Apache::lonnet::allowed('bre',$subdirtoprint) eq 'F') { - my $locald = &Apache::lonnet::filelocation("",$subdirtoprint); - unless (-e $locald) { -#do something in the case of the absence of this subdirectory on the local mashine -#replication process - } - my @list_of_files = (); - my @content_directory = &Apache::lonnet::dirlist($subdirtoprint); - for (my $iy=0;$iy<=$#content_directory;$iy++) { - my @tempo_array = split(/&/,$content_directory[$iy]); - $content_directory[$iy] = $tempo_array[0]; - if ($content_directory[$iy] =~ m/\.problem$/) { - push @list_of_files,$content_directory[$iy]; - } + } elsif ($choice eq 'Subdirectory print') { + my $subdirtoprint = &Apache::lonnet::filelocation("",$ENV{'form.url'}); + $subdirtoprint =~ s/\/[^\/]+$//; + my @list_of_files = (); + my $localdirectory = $subdirtoprint; + $localdirectory =~ s/.*(\/res\/)/$1/; + my @content_directory = &Apache::lonnet::dirlist($localdirectory); + for (my $iy=0;$iy<=$#content_directory;$iy++) { + my @tempo_array = split(/&/,$content_directory[$iy]); + $content_directory[$iy] = $tempo_array[0]; + if ($content_directory[$iy] =~ m/^[^\.]+\.problem$/) { + push @list_of_files,$content_directory[$iy]; } - for (my $i=0;$i<=$#list_of_files;$i++) { - $subdirtoprint =~ s/\/$//; - my $urlp = $subdirtoprint.'/'.$list_of_files[$i]; - my %moreenv; - $moreenv{'form.grade_target'}='tex'; - &Apache::lonnet::appenv(%moreenv); - my $texversion=&Apache::lonnet::ssi($urlp); - &Apache::lonnet::delenv('form.grade_target'); - $texversion =~ s/(\\begin{document})/$1 {\\tiny\\begin{verbatim}$urlp\\end{verbatim}}/; - $result .= $texversion; - } - $result = &additional_cleanup($result); - - } else { -#message "you not allowed to do this" } + $localdirectory =~ s/\/$//; + for (my $i=0;$i<=$#list_of_files;$i++) { + my $urlp = $localdirectory.'/'.$list_of_files[$i]; + my %moreenv; + $moreenv{'form.grade_target'}='tex'; + &Apache::lonnet::appenv(%moreenv); + my $texversion=&Apache::lonnet::ssi($urlp); + &Apache::lonnet::delenv('form.grade_target'); + $texversion =~ s/(\\begin{document})/$1 {\\tiny\\begin{verbatim}$urlp\\end{verbatim}}/; + $result .= $texversion; + } + $result = &additional_cleanup($result); + + - - + } #-- corrections for the different page formats if ($layout eq 'CBI') { @@ -249,7 +240,7 @@ ENDPART m/.*\/(.*)/; $courseidinfo = $ENV{'course.physnet_'.$1.'.description'}; $result =~ s/\\documentclass\[letterpaper\]{article}/\\documentclass\[twocolumn\]{article}/; - $result =~ s/\\begin{document}/\\textheight 25\.9cm\\oddsidemargin = -0\.57in\\evensidemargin = -0\.57in\\textwidth= 7\.7in\\renewcommand{\\ref}{\\keephidden\}\\begin{document}\\voffset=-1\.8cm\\setcounter{page}{1}\\noindent\\fbox{\\textbf{$ENV{'environment.firstname'} $ENV{'environment.lastname'}}}\\hskip 1\.4in $courseidinfo \\vskip 5 mm /; + $result =~ s/\\begin{document}/\\textheight 25\.9cm\\oddsidemargin = -0\.57in\\evensidemargin = -0\.57in\\textwidth= 7\.7in\\newlength{\\minipagewidth}\\setlength{\\minipagewidth}{\\textwidth\/2-0\.2in}\\renewcommand{\\ref}{\\keephidden\}\\begin{document}\\voffset=-1\.8cm\\setcounter{page}{1}\\noindent\\fbox{\\textbf{$ENV{'environment.firstname'} $ENV{'environment.lastname'}}}\\hskip 1\.4in $courseidinfo \\vskip 5 mm /; $result =~ s/\\includegraphics{/\\includegraphics\[width=9\.0 cm\]{/g; $result =~ s/(\\end{document})/\\newline\\noindent\\makebox\[9.0cm\]\[b\]{\\hrulefill}\\newline\\noindent\\tiny Dept\. of Physics and Astronomy, MSU\\makebox\[1.5cm\]\[b\]{\\hfill}LON-CAPA\\copyright MSU GNU\/GPL $1/; } @@ -269,9 +260,10 @@ ENDPART $result =~ s/{\\par }\s*\\\\/\\\\/gm; $result =~ s/\\\\\s+\[/ \[/g; $result =~ s/θ/\$\\theta\$/g; #converts theta from html into tex + $result =~ s/\b_+\b/\\makebox\[1 cm\]\[b\]{\\hrulefill}/g; #-- writing .tex file in prtspool my $temp_file; - $filename = "/home/httpd/prtspool/$ENV{'user.name'}$ENV{'user.domain'}temp$ENV{'user.login.time'}.tex"; + my $filename = "/home/httpd/prtspool/$ENV{'user.name'}_$ENV{'user.domain'}_printout_".time."_".rand(10000000).".tex"; unless ($temp_file = Apache::File->new('>'.$filename)) { $r->log_error("Couldn't open $filename for output $!"); return SERVER_ERROR; @@ -296,7 +288,17 @@ sub additional_cleanup { } return $result; } - +sub page_cleanup { + my $result = shift; + $_ = $result; + m/\\end{document}(\d*)$/; + my $insert = '{'; + for (my $id=1;$id<=$1;$id++) { $insert .='l'; } + $insert .= '}'; + $result =~ s/(\\begin{tabular})INSERT/$1$insert/g; + $result =~ s/&\s*REMOVE\\\\/\\end{tabular}\\\\\\begin{tabular}$insert/g; + return $result; +} sub content_map { #-- find a list of files to print