4 use IO::Uncompress::AnyInflate qw(anyinflate);
5 use Dpkg::Version qw(vercmp);
6 use Dpkg::Arch qw(debarch_is);
18 open(PAS, '<', $pasfile);
23 my ($p, $c) = split(/:\s*/);
24 $pas->{$p} = { arch => [ split(/\s+/, $c) ], mode => substr($c, 0, 1) ne '!' };
29 local($/) = ""; # read in paragraph mode
31 foreach my $s (@$SRC) {
32 my $S = new IO::Uncompress::AnyInflate($s) || return "WB::QD::SRC can't open $s";
35 /^Package:\s*(\S+)$/mi and $p->{'name'} = $1;
36 /^Version:\s*(\S+)$/mi and $p->{'version'} = $1;
37 /^Binary:\s*(.*)$/mi and $p->{'binary'} = $1;
38 /^Architecture:\s*(.+)$/mi and $p->{'arch'} = $1;
39 /^Priority:\s*(\S+)$/mi and $p->{'priority'} = $1;
40 /^Section:\s*(\S+)$/mi and $p->{'section'} = $1;
41 /^Build-Depends:\s*(.*)$/mi and $p->{'depends'} = $1;
42 /^Build-Conflicts:\s*(.*)$/mi and $p->{'conflicts'} = $1;
44 next unless $p->{'name'} and $p->{'version'};
45 next if $p->{'arch'} eq 'all';
46 foreach my $tarch (split(/\s+/, $p->{'arch'})) {
47 $p->{'for-us'} = 1 if debarch_is($arch, $tarch);
51 # ignore if package already exists with higher version
52 if ($srcs->{$p->{'name'}}) {
53 next if (vercmp($srcs->{$p->{'name'}}->{'version'}, $p->{'version'}) > 0);
55 my @a = split(/,? /, $p->{'binary'}) if $p->{'binary'};
57 $srcs->{$p->{'name'}} = $p;
62 foreach my $p (@$BIN) {
63 my $P = new IO::Uncompress::AnyInflate($p) || return "WB::QD::PKGS can't open $p";
66 /^Version:\s*(\S+)$/mi and $p->{'version'} = $1;
67 /^Version:\s*(\S+)\+b([0-9]+)$/mi and $p->{'version'} = $1 and $p->{'binnmu'} = $2;
68 /^Architecture:\s*(\S+)$/mi and $p->{'arch'} = $1;
69 /^Package:\s*(\S+)$/mi and $p->{'binary'} = $1;
70 /^Package:\s*(\S+)$/mi and $p->{'source'} = $1;
71 /^Source:\s*(\S+)$/mi and $p->{'source'} = $1;
72 /^Source:\s*(\S+)\s+\((\S+)\)$/mi and $p->{'source'} = $1 and $p->{'version'} = $2;
74 next unless $p->{'arch'} eq 'all' || $p->{'arch'} eq ${arch};
75 $binary->{$p->{'binary'}} = { 'version' => $p->{'version'}, 'arch' => $p->{'arch'}} unless $binary->{$p->{'binary'}} and vercmp($binary->{$p->{'binary'}}->{'version'}, $p->{'version'}) < 0;
77 #next if $pas->{$p->{'binary'}} && pasignore($pas->{$p->{'binary'}}, $arch);
78 next if $p->{'arch'} eq 'all';
79 next unless $srcs->{$p->{'source'}};
80 $srcs->{$p->{'source'}}->{'compiled'} = 1;
81 next unless $srcs->{$p->{'source'}}->{'version'} eq $p->{'version'};
82 $srcs->{$p->{'source'}}->{'installed'} = 1;
83 next unless $p->{'binnmu'};
84 next if ($srcs->{$p->{'source'}}->{'binnmu'}) && ($srcs->{$p->{'source'}}->{'binnmu'} > $p->{'binnmu'});
85 $srcs->{$p->{'source'}}->{'binnmu'} = $p->{'binnmu'};
91 for my $k (keys %$srcs) {
92 if ($srcs->{$k}->{'installed'}) {
93 $srcs->{$k}->{'status'} = 'installed';
94 delete $srcs->{$k}->{'installed'};
95 } elsif ($srcs->{$k}->{'compiled'}) {
96 $srcs->{$k}->{'status'} = 'out-of-date';
98 $srcs->{$k}->{'status'} = 'uncompiled';
100 delete $srcs->{$k}->{'compiled'};
101 $srcs->{$k}->{'status'} = 'installed' if $srcs->{$k}->{'arch'} && $srcs->{$k}->{'arch'} eq 'all';
103 if (!$srcs->{$k}->{'for-us'} && $srcs->{$k}->{'status'} ne 'installed') {
104 $srcs->{$k}->{'status'} = 'auto-not-for-us';
106 delete $srcs->{$k}->{'for-us'};
109 #$p ||= $pas->{'%'.$k};
110 #$srcs->{$k}->{'status'} = 'not-for-us' if pasignore($p, $arch);
111 if (pasignore($pas->{'%'.$k}, $arch)) {
112 $srcs->{$k}->{'status'} = 'not-for-us';
115 for my $bin (@{$srcs->{$k}->{'binary'}}) {
116 next if pasignore($pas->{$bin}, $arch);
117 next if $binary->{$bin} and $binary->{$bin}->{'arch'} eq 'all';
120 $srcs->{$k}->{'status'} = 'not-for-us';
122 $srcs->{'_binary'} = $binary;
131 if ($p && $p->{'mode'}) {
132 return 1 unless grep { $_ eq $arch } @{$p->{'arch'}};
134 if ($p && not $p->{'mode'}) {
135 return 1 if grep /^!$arch$/, @{$p->{'arch'}};