Accepting request 320566 from mozilla:addons

- Recognize <Description> XML tags with arbitrary namespace prefixes

OBS-URL: https://build.opensuse.org/request/show/320566
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/mozaddon-devel?expand=0&rev=3
This commit is contained in:
Stephan Kulow 2015-08-05 17:17:53 +00:00 committed by Git OBS Bridge
commit ae2ba79b7e
3 changed files with 73 additions and 38 deletions

View File

@ -1,3 +1,9 @@
-------------------------------------------------------------------
Wed Aug 5 09:41:47 UTC 2015 - jengelh@inai.de
- Recognize <Description> XML tags with arbitrary namespace
prefixes
------------------------------------------------------------------- -------------------------------------------------------------------
Mon Apr 1 20:36:52 UTC 2013 - jengelh@inai.de Mon Apr 1 20:36:52 UTC 2013 - jengelh@inai.de

View File

@ -1,7 +1,7 @@
# #
# spec file for package mozaddon-devel # spec file for package mozaddon-devel
# #
# Copyright (c) 2013 SUSE LINUX Products GmbH, Nuernberg, Germany. # Copyright (c) 2015 SUSE LINUX GmbH, Nuernberg, Germany.
# #
# All modifications and additions to the file contributed by third parties # All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed # remain the property of their copyright owners, unless otherwise agreed
@ -17,7 +17,7 @@
Name: mozaddon-devel Name: mozaddon-devel
Version: 0 Version: 1
Release: 0 Release: 0
Summary: RPM macros for building Mozilla extensions under openSUSE Summary: RPM macros for building Mozilla extensions under openSUSE
License: SUSE-Public-Domain License: SUSE-Public-Domain

View File

@ -3,53 +3,82 @@
# authored by Jan Engelhardt, 2011-03-24 # authored by Jan Engelhardt, 2011-03-24
# released into the Public Domain # released into the Public Domain
# #
use Archive::Zip qw(:ERROR_CODES :CONSTANTS);
use XML::Simple; use XML::Simple;
&main();
my $file = shift || die "Usage: $0 [install.rdf|somefile.xpi]\n"; sub get_rdf
my $xml; {
my $file = shift @_;
if ($file =~ /\.xpi$/) { if ($file eq "install.rdf") {
use Archive::Zip qw/:ERROR_CODES :CONSTANTS/; return XMLin($file);
my $zip = Archive::Zip->new(); }
if ( $zip->read($file) != AZ_OK ) { if (substr($file, -4, 4) eq ".xpi") {
die "zip file read error\n"; my $zip = Archive::Zip->new();
if ($zip->read($file) != AZ_OK) {
die "zip file read error\n";
}
my $data = $zip->contents("install.rdf");
die "missing install.rdf in $file\n" unless $data;
return XMLin($data);
} }
my $data = $zip->contents("install.rdf");
die "missing install.rdf in $file\n" unless $data;
$xml = XMLin($data) || die "$!\n";
} elsif ($file =~ /install.rdf/) {
$xml = XMLin($file) || die "$!\n";
} else {
die "unsupported file format\n"; die "unsupported file format\n";
} }
my $desc; sub get_desc
for my $tag (qw/RDF:Description Description/) { {
if (exists $xml->{$tag}) { my $xml = shift @_;
if (ref $xml->{$tag} eq 'ARRAY') { my $desc;
$desc = $xml->{$tag}; foreach my $tag (keys %$xml) {
} else { if ($tag !~ m{^(\w+:)?Description$}) {
$desc = [ $xml->{$tag} ]; next;
}
if (ref($xml->{$tag}) eq "ARRAY") {
return $xml->{$tag};
}
return [$xml->{$tag}];
}
}
sub get_id
{
my $desc = shift @_;
my $id;
foreach (qw(id em:id)) {
if (exists($desc->{$_})) {
$id = $desc->{$_};
last;
} }
} }
return $id;
} }
my $uuid; sub main
my $id; {
for my $x (@$desc) { my $file = shift @ARGV;
if ($x->{"em:id"} =~ /{[[:xdigit:]]+-/) { if (!defined($file)) {
print STDERR "Warning: multiple uuids!\n" if defined $uuid; print "Usage: $0 {install.rdf|something.xpi}\n";
$uuid = $x->{"em:id"}; exit 1;
} elsif ($x->{"em:id"} =~ /@/) { }
print STDERR "Warning: multiple ids!\n" if defined $id; my $xml = get_rdf($file);
$id = $x->{"em:id"}; if (!defined($xml)) {
die "xml: $!\n";
}
my $desc_list = &get_desc($xml);
my $id;
foreach my $one_desc (@$desc_list) {
my $value = &get_id($one_desc);
if ($value =~ /\@|{[[:xdigit:]]+-/) {
if (defined($id)) {
print STDERR "Warning: multiple IDs/UUIDs!\n";
}
$id = $value;
}
}
if (!defined($id)) {
exit 1;
} }
}
if (defined $id) {
print "$id\n"; print "$id\n";
} elsif (defined $uuid) {
print "$uuid\n";
} else {
exit 1;
} }