- print "DEBUG: Considering entry ".join( ':', @data)."<br>" if $debug > 2;
- if ($suites{$data[0]} && ($archs{$data[1]} || $data[1] eq 'all')
- && $sections{$data[2]}) {
- print "DEBUG: Using entry ".join( ':', @data)."<br>" if $debug > 2;
- push @results, [ $keyword, @data ];
+ foreach my $pkg (sort keys %pkgs) {
+ read_entry( \%packages, $pkg, \@results );
+ }
+ }
+} elsif ($searchon eq 'sourcenames') {
+
+ $keyword = lc $keyword unless $case_bool;
+
+ my $obj = tie my %packages, 'DB_File', "$DBDIR/sources_small.db", O_RDONLY, 0666, $DB_BTREE
+ or die "couldn't tie DB $DBDIR/sources_small.db: $!";
+
+ if ($exact) {
+ read_src_entry( \%packages, $keyword, \@results );
+ } else {
+ while (my ($pkg, $result) = each %packages) {
+ #what's faster? I can't really see a difference
+ (index($pkg, $keyword) >= 0) or next;
+ #$pkg =~ /\Q$keyword\E/ or next;
+ foreach (split /\000/, $result) {
+ my @data = split ( /\s/, $_, 5 );
+ print "DEBUG: Considering entry ".join( ':', @data)."<br>" if $debug > 2;
+ if ($suites{$data[0]} && $sections{$data[1]}) {
+ print "DEBUG: Using entry ".join( ':', @data)."<br>" if $debug > 2;
+ push @results, [ $pkg , @data ];
+ }
+ }