--- loncom/interface/multidownload.pl 2007/04/26 22:05:50 1.13
+++ loncom/interface/multidownload.pl 2007/04/26 23:07:34 1.15
@@ -2,7 +2,7 @@
# CGI-script to allow download of all essay submissions of
# multiple students.
#
-# $Id: multidownload.pl,v 1.13 2007/04/26 22:05:50 banghart Exp $
+# $Id: multidownload.pl,v 1.15 2007/04/26 23:07:34 banghart Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -82,7 +82,10 @@ if (&Apache::lonnet::allowed('vgr',$scop
my $uname = $env{'user.name'};
my $udom = $env{'user.domain'};
&mkpath($doc_zip_root."/zipdir/$uname$udom/$unique_path",0,0700);
+ my $file_problem = 0;
foreach my $stu (@stuchecked) {
+ my %files_saved;
+ my $file_increment = 2;
my ($stuname,$studom,$fullname) = split(/:/,$stu);
my %record = &Apache::lonnet::restore($symb,$courseid,$studom,$stuname);
foreach my $part (@part_response_id) {
@@ -94,7 +97,24 @@ if (&Apache::lonnet::allowed('vgr',$scop
my $file_name_only = $2;
&Apache::lonnet::repcopy($file);
my $source = &Apache::lonnet::filelocation("",$file);
- ©($source,"$doc_zip_root/zipdir/$uname$udom/$unique_path/$stuname/part$partid/resp$respid/$file_name_only");
+ my $destination = "$doc_zip_root/zipdir/$uname$udom/$unique_path/$stuname/part$partid/resp$respid/$file_name_only";
+ if (exists($files_saved{$destination})) {
+ # file has already been saved once
+ &Apache::lonnet::logthis("found duplicate file name");
+ &Apache::lonnet::logthis("destination was $destination");
+ $destination =~ /(^.*)(\..+$)/;
+ $destination = $1.$file_increment.$2;
+ &Apache::lonnet::logthis("destination is $destination");
+ $file_increment ++;
+ }
+ $files_saved{$destination} = 1;
+ if (!©($source,$destination)) {
+ if (!$file_problem) {
+ print &mt("Unable to create:
");
+ $file_problem = 1;
+ }
+ print ("$stuname/part$partid/resp$respid/$file_name_only
");
+ }
}
}
}