* scripts/dpkg-genchanges.pl: Some code refactoring. Also fix the
generation of the Description field to not have duplicate description
in case of udeb (a single description per binary package is enough).
---
 scripts/dpkg-genchanges.pl |   88 +++++++++++++++++++++-----------------------
 1 files changed, 42 insertions(+), 46 deletions(-)

diff --git a/scripts/dpkg-genchanges.pl b/scripts/dpkg-genchanges.pl
index d825581..83176ce 100755
--- a/scripts/dpkg-genchanges.pl
+++ b/scripts/dpkg-genchanges.pl
@@ -257,58 +257,54 @@ foreach $_ (keys %{$src_fields}) {
     }
 }
 
-# Scan control info of all binary packages
-foreach my $pkg ($control->get_packages()) {
+# Scan control info of all binary packages unless
+# we have a source only upload
+my @pkg;
+push @pkg, $control->get_packages() unless is_sourceonly;
+foreach my $pkg (@pkg) {
     my $p = $pkg->{"Package"};
     my $a = $pkg->{"Architecture"};
+
+    if (not defined($p2f{$p})) {
+       # No files for this package... warn if it's unexpected
+       if ((debarch_eq('all', $a) and ($include & ARCH_INDEP)) ||
+           (grep(debarch_is($host_arch, $_), split(/\s+/, $a))
+                 and ($include & ARCH_DEP))) {
+           warning(_g("package %s in control file but not in files list"),
+                   $p);
+       }
+       next; # and skip it
+    }
+
+    my @f = @{$p2f{$p}}; # List of files for this binary package
+    $p2arch{$p} = $a;
+
     foreach $_ (keys %{$pkg}) {
        my $v = $pkg->{$_};
-       if (!defined($p2f{$p}) && not is_sourceonly) {
-           if ((debarch_eq('all', $a) and ($include & ARCH_INDEP)) ||
-               (grep(debarch_is($host_arch, $_), split(/\s+/, $a))
-                     and ($include & ARCH_DEP))) {
-               warning(_g("package %s in control file but not in files list"),
-                       $p);
-               next;
+
+       if (m/^Description$/) {
+           $v = $1 if $v =~ m/^(.*)\n/;
+           my $desc = sprintf("%-10s - %-.65s", $p, $v);
+           $desc .= " (udeb)" if (grep(/\.udeb$/, @f));
+           push @descriptions, $desc;
+       } elsif (m/^Section$/) {
+           $f2seccf{$_} = $v foreach (@f);
+       } elsif (m/^Priority$/) {
+           $f2pricf{$_} = $v foreach (@f);
+       } elsif (s/^X[BS]*C[BS]*-//i) { # Include XC-* fields
+           $fields->{$_} = $v;
+       } elsif (m/^Architecture$/) {
+           if (grep(debarch_is($host_arch, $_), split(/\s+/, $v))
+               and ($include & ARCH_DEP)) {
+               $v = $host_arch;
+           } elsif (!debarch_eq('all', $v)) {
+               $v = '';
            }
+           push(@archvalues,$v) unless !$v || $archadded{$v}++;
+       } elsif (m/^$control_pkg_field_regex$/ || m/^X[BS]+-/i) {
+           # Silently ignore valid fields
        } else {
-           my @f;
-           @f = @{$p2f{$p}} if defined($p2f{$p});
-           $p2arch{$p}=$a;
-
-           if (m/^Description$/) {
-               $v=$PREMATCH if $v =~ m/\n/;
-               my %d;
-               # dummy file to get each description at least once (e.g. -S)
-               foreach my $f (("", @f)) {
-                   my $desc = sprintf("%-10s - %-.65s%s", $p, $v,
-                                      $f =~ m/\.udeb$/ ? " (udeb)" : '');
-                   $d{$desc}++;
-               }
-               push @descriptions, keys %d;
-           } elsif (m/^Section$/) {
-               $f2seccf{$_} = $v foreach (@f);
-           } elsif (m/^Priority$/) {
-               $f2pricf{$_} = $v foreach (@f);
-           } elsif (s/^X[BS]*C[BS]*-//i) { # Include XC-* fields
-               $fields->{$_} = $v;
-           } elsif (m/^Architecture$/) {
-               if (not is_sourceonly) {
-                   if (grep(debarch_is($host_arch, $_), split(/\s+/, $v))
-                       and ($include & ARCH_DEP)) {
-                       $v = $host_arch;
-                   } elsif (!debarch_eq('all', $v)) {
-                       $v = '';
-                   }
-               } else {
-                   $v = '';
-               }
-               push(@archvalues,$v) unless !$v || $archadded{$v}++;
-           } elsif (m/^$control_pkg_field_regex$/ || m/^X[BS]+-/i) {
-               # Silently ignore valid fields
-           } else {
-               unknown(_g("package's section of control info file"));
-           }
+           unknown(_g("package's section of control info file"));
        }
     }
 }
-- 
1.5.3.8


-- 
To UNSUBSCRIBE, email to [EMAIL PROTECTED]
with a subject of "unsubscribe". Trouble? Contact [EMAIL PROTECTED]

Reply via email to