Commit f39fc76d authored by mkanat%bugzilla.org's avatar mkanat%bugzilla.org

Bug 147776: Make checksetup.pl re-write localconfig with the most modern comments.

Patch By Max Kanat-Alexander <mkanat@bugzilla.org> (module owner) a=mkanat
parent b45d242b
...@@ -64,6 +64,7 @@ sub FILESYSTEM { ...@@ -64,6 +64,7 @@ sub FILESYSTEM {
my $libdir = bz_locations()->{'libpath'}; my $libdir = bz_locations()->{'libpath'};
my $extlib = bz_locations()->{'ext_libpath'}; my $extlib = bz_locations()->{'ext_libpath'};
my $skinsdir = bz_locations()->{'skinsdir'}; my $skinsdir = bz_locations()->{'skinsdir'};
my $localconfig = bz_locations()->{'localconfig'};
my $ws_group = Bugzilla->localconfig->{'webservergroup'}; my $ws_group = Bugzilla->localconfig->{'webservergroup'};
...@@ -116,6 +117,8 @@ sub FILESYSTEM { ...@@ -116,6 +117,8 @@ sub FILESYSTEM {
'sanitycheck.pl' => { perms => $ws_executable }, 'sanitycheck.pl' => { perms => $ws_executable },
'install-module.pl' => { perms => $owner_executable }, 'install-module.pl' => { perms => $owner_executable },
"$localconfig.old" => { perms => $owner_readable },
'docs/makedocs.pl' => { perms => $owner_executable }, 'docs/makedocs.pl' => { perms => $owner_executable },
'docs/rel_notes.txt' => { perms => $ws_readable }, 'docs/rel_notes.txt' => { perms => $ws_readable },
'docs/README.docs' => { perms => $owner_readable }, 'docs/README.docs' => { perms => $owner_readable },
......
...@@ -187,12 +187,10 @@ EOT ...@@ -187,12 +187,10 @@ EOT
}, },
); );
use constant OLD_LOCALCONFIG_VARS => qw( # When you read the symbol table of a package in Perl (like we do to
mysqlpath # get the localconfig variables), there are some symbols that are always
contenttypes # there and should be ignored.
pages use constant IGNORE_SYMBOLS => qw(_ INC __ANON__);
severities platforms opsys priorities
);
sub read_localconfig { sub read_localconfig {
my ($include_deprecated) = @_; my ($include_deprecated) = @_;
...@@ -221,10 +219,24 @@ Please fix the error in your 'localconfig' file. Alternately, rename your ...@@ -221,10 +219,24 @@ Please fix the error in your 'localconfig' file. Alternately, rename your
EOT EOT
} }
my @vars = map($_->{name}, LOCALCONFIG_VARS); # First we have to get the whole symbol table
push(@vars, OLD_LOCALCONFIG_VARS) if $include_deprecated; my $safe_root = $s->root;
foreach my $var (@vars) { my %safe_package;
my $glob = $s->varglob($var); { no strict 'refs'; %safe_package = %{$safe_root . "::"}; }
# And now we read the contents of every var in the symbol table
# except those from IGNORE_SYMBOLS. If $include_deprecated is false,
# we also skip any vars that aren't specifically listed in
# LOCALCONFIG_VARS.
my @standard_vars = map($_->{name}, LOCALCONFIG_VARS);
foreach my $symbol (keys %safe_package) {
if (!$include_deprecated) {
next if !grep($_ eq $symbol, @standard_vars);
}
next if grep($_ eq $symbol, IGNORE_SYMBOLS);
# Perl 5.10 imports a lot of symbols that we want to ignore that
# all contain "::".
next if $symbol =~ /::/;
my $glob = $s->varglob($symbol);
# We can't get the type of a variable out of a Safe automatically. # We can't get the type of a variable out of a Safe automatically.
# We can only get the glob itself. So we figure out its type this # We can only get the glob itself. So we figure out its type this
# way, by trying first a scalar, then an array, then a hash. # way, by trying first a scalar, then an array, then a hash.
...@@ -234,13 +246,13 @@ EOT ...@@ -234,13 +246,13 @@ EOT
# fine since as I write this all modern localconfig vars are # fine since as I write this all modern localconfig vars are
# actually scalars. # actually scalars.
if (defined $$glob) { if (defined $$glob) {
$localconfig{$var} = $$glob; $localconfig{$symbol} = $$glob;
} }
elsif (defined @$glob) { elsif (defined @$glob) {
$localconfig{$var} = \@$glob; $localconfig{$symbol} = \@$glob;
} }
elsif (defined %$glob) { elsif (defined %$glob) {
$localconfig{$var} = \%$glob; $localconfig{$symbol} = \%$glob;
} }
} }
} }
...@@ -290,11 +302,6 @@ sub update_localconfig { ...@@ -290,11 +302,6 @@ sub update_localconfig {
} }
} }
my @old_vars;
foreach my $name (OLD_LOCALCONFIG_VARS) {
push(@old_vars, $name) if defined $localconfig->{$name};
}
if (!$localconfig->{'interdiffbin'} && $output) { if (!$localconfig->{'interdiffbin'} && $output) {
print <<EOT print <<EOT
...@@ -307,30 +314,41 @@ as well), you should install patchutils from: ...@@ -307,30 +314,41 @@ as well), you should install patchutils from:
EOT EOT
} }
my @old_vars;
foreach my $var (keys %$localconfig) {
push(@old_vars, $var) if !grep($_->{name} eq $var, LOCALCONFIG_VARS);
}
my $filename = bz_locations->{'localconfig'}; my $filename = bz_locations->{'localconfig'};
# Move any custom or old variables into a separate file.
if (scalar @old_vars) { if (scalar @old_vars) {
my $filename_old = "$filename.old";
open(my $old_file, ">>$filename_old") || die "$filename_old: $!";
local $Data::Dumper::Purity = 1;
foreach my $var (@old_vars) {
print $old_file Data::Dumper->Dump([$localconfig->{$var}],
["*$var"]) . "\n\n";
}
close $old_file;
my $oldstuff = join(', ', @old_vars); my $oldstuff = join(', ', @old_vars);
print <<EOT print <<EOT
The following variables are no longer used in $filename, and The following variables are no longer used in $filename, and
should be removed: $oldstuff have been moved to $filename_old: $oldstuff
EOT EOT
} }
if (scalar @new_vars) { # Re-write localconfig
my $filename = bz_locations->{'localconfig'}; open(my $fh, ">$filename") || die "$filename: $!";
my $fh = new IO::File($filename, '>>') || die "$filename: $!";
$fh->seek(0, SEEK_END);
foreach my $var (LOCALCONFIG_VARS) { foreach my $var (LOCALCONFIG_VARS) {
if (grep($_ eq $var->{name}, @new_vars)) {
print $fh "\n", $var->{desc}, print $fh "\n", $var->{desc},
Data::Dumper->Dump([$localconfig->{$var->{name}}], Data::Dumper->Dump([$localconfig->{$var->{name}}],
["*$var->{name}"]); ["*$var->{name}"]);
} }
}
if (@new_vars) {
my $newstuff = join(', ', @new_vars); my $newstuff = join(', ', @new_vars);
print <<EOT; print <<EOT;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment