$category, %catval, %short_category,
$short_date, $list_min_age, $dbbase, @curr_time,
$build_priority, %new_vers, $binNMUver, %merge_srcvers, %merge_binsrc,
- $lock_for_pid, $transactional);
+ $lock_for_pid, $transactional, $read_only);
# global vars
$ENV{'PATH'} = "/bin:/usr/bin:/usr/local/bin:/org/wanna-build/bin/";
$| = 1;
$lock_for_pid = -1; # -1 means normal procedure
$transactional = 0; # 0 means: work on main copy
+$read_only = 0; # 1 means: do not set or check lock, do never write
# map program invocation names to operation modes
my %prognames = ( "uploaded-build" => "set-uploaded",
"start-transaction" => { mode => "start-transaction" },
"commit-transaction" => { mode => "commit-transaction" },
"transactional" => { flag => \$transactional },
+ "read-only" => { flag => \$read_only },
"manual-edit" => { mode => "manual-edit" },
"create-maintenance-lock" => { mode => "maintlock-create" },
"remove-maintenance-lock" => { mode => "maintlock-remove" },
print "wanna-build $version for $distribution on $conf::dbbase\n";
}
+if ($read_only && !isin( $op_mode, qw(list export info))) {
+ warn "Invalid operation with --read-only. You can only use --list, --export or --info.\n";
+ exit 1;
+}
+
if (!@ARGV && !isin( $op_mode, qw(list merge-quinn merge-partial-quinn import export
merge-packages manual-edit maintlock-create lock-for unlock-for
start-transaction commit-transaction
exit 0;
}
-lock_db( $distribution );
+if (!$read_only) {
+ lock_db( $distribution );
+}
if ($op_mode eq "start-transaction") {
copy ( db_filename_master( $distribution ), db_filename_transaction( $distribution ))
}
END {
- untie %db;
- if ($lock_for_pid == -1) {
- unlock_db( $distribution );
- }
- foreach (keys %conf::distributions) {
- untie %{$otherdb{$_}} if tied(%{$otherdb{$_}});
- unlock_db( $_ ) if $otherdb_lock{$_};
+ if (!$read_only) {
+ untie %db;
+ if ($lock_for_pid == -1) {
+ unlock_db( $distribution );
+ }
+ foreach (keys %conf::distributions) {
+ untie %{$otherdb{$_}} if tied(%{$otherdb{$_}});
+ unlock_db( $_ ) if $otherdb_lock{$_};
+ }
}
}
-tie %db, 'MLDBM', db_filename( $distribution ), GDBM_WRCREAT, 0664
+tie %db, 'MLDBM', db_filename( $distribution ), $read_only ? GDBM_READER : GDBM_WRCREAT, 0664
or die "FATAL: Cannot open database\n";
process();
"Skipping.\n";
return;
}
- change_state( \$pkg, 'BD-Uninstallable' );
- $pkg->{'BD-Problem'} = "Installability of build dependencies not tested yet";
+ if ($distribution eq "unstable") {
+ change_state( \$pkg, 'BD-Uninstallable' );
+ $pkg->{'BD-Problem'} = "Installability of build dependencies not tested yet";
+ } else {
+ change_state( \$pkg, 'Needs-Build' );
+ }
delete $pkg->{'Builder'};
delete $pkg->{'Depends'};
log_ta( $pkg, "--give-back" );
unlink( $lockfile );
return;
}
- warn "Databases locked for general maintenance by $usr -- ".
+ warn "Databases in $conf::dbbase locked for general maintenance by $usr -- ".
"please wait\n" if $try == 0;
}
if (++$try > 120) {