[LON-CAPA-cvs] cvs: loncom /interface lonprintout.pm

sakharuk lon-capa-cvs@mail.lon-capa.org
Wed, 22 May 2002 21:10:42 -0000


sakharuk		Wed May 22 17:10:42 2002 EDT

  Modified files:              
    /loncom/interface	lonprintout.pm 
  Log:
   corrected to print subdirectories
  
  
Index: loncom/interface/lonprintout.pm
diff -u loncom/interface/lonprintout.pm:1.30 loncom/interface/lonprintout.pm:1.31
--- loncom/interface/lonprintout.pm:1.30	Mon May 20 20:44:03 2002
+++ loncom/interface/lonprintout.pm	Wed May 22 17:10:42 2002
@@ -1,7 +1,7 @@
 # The LearningOnline Network
 # Printout
 #
-# $Id: lonprintout.pm,v 1.30 2002/05/21 00:44:03 albertel Exp $
+# $Id: lonprintout.pm,v 1.31 2002/05/22 21:10:42 sakharuk Exp $
 #
 # Copyright Michigan State University Board of Trustees
 #
@@ -75,12 +75,14 @@
 <input type="radio" name="choice" value="Standard LaTeX output for the top level sequence">  All problems from the top level sequence<br />
 <br />
 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(<<ENDMENUOUT2);
-<input type="radio" name="choice" value="Subdirectory print">  All problems from particular subdirectory <input type="text" name="subdirect" value="/res/"><br />
+<input type="radio" name="choice" value="Subdirectory print">  All problems from current subdirectory (where this particular problem is)<br />
 ENDMENUOUT2
-    }
-	$r->print(<<ENDMENUOUT3);
+}
+    $r->print(<<ENDMENUOUT3);
 <br /><hr /><br />
 <h1>And what page format do you prefer?</h1>
 <input type="radio" name="layout" value="CBI"> Two columns landscape <br />
@@ -201,43 +203,38 @@
 	    }
 	}	    
 	$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];
-		}
-	    }
-	    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;   
+    } 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];
 	    }
-	    $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') {