--- loncom/interface/spreadsheet/studentcalc.pm 2005/03/10 17:33:57 1.29
+++ loncom/interface/spreadsheet/studentcalc.pm 2005/05/13 20:30:14 1.31
@@ -1,5 +1,5 @@
#
-# $Id: studentcalc.pm,v 1.29 2005/03/10 17:33:57 matthew Exp $
+# $Id: studentcalc.pm,v 1.31 2005/05/13 20:30:14 albertel Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -74,15 +74,15 @@ sub initialize {
}
sub initialize_package {
- $current_course = $ENV{'request.course.id'};
+ $current_course = $env{'request.course.id'};
&initialize_sequence_cache();
&load_cached_export_rows();
}
sub ensure_correct_sequence_data {
- if ($current_course ne $ENV{'request.course.id'}) {
+ if ($current_course ne $env{'request.course.id'}) {
&initialize_sequence_cache();
- $current_course = $ENV{'request.course.id'};
+ $current_course = $env{'request.course.id'};
}
return;
}
@@ -101,22 +101,29 @@ sub initialize_sequence_cache {
for my $sequence ($navmap->getById('0.0'), @all_sequences) {
if ($navmap->hasResource($sequence,sub { shift->is_problem(); }, 0)){
push(@Sequences,$sequence);
+ &get_resources($sequence);
}
}
}
+my %res_memoize;
sub get_resources {
my ($seq) = @_;
+ if (exists($res_memoize{$seq->symb()})) {
+ return @{$res_memoize{$seq->symb()}};
+ }
return () if (! defined($navmap) || ! ref($navmap));
my @resources = $navmap->retrieveResources($seq,
sub { shift->is_problem(); },
0,0,0);
+ $res_memoize{$seq->symb()}=\@resources;
return @resources;
}
sub clear_package {
undef(@Sequences);
undef(%Exportrows);
+ undef(%res_memoize);
&Apache::assesscalc::clear_package();
}
@@ -137,8 +144,8 @@ sub get_html_title {
my $self = shift;
my ($name,$desc,$time) = $self->get_title();
my $title = '
'.$name;
- if ($ENV{'user.name'} ne $self->{'name'} &&
- $ENV{'user.domain'} ne $self->{'domain'}) {
+ if ($env{'user.name'} ne $self->{'name'} &&
+ $env{'user.domain'} ne $self->{'domain'}) {
$title .= ' '.&Apache::loncommon::aboutmewrapper
($self->{'name'}.'@'.$self->{'domain'},
$self->{'name'},$self->{'domain'});
@@ -173,7 +180,7 @@ sub outsheet_html {
####################################
my @AssessFileNames = $self->othersheets('assesscalc');
my $editing_is_allowed = &Apache::lonnet::allowed('mgr',
- $ENV{'request.course.id'});
+ $env{'request.course.id'});
####################################
# Report any calculation errors #
####################################
@@ -221,7 +228,7 @@ END
$r->print($tableheader);
#
# Print out template row
- if (exists($ENV{'request.role.adv'}) && $ENV{'request.role.adv'}) {
+ if (exists($env{'request.role.adv'}) && $env{'request.role.adv'}) {
$r->print('Template | | '.
$self->html_template_row($num_uneditable,
$importcolor)."
\n");
@@ -234,7 +241,7 @@ END
$r->print("\n");
#
# Prepare to output rows
- if (exists($ENV{'request.role.adv'}) && $ENV{'request.role.adv'}) {
+ if (exists($env{'request.role.adv'}) && $env{'request.role.adv'}) {
$tableheader =<<"END";
@@ -319,7 +326,7 @@ sub assess_file_selector {
if (!defined($AssessFiles) || ! @$AssessFiles) {
return '';
}
- return '' if (! &Apache::lonnet::allowed('mgr',$ENV{'request.course.id'}));
+ return '' if (! &Apache::lonnet::allowed('mgr',$env{'request.course.id'}));
my $element_name = 'FileSelect_'.$row;
my $load_dialog = '