version 1.62, 2002/09/12 15:08:43
|
version 1.74, 2002/09/23 21:09:58
|
Line 48 use Apache::inputtags;
|
Line 48 use Apache::inputtags;
|
use Apache::grades; |
use Apache::grades; |
use Apache::edit; |
use Apache::edit; |
use Apache::File(); |
use Apache::File(); |
|
use Apache::lonnavmaps; |
use POSIX qw(strftime); |
use POSIX qw(strftime); |
use GDBM_File; |
use GDBM_File; |
|
|
Line 87 sub menu_for_output {
|
Line 88 sub menu_for_output {
|
<input type="hidden" name="phase" value="two"> |
<input type="hidden" name="phase" value="two"> |
<input type="hidden" name="url" value="$ENV{'form.postdata'}"> |
<input type="hidden" name="url" value="$ENV{'form.postdata'}"> |
<input type="radio" name="choice" value="Standard LaTeX output for current document" checked> Current document <b>$title_for_single_resource</b> |
<input type="radio" name="choice" value="Standard LaTeX output for current document" checked> Current document <b>$title_for_single_resource</b> |
(you will print what you saw on the screen)<br /> |
(prints what you just saw on the screen)<br /> |
ENDMENUOUT1 |
ENDMENUOUT1 |
if ((not $ENV{'request.role'}=~m/^au\./) and (not $ENV{'request.role'}=~m/^ca\./)) { |
if ((not $ENV{'request.role'}=~m/^au\./) and (not $ENV{'request.role'}=~m/^ca\./)) { |
$r->print(<<ENDMENUOUT2); |
$r->print(<<ENDMENUOUT2); |
<input type="radio" name="choice" value="Standard LaTeX output for the primary sequence"> All problems from the sequence <b>$title_for_sequence</b><br /> |
<input type="radio" name="choice" value="Standard LaTeX output for the primary sequence"> All problems from <b>$title_for_sequence</b><br /> |
<input type="radio" name="choice" value="Standard LaTeX output for whole primary sequence"> All problems plus any html/xml files from the sequence <b>$title_for_sequence</b><br /> |
<input type="radio" name="choice" value="Standard LaTeX output for whole primary sequence"> All problems plus any pages or html/xml files from <b>$title_for_sequence</b><br /> |
ENDMENUOUT2 |
ENDMENUOUT2 |
} |
} |
if ($ENV{'request.role'}=~m/^cc\./ or $ENV{'request.role'}=~m/^in\./ or $ENV{'request.role'}=~m/^ta\./) { |
if ($ENV{'request.role'}=~m/^cc\./ or $ENV{'request.role'}=~m/^in\./ or $ENV{'request.role'}=~m/^ta\./) { |
$r->print(<<ENDMENUOUT6); |
$r->print(<<ENDMENUOUT6); |
<input type="radio" name="choice" value="Standard LaTeX output for the top level sequence"> All problems in this course (<b>warning:</b> this may be time consuming) <br /> |
<input type="radio" name="choice" value="Standard LaTeX output for the top level sequence"> All problems in this course (<b>warning:</b> this may be time consuming) <br /> |
<br /> |
<br /> |
<input type="radio" name="choice" value="All class print"> All problems from the sequence <b>$title_for_sequence</b> for selected students<br /><br /> |
<input type="radio" name="choice" value="All class print"> All problems from <b>$title_for_sequence</b> for selected students<br /><br /> |
ENDMENUOUT6 |
ENDMENUOUT6 |
} |
} |
my $subdirtoprint = &Apache::lonnet::filelocation("",$ENV{'form.url'}); |
my $subdirtoprint = &Apache::lonnet::filelocation("",$ENV{'form.url'}); |
Line 315 sub additional_print_menu {
|
Line 316 sub additional_print_menu {
|
<input type="hidden" name="numberofstudents" value="$ENV{'form.numberofstudents'}"> |
<input type="hidden" name="numberofstudents" value="$ENV{'form.numberofstudents'}"> |
<input type="hidden" name="numberofproblems" value="$ENV{'form.numberofproblems'}"> |
<input type="hidden" name="numberofproblems" value="$ENV{'form.numberofproblems'}"> |
<input type="hidden" name="numberofcolumns" value="$ENV{'form.numberofcolumns'}"> |
<input type="hidden" name="numberofcolumns" value="$ENV{'form.numberofcolumns'}"> |
Define page layout parameters: <br /> |
Define one column layout parameters: <br /> |
<b>Width</b>: <input type="text" name="width" width="8" value="9cm"> <br /> |
<b>Width</b>: <input type="text" name="width" width="8" value="9cm"> <br /> |
<b>Height</b>: <input type="text" name="height" width="8" value="25.9cm"> <br /> |
<b>Height</b>: <input type="text" name="height" width="8" value="25.9cm"> <br /> |
<b>Left margin</b>: <input type="text" name="leftmargin" width="8" value="-0.57in"> <br /> |
<b>Left margin</b>: <input type="text" name="leftmargin" width="8" value="-0.57in"> <br /> |
Line 341 ENDPART
|
Line 342 ENDPART
|
|
|
my $choice = $ENV{'form.choice'}; |
my $choice = $ENV{'form.choice'}; |
my $layout = $ENV{'form.layout'}; |
my $layout = $ENV{'form.layout'}; |
my $numberofcolumns = $ENV{'form.numberofcolumns'}; |
my $numberofcolumns = $ENV{'form.numberofcolumns'}; |
|
my $papersize = $ENV{'form.papersize'}; |
my $laystyle = 'book'; |
my $laystyle = 'book'; |
my $result = ''; |
my $result = ''; |
my $number_of_columns = 1; |
my $number_of_columns = 1; #used only for pages to determine the width of the cell |
my $selectionmade = ''; |
my $selectionmade = ''; |
|
|
if ($choice eq 'Standard LaTeX output for current document') { |
if ($choice eq 'Standard LaTeX output for current document') { |
Line 360 ENDPART
|
Line 362 ENDPART
|
my $texversion=&Apache::lonnet::ssi($ENV{'form.url'}); |
my $texversion=&Apache::lonnet::ssi($ENV{'form.url'}); |
&Apache::lonnet::delenv('form.grade_target'); |
&Apache::lonnet::delenv('form.grade_target'); |
$result .= $texversion; |
$result .= $texversion; |
$result = &additional_cleanup($result); |
|
if ($ENV{'form.url'}=~m/\.page\s*$/) { |
if ($ENV{'form.url'}=~m/\.page\s*$/) { |
($result,$number_of_columns) = &page_cleanup($result); |
($result,$number_of_columns) = &page_cleanup($result); |
} |
} |
Line 369 ENDPART
|
Line 370 ENDPART
|
#-- minimal sequence to which the current document belongs |
#-- minimal sequence to which the current document belongs |
#-- where is the primary sequence containing file? |
#-- where is the primary sequence containing file? |
my $symbolic = &Apache::lonnet::symbread($ENV{'form.url'}); |
my $symbolic = &Apache::lonnet::symbread($ENV{'form.url'}); |
$symbolic =~ m/([^_]+)_/; |
my @sequence = split('___',$symbolic); |
my $primary_sequence = '/res/'.$1; |
my $primary_sequence = '/res/'.$sequence[0]; |
#-- open and analyses the primary sequence |
my @master_seq = &coming_from_hash($primary_sequence,$sequence[0]); |
my $sequence_file=&Apache::lonnet::filelocation("",$primary_sequence); |
|
my $sequencefilecontents=&Apache::lonnet::getfile($sequence_file); |
|
my @master_seq = &coming_from_hash($primary_sequence); |
|
#-- produce an output string |
#-- produce an output string |
|
my $flag_latex_header_remove = 'NO'; |
|
my $flag_page_in_sequence = 'NO'; |
for (my $i=0;$i<=$#master_seq;$i++) { |
for (my $i=0;$i<=$#master_seq;$i++) { |
my $urlp = $master_seq[$i]; |
my ($urlp,$symb) = split /&&/, $master_seq[$i]; |
if ($choice eq 'Standard LaTeX output for the primary sequence') { |
if ($choice eq 'Standard LaTeX output for the primary sequence') { |
|
#prints only problems |
$selectionmade = 2; |
$selectionmade = 2; |
if ($urlp =~ m/\.(problem|exam|quiz|assess|survey|form|library)/) { |
if ($urlp =~ m/\.(problem|exam|quiz|assess|survey|form|library)/) { |
my %moreenv; |
my %moreenv; |
$moreenv{'form.grade_target'}='tex'; |
$moreenv{'form.grade_target'}='tex'; |
&Apache::lonnet::appenv(%moreenv); |
&Apache::lonnet::appenv(%moreenv); |
my $texversion=&Apache::lonnet::ssi($urlp); |
&Apache::lonnet::logthis("Trying to get $urlp with symb $symb"); |
|
my $texversion=&Apache::lonnet::ssi($urlp,('symb'=>$symb)); |
&Apache::lonnet::delenv('form.grade_target'); |
&Apache::lonnet::delenv('form.grade_target'); |
|
if ($flag_latex_header_remove ne 'NO') { |
|
$texversion = &latex_header_footer_remove($texversion); |
|
} else { |
|
$texversion =~ s/\\end{document}//; |
|
} |
$result .= $texversion; |
$result .= $texversion; |
|
$flag_latex_header_remove = 'YES'; |
} |
} |
} elsif ($urlp =~ /\S+/) { |
} elsif ($urlp =~ /\S+/) { |
|
#prints problems, pages and any html/xml files |
$selectionmade = 3; |
$selectionmade = 3; |
my %moreenv; |
my %moreenv; |
$moreenv{'form.grade_target'}='tex'; |
$moreenv{'form.grade_target'}='tex'; |
&Apache::lonnet::appenv(%moreenv); |
&Apache::lonnet::appenv(%moreenv); |
my $texversion=&Apache::lonnet::ssi($urlp); |
my $texversion=&Apache::lonnet::ssi($urlp,('symb'=>$symb)); |
&Apache::lonnet::delenv('form.grade_target'); |
&Apache::lonnet::delenv('form.grade_target'); |
$result .= $texversion; |
if ($urlp =~ m/\.page/) { |
|
($texversion,my $number_of_columns_page) = &page_cleanup($texversion); |
|
if ($number_of_columns_page > $number_of_columns) {$number_of_columns=$number_of_columns_page;} |
|
$texversion =~ s/\\end{document}\d*/\\end{document}/; |
|
$flag_page_in_sequence = 'YES'; |
|
} |
|
if ($flag_latex_header_remove ne 'NO') { |
|
$texversion = &latex_header_footer_remove($texversion); |
|
} else { |
|
$texversion =~ s/\\end{document}//; |
|
} |
|
$result .= $texversion; |
|
$flag_latex_header_remove = 'YES'; |
} |
} |
} |
} |
$result = &additional_cleanup($result); |
if ($flag_page_in_sequence eq 'YES') {$result =~ s/\\usepackage{calc}/\\usepackage{calc}\\usepackage{longtable}/;} |
|
$result .= '\end{document}'; |
} elsif ($choice eq 'Standard LaTeX output for the top level sequence') { |
} elsif ($choice eq 'Standard LaTeX output for the top level sequence') { |
# where is the main sequence of the course? |
# where is the main sequence of the course? |
$selectionmade = 4; |
$selectionmade = 4; |
my $main_seq = '/res/'.$ENV{'request.course.uri'}; |
my $main_seq = '/res/'.$ENV{'request.course.uri'}; |
my $file=&Apache::lonnet::filelocation("",$main_seq); |
my @file_seq = &coming_from_hash_whole($main_seq); |
my $filecontents=&Apache::lonnet::getfile($file); |
my $flag_latex_header_remove = 'NO'; |
my @file_seq = &content_map($filecontents); |
|
for (my $iu=0;$iu<=$#file_seq;$iu++) { |
|
$file_seq[$iu]=~s/^"//; |
|
$file_seq[$iu]=~s/"$//; |
|
if ($file_seq[$iu]=~m/\S+/) { |
|
$file_seq[$iu]=&Apache::lonnet::filelocation("",$file_seq[$iu]); |
|
} else { |
|
$file_seq[$iu]= 'REMOVE IT PLEASE'; |
|
} |
|
} |
|
my $i=0; |
|
my $limit = $#file_seq; |
|
while ($i<=$limit) { |
|
unless ($file_seq[$i]=~m/\.(problem|page)/) { |
|
if ($file_seq[$i]=~m/\.sequence/) { |
|
my $filecontents=&Apache::lonnet::getfile($file_seq[$i]); |
|
my @newfile_seq = &content_map($filecontents); |
|
for (my $iu=0;$iu<=$#newfile_seq;$iu++) { |
|
$newfile_seq[$iu]=~s/^"//; |
|
$newfile_seq[$iu]=~s/"$//; |
|
if ($newfile_seq[$iu]=~m/\S+/) { |
|
$newfile_seq[$iu]=&Apache::lonnet::filelocation("",$newfile_seq[$iu]); |
|
} else { |
|
$newfile_seq[$iu]= 'REMOVE IT PLEASE'; |
|
} |
|
} |
|
splice @file_seq,$i,1,@newfile_seq; |
|
$i=0; |
|
$limit = $#file_seq; |
|
} else { |
|
splice @file_seq,$i,1,'REMOVE IT PLEASE'; |
|
} |
|
} |
|
$i++; |
|
} |
|
for (my $iu=0;$iu<=$#file_seq;$iu++) { |
|
if ($file_seq[$iu]=~m/REMOVE IT PLEASE/) { |
|
splice @file_seq,$iu,1; |
|
} |
|
} |
|
if ($file_seq[-1]=~m/REMOVE IT PLEASE/) { |
|
pop @file_seq; |
|
} |
|
#-- produce an output string |
#-- produce an output string |
for (my $i=0;$i<=$#file_seq;$i++) { |
for (my $i=0;$i<=$#file_seq;$i++) { |
my $urlp = $file_seq[$i]; |
my ($urlp,$symb) = split /&&/, $file_seq[$i]; |
$urlp=~s/\/home\/httpd\/html//; |
$urlp=~s/\/home\/httpd\/html//; |
if ($urlp=~m/\.(problem|exam|quiz|assess|survey|form|library)/) { |
if ($urlp=~m/\.(problem|exam|quiz|assess|survey|form|library)/) { |
my %moreenv; |
my %moreenv; |
$moreenv{'form.grade_target'}='tex'; |
$moreenv{'form.grade_target'}='tex'; |
&Apache::lonnet::appenv(%moreenv); |
&Apache::lonnet::appenv(%moreenv); |
my $texversion=&Apache::lonnet::ssi($urlp); |
my $texversion=&Apache::lonnet::ssi($urlp,('symb'=>$symb)); |
&Apache::lonnet::delenv('form.grade_target'); |
&Apache::lonnet::delenv('form.grade_target'); |
$result .= $texversion; |
if ($flag_latex_header_remove ne 'NO') { |
} |
$texversion = &latex_header_footer_remove($texversion); |
|
} else { |
|
$texversion =~ s/\\end{document}//; |
|
} |
|
$result .= $texversion; |
|
$flag_latex_header_remove = 'YES'; |
|
} |
} |
} |
$result = &additional_cleanup($result); |
$result .= '\end{document}'; |
} elsif ($choice eq 'All class print') { |
} elsif ($choice eq 'All class print') { |
#-- prints assignments for whole class or for selected students |
#-- prints assignments for whole class or for selected students |
$selectionmade = 5; |
$selectionmade = 5; |
my (@students,@st_output) = ((),()); |
my @students = (); |
for (my $i=0; $i<$ENV{'form.numberofstudents'};$i++) { |
for (my $i=0; $i<$ENV{'form.numberofstudents'};$i++) { |
if ($ENV{'form.whomtoprint'.$i}=~/:/) { |
if ($ENV{'form.whomtoprint'.$i}=~/:/) { |
push @students,$ENV{'form.whomtoprint'.$i}; |
push @students,$ENV{'form.whomtoprint'.$i}; |
Line 473 ENDPART
|
Line 458 ENDPART
|
} |
} |
#where is the primary sequence containing current resource (the same for all students)? |
#where is the primary sequence containing current resource (the same for all students)? |
my $symbolic = &Apache::lonnet::symbread($ENV{'form.url'}); |
my $symbolic = &Apache::lonnet::symbread($ENV{'form.url'}); |
$symbolic =~ m/([^_]+)_/; |
my @sequence = split('___',$symbolic); |
my $primary_sequence = '/res/'.$1; |
my $primary_sequence = '/res/'.$sequence[0]; |
#opens and analyses the primary sequence file, produces the array of resources |
my @master_seq = &coming_from_hash($primary_sequence,$sequence[0); |
my $sequence_file=&Apache::lonnet::filelocation("",$primary_sequence); |
#loop over students |
my $sequencefilecontents=&Apache::lonnet::getfile($sequence_file); |
my $flag_latex_header_remove = 'NO'; |
my @master_seq = &content_map($sequencefilecontents); |
|
#loop over students |
|
foreach my $person (@students) { |
foreach my $person (@students) { |
my $current_output = ''; |
my $current_output = ''; |
my ($usersection,$username,$userdomain) = split /:/,$person; |
my ($usersection,$username,$userdomain) = split /:/,$person; |
my $fullname = &Apache::grades::get_fullname($username,$userdomain); |
my $fullname = &Apache::grades::get_fullname($username,$userdomain); |
#goes through all resources, checks if they are available for current student, and produces output |
#goes through all resources, checks if they are available for current student, and produces output |
foreach my $curres (@master_seq) { |
foreach my $curresline (@master_seq) { |
$curres =~ s/^"//; |
my ($curres,$symb) = split /&&/, $curresline; |
$curres =~ s/"$//; |
if ($curres=~ m/\.(problem|exam|quiz|assess|survey|form|library)/) { |
if ($curres=~/\w+/) { |
|
my $symb = &Apache::lonnet::symbread($curres); |
|
my ($map,$id,$res_url) = split(/___/,$symb); |
my ($map,$id,$res_url) = split(/___/,$symb); |
if (&Apache::lonnet::allowed('bre',$res_url)) { |
if (&Apache::lonnet::allowed('bre',$res_url)) { |
my $rendered = &Apache::loncommon::get_student_view($symb,$username,$userdomain, |
my $rendered = &Apache::loncommon::get_student_view($symb,$username,$userdomain, |
$ENV{'request.course.id'},'tex'); |
$ENV{'request.course.id'},'tex'); |
|
if ($flag_latex_header_remove eq 'YES') { |
|
$rendered = &latex_header_footer_remove($rendered); |
|
} else { |
|
$rendered =~ s/\\end{document}//; |
|
} |
$current_output .= $rendered; |
$current_output .= $rendered; |
} |
} |
|
$flag_latex_header_remove = 'YES'; |
} |
} |
} |
} |
$current_output =~ s/\\begin{document}/\\begin{document}\\noindent\\parbox{\\minipagewidth}{\\noindent\\fbox{\\textbf{$fullname}}\\hskip 1\.4in } \\vskip 5 mm /; |
if ($current_output=~/\\documentclass/) { |
|
$current_output =~ s/\\begin{document}/\\begin{document}\\noindent\\parbox{\\minipagewidth}{\\noindent\\fbox{\\textbf{$fullname}}\\hskip 1\.4in } \\vskip 5 mm /; |
|
} else { |
|
$current_output = '\\vskip 3mm\noindent\parbox{\minipagewidth}{\noindent\fbox{\textbf{'.$fullname.'}}\hskip 1.4in } \vskip 5 mm '.$current_output; |
|
} |
$result .= $current_output; |
$result .= $current_output; |
} |
} |
$result = &additional_cleanup($result); |
$result .= '\end{document}'; |
} elsif ($choice eq 'Subdirectory print') { |
} elsif ($choice eq 'Subdirectory print') { |
#prints selected problems from the subdirectory |
#prints selected problems from the subdirectory |
$selectionmade = 6; |
$selectionmade = 6; |
Line 510 ENDPART
|
Line 501 ENDPART
|
if ($ENV{'form.whattoprint'.$i}=~/^\//) { |
if ($ENV{'form.whattoprint'.$i}=~/^\//) { |
push @list_of_files,$ENV{'form.whattoprint'.$i}; |
push @list_of_files,$ENV{'form.whattoprint'.$i}; |
} |
} |
} |
} |
|
my $flag_latex_header_remove = 'NO'; |
for (my $i=0;$i<=$#list_of_files;$i++) { |
for (my $i=0;$i<=$#list_of_files;$i++) { |
my $urlp = $list_of_files[$i]; |
my $urlp = $list_of_files[$i]; |
if ($urlp=~/\//) { |
if ($urlp=~/\//) { |
Line 523 ENDPART
|
Line 515 ENDPART
|
my $texversion=&Apache::lonnet::ssi($urlp); |
my $texversion=&Apache::lonnet::ssi($urlp); |
&Apache::lonnet::delenv('form.grade_target'); |
&Apache::lonnet::delenv('form.grade_target'); |
$texversion =~ s/(\\begin{document})/$1 {\\tiny\\begin{verbatim}$urlp\\end{verbatim}}/; |
$texversion =~ s/(\\begin{document})/$1 {\\tiny\\begin{verbatim}$urlp\\end{verbatim}}/; |
|
if ($flag_latex_header_remove ne 'NO') { |
|
$texversion = &latex_header_footer_remove($texversion); |
|
} else { |
|
$texversion =~ s/\\end{document}//; |
|
} |
$result .= $texversion; |
$result .= $texversion; |
} |
} |
|
$flag_latex_header_remove = 'YES'; |
} |
} |
$result = &additional_cleanup($result); |
$result .= '\end{document}'; |
} |
} |
#-- corrections for the different page formats |
#-------------------------------------------------------- corrections for the different page formats |
|
# my ($textwidth,$textheight,$offset) = (0,0,0); |
|
# if ($papersize=~/Letter/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/Legal/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/Ledger/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/Executive/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/A4/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/A3/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/A2/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/A5/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# } elsif($papersize=~/A6/) { |
|
# $textwidth = ; |
|
# $textheight = ; |
|
# $offset = ; |
|
# <option selected> Letter [8 1/2x11 in] </option> |
|
# <option> Legal [8 1/2x14 in] </option> |
|
# <option> Ledger/Tabloid [11x17 in] </option> |
|
# <option> Executive [7 1/2x10 in] </option> |
|
# <option> A2 [420x594 mm] </option> |
|
# <option> A3 [297x420 mm] </option> |
|
# <option> A4 [210x297 mm] </option> |
|
# <option> A5 [148x210 mm] </option> |
|
# <option> A6 [105x148 mm] </option> |
|
# |
|
# } |
|
|
if ($layout eq 'CBI' and $numberofcolumns eq '1') { |
if ($layout eq 'CBI' and $numberofcolumns eq '1') { |
$result =~ s/\\begin{document}/\\setlength{\\oddsidemargin}{-40pt}\\setlength{\\evensidemargin}{-60pt}\\setlength{\\topmargin}{200pt}\\setlength{\\textwidth}{4\.4in}\\setlength{\\textheight}{6\.8in}\\setlength{\\parindent}{20pt}\\setlength{\\marginparwidth}{90pt}\\setlength{\\textfloatsep}{8pt plus 2\.0pt minus 4\.0pt} \\begin{document}/; |
$result =~ s/\\begin{document}/\\setlength{\\oddsidemargin}{-40pt}\\setlength{\\evensidemargin}{-60pt}\\setlength{\\topmargin}{200pt}\\setlength{\\textwidth}{4\.4in}\\setlength{\\textheight}{6\.8in}\\setlength{\\parindent}{20pt}\\setlength{\\marginparwidth}{90pt}\\setlength{\\textfloatsep}{8pt plus 2\.0pt minus 4\.0pt} \\begin{document}/; |
$result =~ s/\$number_of_columns/$number_of_columns/g; |
$result =~ s/\$number_of_columns/$number_of_columns/g; |
Line 601 FINALEND
|
Line 648 FINALEND
|
} |
} |
|
|
|
|
sub coming_from_hash { |
sub coming_from_hash_whole { |
|
|
my $mainsequence = shift; |
my $mainsequence = shift; |
my @resourcelist = (); |
my @resourcelist = (); |
|
my $mapid = $hash{'map_pc_'.$mainsequence}; |
my $mapstart = $hash{'map_start_'.$mainsequence}; |
my $mapstart = $hash{'map_start_'.$mainsequence}; |
my $mapfinish = $hash{'map_finish_'.$mainsequence}; |
my $mapfinish = $hash{'map_finish_'.$mainsequence}; |
my $current_resource = $mapstart; |
my $current_resource = $mapstart; |
while ($current_resource ne $mapfinish) { |
while ($current_resource ne $mapfinish) { |
|
if ($hash{'src_'.$current_resource}=~/\.sequence$/) { |
|
push @resourcelist,&coming_from_hash_whole($hash{'src_'.$current_resource}); |
|
} else { |
|
$mainsequence =~ /\/res\/(.*)$/; |
|
my $presymb = $1; |
|
my $rid = $hash{'ids_'.$hash{'src_'.$current_resource}}; |
|
if ($rid=~/,/) { |
|
my @rid = split /,/, $rid; |
|
foreach my $rid_element (@rid) { |
|
if ($rid_element =~ m/^$mapid\.(\d*)/) { |
|
$rid = $1; |
|
last; |
|
} |
|
} |
|
} else { |
|
$rid =~ m/^$mapid\.(\d*)/; |
|
$rid = $1; |
|
} |
|
$hash{'src_'.$current_resource} =~ m/\/res\/(.*)$/; |
|
my $symb = $presymb.'___'.$rid.'___'.$1; |
|
push @resourcelist,$hash{'src_'.$current_resource}.'&&'.$symb; |
|
} |
|
$current_resource = $hash{'goesto_'.$hash{'to_'.$current_resource}}; |
|
} |
|
return @resourcelist; |
|
} |
|
|
|
|
|
sub coming_from_hash { |
|
|
|
my ($mainsequence,$symb) = @_; |
|
my @resourcelist = (); |
|
my $mapid = $hash{'map_pc_'.$mainsequence}; |
|
my $mapstart = $hash{'map_start_'.$mainsequence}; |
|
my $mapfinish = $hash{'map_finish_'.$mainsequence}; |
|
my ($presymb) = split(/___/,$symb); |
|
$presymb = $presymb.'___'; |
|
my $current_resource = $mapstart; |
|
while ($current_resource ne $mapfinish) { |
if (not $hash{'src_'.$current_resource}=~/\.sequence$/) { |
if (not $hash{'src_'.$current_resource}=~/\.sequence$/) { |
push @resourcelist,$hash{'src_'.$current_resource}; |
my $rid = $hash{'ids_'.$hash{'src_'.$current_resource}}; |
|
if ($rid=~/,/) { |
|
my @rid = split /,/, $rid; |
|
foreach my $rid_element (@rid) { |
|
if ($rid_element =~ m/^$mapid\.(\d*)/) { |
|
$rid = $1; |
|
last; |
|
} |
|
} |
|
} else { |
|
$rid =~ m/^$mapid\.(\d*)/; |
|
$rid = $1; |
|
} |
|
$hash{'src_'.$current_resource} =~ m/\/res\/(.*)$/; |
|
$symb = $presymb.$rid.'___'.$1; |
|
push @resourcelist,$hash{'src_'.$current_resource}.'&&'.$symb; |
} else { |
} else { |
push @resourcelist,&coming_from_hash($hash{'src_'.$current_resource}); |
push @resourcelist,&coming_from_hash($hash{'src_'.$current_resource}); |
} |
} |
$current_resource = $hash{'goesto_'.$hash{'to_'.$current_resource}}; |
$current_resource = $hash{'goesto_'.$hash{'to_'.$current_resource}}; |
} |
} |
|
#needs if final resource in the map (type="finish") contains something |
|
if (not $hash{'src_'.$current_resource}=~/\.sequence$/) { |
|
my $rid = $hash{'ids_'.$hash{'src_'.$current_resource}}; |
|
if ($rid=~/,/) { |
|
my @rid = split /,/, $rid; |
|
foreach my $rid_element (@rid) { |
|
if ($rid_element =~ m/^$mapid\.(\d*)/) { |
|
$rid = $1; |
|
last; |
|
} |
|
} |
|
} else { |
|
$rid =~ m/^$mapid\.(\d*)/; |
|
$rid = $1; |
|
} |
|
$hash{'src_'.$current_resource} =~ m/\/res\/(.*)$/; |
|
$symb = $presymb.$rid.'___'.$1; |
|
push @resourcelist,$hash{'src_'.$current_resource}.'&&'.$symb; |
|
} else { |
|
push @resourcelist,&coming_from_hash($hash{'src_'.$current_resource}); |
|
} |
return @resourcelist; |
return @resourcelist; |
} |
} |
|
|
|
|
|
sub latex_header_footer_remove { |
|
my $text = shift; |
|
$text =~ s/\\end{document}//; |
|
$text =~ s/\\documentclass([^&]*)\\begin{document}//; |
|
return $text; |
|
} |
|
|
|
|
sub character_chart { |
sub character_chart { |
my $result = shift; |
my $result = shift; |
$result =~ s/�?0?7;//g; |
$result =~ s/�?0?7;//g; |
Line 947 sub character_chart {
|
Line 1078 sub character_chart {
|
|
|
#'"` |
#'"` |
|
|
sub additional_cleanup { |
|
my $result = shift; |
|
my $first_app = index($result,'\documentclass',0); |
|
$first_app = index($result,'\documentclass',$first_app+5); |
|
while ($first_app != -1) { |
|
my $second_app = index($result,'begin{document}',$first_app); |
|
$first_app = rindex($result,'\end{document}',$first_app); |
|
substr($result,$first_app,$second_app-$first_app+15) = '\vskip 3 mm'; |
|
$first_app = index($result,'\documentclass',$first_app+5); |
|
} |
|
return $result; |
|
} |
|
sub page_cleanup { |
sub page_cleanup { |
my $result = shift; |
my $result = shift; |
$_ = $result; |
|
m/\\end{document}(\d*)$/; |
$result =~ m/\\end{document}(\d*)$/; |
my $number_of_columns = $1; |
my $number_of_columns = $1; |
my $insert = '{'; |
my $insert = '{'; |
for (my $id=1;$id<=$number_of_columns;$id++) { $insert .='l'; } |
for (my $id=1;$id<=$number_of_columns;$id++) { $insert .='l'; } |
$insert .= '}'; |
$insert .= '}'; |
$result =~ s/(\\begin{longtable})INSERTTHEHEADOFLONGTABLE/$1$insert/g; |
$result =~ s/(\\begin{longtable})INSERTTHEHEADOFLONGTABLE\\endfirsthead\\endhead/$1$insert/g; |
$result =~ s/&\s*REMOVETHEHEADOFLONGTABLE\\\\/\\\\/g; |
$result =~ s/&\s*REMOVETHEHEADOFLONGTABLE\\\\/\\\\/g; |
$result =~ s/(\\vskip\s*\d+\s*mm)/}\\\\\\parbox{\\minipagewidth}{/g; |
|
$result =~ s/\\parbox{\\minipagewidth}{}\s*\\\\\s*(\\parbox{\\minipagewidth})/$1/g; |
|
$result =~ s/\\parbox{\\minipagewidth}{\s*\\\\\\\\/\\parbox{\\minipagewidth}{/g; |
|
return $result,$number_of_columns; |
return $result,$number_of_columns; |
} |
} |
|
|
sub content_map { |
|
#-- find a list of files to print |
|
my $map_string = shift; |
|
my @number_seq = (); |
|
my @file_seq = (); |
|
my $startlink = index($map_string,'<link',0); |
|
my $endlink = index($map_string,'</link>',$startlink); |
|
my $chunk = substr($map_string,$startlink,$endlink-$startlink+7); |
|
$_ = $chunk; |
|
m/from=\"(\d+)\"/; |
|
push @number_seq,$1; |
|
while ($startlink != -1) { |
|
$endlink = index($map_string,'</link>',$startlink); |
|
$chunk = substr($map_string,$startlink,$endlink-$startlink+7); |
|
substr($map_string,$startlink,$endlink-$startlink+7) = ''; |
|
$_ = $chunk; |
|
m/to=\"(\d+)\"/; |
|
push @number_seq,$1; |
|
$startlink = index($map_string,'from="'.$1.'"',0); |
|
$startlink = rindex($map_string,'<link ',$startlink); |
|
} |
|
my $stalink = index($map_string,' to="'.$number_seq[0].'"',0); |
|
while ($stalink != -1) { |
|
$startlink = rindex($map_string,'<link ',$stalink); |
|
$endlink = index($map_string,'</link>',$startlink); |
|
$chunk = substr($map_string,$startlink,$endlink-$startlink+7); |
|
substr($map_string,$startlink,$endlink-$startlink+7) = ''; |
|
$_ = $chunk; |
|
m/from=\"(\d+)\"/; |
|
unshift @number_seq,$1; |
|
$stalink = index($map_string,' to="'.$number_seq[0].'"',0); |
|
} |
|
for (my $i=0;$i<=$#number_seq;$i++) { |
|
$stalink = index($map_string,' id="'.$number_seq[$i].'"',0); |
|
{ |
|
my $ahed1 = index($map_string,'src="',$stalink); |
|
my $ahed2 = index($map_string,'</resource>',$stalink); |
|
if ($ahed1 != -1) { |
|
if ($ahed1 < $ahed2) { |
|
$startlink = $ahed1; |
|
} else { |
|
$startlink = rindex($map_string,'src="',$stalink); |
|
} |
|
} else { |
|
$startlink = rindex($map_string,'src="',$stalink); |
|
} |
|
|
|
} |
|
$startlink = index($map_string,'"',$startlink); |
|
$endlink = index($map_string,'"',$startlink+1); |
|
$chunk = substr($map_string,$startlink,$endlink-$startlink+1); |
|
push @file_seq,$chunk; |
|
} |
|
return @file_seq; |
|
} |
|
|
|
|
|
sub details_for_menu { |
sub details_for_menu { |
|
|
my $name_of_resourse = $hash{'title_'.$hash{'ids_'.$ENV{'form.postdata'}}}; |
my $name_of_resourse = $hash{'title_'.$hash{'ids_'.$ENV{'form.postdata'}}}; |
my $symbolic = &Apache::lonnet::symbread($ENV{'form.postdata'}); |
my $symbolic = &Apache::lonnet::symbread($ENV{'form.postdata'}); |
$symbolic =~ m/([^_]+)_/; |
my ($map,$id,$resource)=split(/___/,$symbolic); |
my $name_of_sequence = $hash{'title_'.$hash{'ids_/res/'.$1}}; |
my $name_of_sequence = $hash{'title_'.$hash{'ids_/res/'.$map}}; |
|
if ($name_of_sequence =~ /^\s*$/) { |
|
$map =~ m|([^/]+)$|; |
|
$name_of_sequence = $1; |
|
} |
my $name_of_map = $hash{'title_'.$hash{'ids_/res/'.$ENV{'request.course.uri'}}}; |
my $name_of_map = $hash{'title_'.$hash{'ids_/res/'.$ENV{'request.course.uri'}}}; |
|
if ($name_of_map =~ /^\s*$/) { |
return $name_of_resourse,$name_of_sequence,$name_of_map; |
$ENV{'request.course.uri'} =~ m|([^/]+)$|; |
|
$name_of_map = $1; |
|
} |
|
return ($name_of_resourse,$name_of_sequence,$name_of_map); |
|
|
} |
} |
|
|
Line 1048 sub details_for_menu {
|
Line 1116 sub details_for_menu {
|
sub handler { |
sub handler { |
|
|
my $r = shift; |
my $r = shift; |
|
|
|
my $loaderror=&Apache::lonnet::overloaderror($r); |
|
if ($loaderror) { return $loaderror; } |
|
$loaderror= |
|
&Apache::lonnet::overloaderror($r, |
|
$ENV{'course.'.$ENV{'request.course.id'}.'.home'}); |
|
if ($loaderror) { return $loaderror; } |
|
|
$r->content_type('text/html'); |
$r->content_type('text/html'); |
$r->send_http_header; |
$r->send_http_header; |
$r->print(&Apache::loncommon::bodytag("Printing")); |
$r->print(&Apache::loncommon::bodytag("Printing")); |
Line 1094 sub handler {
|
Line 1170 sub handler {
|
1; |
1; |
__END__ |
__END__ |
|
|
|
|
|
|
|
|
#### Test block |
|
# my $ere; |
|
# foreach $ere (%ENV) { |
|
# $result .= ' SS '.$ere.' => '.$ENV{$ere}.' FF '."\n\n"; |
|
# } |
|
#### |
|