Uggh; horrible inner loop screwing up all performance :-(

This might actually make the redis version unnecessary for most people!
And if it does, well shame on me for not instrumenting things at a more
granular level before going all "oh we need a cache!"

[In my defense, I blame redis for being such a sweet little tool that I
felt compelled to use it somehow!]

----

t/sequence failed because the test itself was in error; fixed.
This commit is contained in:
Sitaram Chamarty 2012-11-14 15:12:30 +05:30
parent 1f96180df0
commit d3d93961a0
4 changed files with 19 additions and 4 deletions

View file

@ -32,6 +32,7 @@ our $data_version = '';
our %repos; our %repos;
our %one_repo; our %one_repo;
our %groups; our %groups;
our %patterns;
our %configs; our %configs;
our %one_config; our %one_config;
our %split_conf; our %split_conf;
@ -326,8 +327,10 @@ sub memberships {
} }
} }
for my $i ( keys %groups ) { push @ret, @{ $groups{$base} } if exists $groups{$base};
if ( $base eq $i or $base =~ /^$i$/ or $base2 and ( $base2 eq $i or $base2 =~ /^$i$/ ) ) { push @ret, @{ $groups{$base2} } if $base2 and exists $groups{$base2};
for my $i ( keys %{ $patterns{groups} } ) {
if ( $base =~ /^$i$/ or $base2 and ( $base2 =~ /^$i$/ ) ) {
push @ret, @{ $groups{$i} }; push @ret, @{ $groups{$i} };
} }
} }

View file

@ -288,6 +288,8 @@ sub store_common {
my $cc = "conf/gitolite.conf-compiled.pm"; my $cc = "conf/gitolite.conf-compiled.pm";
my $compiled_fh = _open( ">", "$cc.new" ); my $compiled_fh = _open( ">", "$cc.new" );
my %patterns = ();
my $data_version = glrc('current-data-version'); my $data_version = glrc('current-data-version');
trace( 3, "data_version = $data_version" ); trace( 3, "data_version = $data_version" );
print $compiled_fh Data::Dumper->Dump( [$data_version], [qw(*data_version)] ); print $compiled_fh Data::Dumper->Dump( [$data_version], [qw(*data_version)] );
@ -301,7 +303,17 @@ sub store_common {
my %groups = %{ inside_out( \%groups ) }; my %groups = %{ inside_out( \%groups ) };
$dumped_data = Data::Dumper->Dump( [ \%groups ], [qw(*groups)] ); $dumped_data = Data::Dumper->Dump( [ \%groups ], [qw(*groups)] );
print $compiled_fh $dumped_data; print $compiled_fh $dumped_data;
# save patterns in %groups for faster handling of multiple repos, such
# as happens in the various POST_COMPILE scripts
for my $k (keys %groups) {
$patterns{groups}{$k} = 1 unless $k =~ $REPONAME_PATT;
}
} }
$dumped_data = Data::Dumper->Dump( [ \%patterns ], [qw(*patterns)] ) if %patterns;
print $compiled_fh $dumped_data;
print $compiled_fh Data::Dumper->Dump( [ \%split_conf ], [qw(*split_conf)] ) if %split_conf; print $compiled_fh Data::Dumper->Dump( [ \%split_conf ], [qw(*split_conf)] ) if %split_conf;
close $compiled_fh or _die "close compiled-conf failed: $!\n"; close $compiled_fh or _die "close compiled-conf failed: $!\n";

View file

@ -58,7 +58,7 @@ $UNSAFE_PATT = qr([`~#\$\&()|;<>]);
# find the rc file and 'do' it # find the rc file and 'do' it
# ---------------------------------------------------------------------- # ----------------------------------------------------------------------
my $current_data_version = "3.0"; my $current_data_version = "3.2";
my $rc = glrc('filename'); my $rc = glrc('filename');
if (-r $rc and -s $rc) { if (-r $rc and -s $rc) {

View file

@ -55,7 +55,7 @@ try "
confreset;confadd ' confreset;confadd '
@staff = u1 u2 u3 @staff = u1 u2 u3
@gfoo = foo/CREATOR/.+ @gfoo = foo/CREATOR/..*
repo @gfoo repo @gfoo
C = u1 C = u1
RW+ = CREATOR RW+ = CREATOR