+2008-03-16 Raphael Hertzog <hertzog@debian.org>
+
+ * scripts/Dpkg/Shlibs/Objdump.pm: Add "objid" property to
+ symbols and fake "soname" property with the basename of the
+ object's filename if the object has no official SONAME.
+ * scripts/dpkg-shlibdeps.pl: Add some more debugging messages.
+ * scripts/dpkg-shlibdeps.pl: Also count usage of alternate sonames
+ for symbols found in symbols files.
+
2008-03-16 Guillem Jover <guillem@debian.org>
* configure.ac (AC_CHECK_HEADERS): Add 'libintl.h'.
must be discarded due to another dependency appearing further
in the field, the superseding dependency will take the place of the
discarded one. Added a test case for this.
+ * dpkg-shlibdeps properly accounts usage of symbols provided by private
+ libraries without SONAME. Closes: #469838
[ Frank Lichtenheld ]
* Add a warning in dpkg-buildpackage if the build-dependencies are not
sub add_dynamic_symbol {
my ($self, $symbol) = @_;
- $symbol->{soname} = $self->{SONAME};
+ $symbol->{objid} = $symbol->{soname} = $self->get_id();
+ $symbol->{soname} =~ s{^.*/}{} unless $self->{SONAME};
if ($symbol->{version}) {
$self->{dynsyms}{$symbol->{name} . '@' . $symbol->{version}} = $symbol;
} else {
} elsif (m/^-t(.*)$/) {
$packagetype = $1;
} elsif (m/^-v$/) {
- $debug = 1;
+ $debug++;
} elsif (m/^-x(.*)$/) {
push @exclude, $1;
} elsif (m/^-/) {
my $cur_field;
foreach my $file (keys %exec) {
$cur_field = $exec{$file};
- print "Scanning $file (for $cur_field field)\n" if $debug;
+ print ">> Scanning $file (for $cur_field field)\n" if $debug;
my $obj = Dpkg::Shlibs::Objdump::Object->new($file);
my @sonames = $obj->get_needed_libraries;
} else {
# No symbol file found, fall back to standard shlibs
my $id = $dumplibs_wo_symfile->parse($lib);
- if ($id ne $soname) {
+ if (($id ne $soname) and ($id ne $lib)) {
warning(_g("%s has an unexpected SONAME (%s)"), $lib, $id);
$alt_soname{$id} = $soname;
}
} else {
$name .= "\@Base";
}
+ print " Looking up symbol $name\n" if $debug > 1;
my $symdep = $symfile->lookup_symbol($name, \@sonames);
if (defined($symdep)) {
+ print " Found in symbols file of $symdep->{soname}\n" if $debug > 1;
$used_sonames{$symdep->{soname}}++;
+ if (exists $alt_soname{$symdep->{soname}}) {
+ # Also count usage on alternate soname
+ $used_sonames{$alt_soname{$symdep->{soname}}}++;
+ }
update_dependency_version($symdep->{depends},
$symdep->{minver});
} else {
my $syminfo = $dumplibs_wo_symfile->locate_symbol($name);
if (not defined($syminfo)) {
+ print " Not found\n" if $debug > 1;
next if $disable_warnings;
# Complain about missing symbols only for executables
# and public libraries
}
}
} else {
+ print " Found in $syminfo->{soname} ($syminfo->{objid})\n" if $debug > 1;
if (exists $alt_soname{$syminfo->{soname}}) {
# Also count usage on alternate soname
$used_sonames{$alt_soname{$syminfo->{soname}}}++;