]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 552167: show_bug.cgi loads flagtypes from the database for each attachment
authorFrédéric Buclin <LpSolit@gmail.com>
Tue, 30 Mar 2010 21:44:38 +0000 (23:44 +0200)
committerFrédéric Buclin <LpSolit@gmail.com>
Tue, 30 Mar 2010 21:44:38 +0000 (23:44 +0200)
r/a=mkanat

Bugzilla/Flag.pm

index e6b7bb936dc0f2500345e6eb59757b2f62080615..ab8961967c6ad86aea64a60dce4953e9fbb91e4a 100644 (file)
@@ -54,6 +54,7 @@ whose names start with _ or a re specifically noted as being private.
 =cut
 
 use Scalar::Util qw(blessed);
+use Storable qw(dclone);
 
 use Bugzilla::FlagType;
 use Bugzilla::Hook;
@@ -1023,7 +1024,9 @@ sub _flag_types {
     }
 
     # Get all available flag types for the given product and component.
-    my $flag_types = Bugzilla::FlagType::match($vars);
+    my $cache = Bugzilla->request_cache->{flag_types_per_component}->{$vars->{target_type}} ||= {};
+    my $flag_data = $cache->{$vars->{component_id}} ||= Bugzilla::FlagType::match($vars);
+    my $flag_types = dclone($flag_data);
 
     $_->{flags} = [] foreach @$flag_types;
     my %flagtypes = map { $_->id => $_ } @$flag_types;
@@ -1033,8 +1036,7 @@ sub _flag_types {
     # or component).
     @$flags = grep { exists $flagtypes{$_->type_id} } @$flags;
     push(@{$flagtypes{$_->type_id}->{flags}}, $_) foreach @$flags;
-
-    return [sort {$a->sortkey <=> $b->sortkey || $a->name cmp $b->name} values %flagtypes];
+    return $flag_types;
 }
 
 =head1 SEE ALSO