use Debbugs::Status qw(read_bug split_status_fields);
use Debbugs::Log;
use Debbugs::DB;
-use Debbugs::DB::Load qw(load_bug handle_load_bug_queue :load_package :load_suite);
+use Debbugs::DB::Load qw(:load_bug :load_package :load_suite);
use DateTime;
use File::stat;
use File::Basename;
# tags
# add all tags
+ my %tags;
+ for my $tag (@{$config{tags}}) {
+ $tags{$tag} = 1;
+ $s->resultset('Tag')->find_or_create({tag => $tag});
+ }
# mark obsolete tags
+ for my $tag ($s->resultset('Tag')->search_rs()->all()) {
+ next if exists $tags{$tag->tag};
+ $tag->obsolete(1);
+ $tag->update;
+ }
# severities
my %sev_names;
- my $order = 0;
- for my $sev_name (@{$config{severities}}) {
+ my $order = -1;
+ for my $sev_name (($config{default_severity},@{$config{severity_list}})) {
# add all severitites
my $sev = $s->resultset('Severity')->find_or_create({severity => $sev_name});
# mark strong severities
if (grep {$_ eq $sev_name} @{$config{strong_severities}}) {
$sev->strong(1);
}
- $sev->order($order);
+ $sev->ordering($order);
$sev->update();
$order++;
$sev_names{$sev_name} = 1;
}
# mark obsolete severities
- for my $sev ($s->resultset('Severity')->find()) {
+ for my $sev ($s->resultset('Severity')->search_rs()->all()) {
next if exists $sev_names{$sev->severity()};
$sev->obsolete(1);
$sev->update();
$verbose,
sub {
my $bug = shift;
- eval {
+ my $stat = stat(getbugcomponent($bug,'log',$initialdir));
+ if (not defined $stat) {
+ print STDERR "Unable to stat $bug $!\n";
+ next;
+ }
+ if ($options{quick}) {
+ my $rs = $s->resultset('Bug')->search({bug=>$bug})->single();
+ next if defined $rs and $stat->mtime < $rs->last_modified()->epoch();
+ }
+ eval {
load_bug_log(db => $s,
bug => $bug);
};