| Index: third_party/dpkg-dev/scripts/Dpkg/Vendor/Ubuntu.pm
|
| diff --git a/third_party/dpkg-dev/scripts/Dpkg/Vendor/Ubuntu.pm b/third_party/dpkg-dev/scripts/Dpkg/Vendor/Ubuntu.pm
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..e9c2003a991c2d268eff736386788354129f4a23
|
| --- /dev/null
|
| +++ b/third_party/dpkg-dev/scripts/Dpkg/Vendor/Ubuntu.pm
|
| @@ -0,0 +1,185 @@
|
| +# Copyright © 2008 Ian Jackson <ian@davenant.greenend.org.uk>
|
| +# Copyright © 2008 Canonical, Ltd.
|
| +# written by Colin Watson <cjwatson@ubuntu.com>
|
| +# Copyright © 2008 James Westby <jw+debian@jameswestby.net>
|
| +# Copyright © 2009 Raphaël Hertzog <hertzog@debian.org>
|
| +#
|
| +# This program is free software; you can redistribute it and/or modify
|
| +# it under the terms of the GNU General Public License as published by
|
| +# the Free Software Foundation; either version 2 of the License, or
|
| +# (at your option) any later version.
|
| +#
|
| +# This program is distributed in the hope that it will be useful,
|
| +# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
| +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
| +# GNU General Public License for more details.
|
| +#
|
| +# You should have received a copy of the GNU General Public License
|
| +# along with this program. If not, see <https://www.gnu.org/licenses/>.
|
| +
|
| +package Dpkg::Vendor::Ubuntu;
|
| +
|
| +use strict;
|
| +use warnings;
|
| +
|
| +our $VERSION = '0.01';
|
| +
|
| +use Dpkg::ErrorHandling;
|
| +use Dpkg::Gettext;
|
| +use Dpkg::Path qw(find_command);
|
| +use Dpkg::Control::Types;
|
| +use Dpkg::BuildOptions;
|
| +use Dpkg::Arch qw(debarch_eq get_host_arch);
|
| +
|
| +use parent qw(Dpkg::Vendor::Debian);
|
| +
|
| +=encoding utf8
|
| +
|
| +=head1 NAME
|
| +
|
| +Dpkg::Vendor::Ubuntu - Ubuntu vendor object
|
| +
|
| +=head1 DESCRIPTION
|
| +
|
| +This vendor object customize the behaviour of dpkg-source
|
| +to check that Maintainers have been modified if necessary.
|
| +
|
| +=cut
|
| +
|
| +sub run_hook {
|
| + my ($self, $hook, @params) = @_;
|
| +
|
| + if ($hook eq 'before-source-build') {
|
| + my $src = shift @params;
|
| + my $fields = $src->{fields};
|
| +
|
| + # check that Maintainer/XSBC-Original-Maintainer comply to
|
| + # https://wiki.ubuntu.com/DebianMaintainerField
|
| + if (defined($fields->{'Version'}) and defined($fields->{'Maintainer'}) and
|
| + $fields->{'Version'} =~ /ubuntu/) {
|
| + if ($fields->{'Maintainer'} !~ /ubuntu/i) {
|
| + if (defined ($ENV{DEBEMAIL}) and $ENV{DEBEMAIL} =~ /\@ubuntu\.com/) {
|
| + error(_g('Version number suggests Ubuntu changes, but Maintainer: does not have Ubuntu address'));
|
| + } else {
|
| + warning(_g('Version number suggests Ubuntu changes, but Maintainer: does not have Ubuntu address'));
|
| + }
|
| + }
|
| + unless ($fields->{'Original-Maintainer'}) {
|
| + warning(_g('Version number suggests Ubuntu changes, but there is no XSBC-Original-Maintainer field'));
|
| + }
|
| + }
|
| +
|
| + } elsif ($hook eq 'keyrings') {
|
| + my @keyrings = $self->SUPER::run_hook($hook);
|
| +
|
| + push(@keyrings, '/usr/share/keyrings/ubuntu-archive-keyring.gpg');
|
| + return @keyrings;
|
| +
|
| + } elsif ($hook eq 'register-custom-fields') {
|
| + my @field_ops = $self->SUPER::run_hook($hook);
|
| + push @field_ops,
|
| + [ 'register', 'Launchpad-Bugs-Fixed',
|
| + CTRL_FILE_CHANGES | CTRL_CHANGELOG ],
|
| + [ 'insert_after', CTRL_FILE_CHANGES, 'Closes', 'Launchpad-Bugs-Fixed' ],
|
| + [ 'insert_after', CTRL_CHANGELOG, 'Closes', 'Launchpad-Bugs-Fixed' ];
|
| + return @field_ops;
|
| +
|
| + } elsif ($hook eq 'post-process-changelog-entry') {
|
| + my $fields = shift @params;
|
| +
|
| + # Add Launchpad-Bugs-Fixed field
|
| + my $bugs = find_launchpad_closes($fields->{'Changes'} || '');
|
| + if (scalar(@$bugs)) {
|
| + $fields->{'Launchpad-Bugs-Fixed'} = join(' ', @$bugs);
|
| + }
|
| +
|
| + } elsif ($hook eq 'update-buildflags') {
|
| + my $flags = shift @params;
|
| + my $build_opts = Dpkg::BuildOptions->new();
|
| +
|
| + if (!$build_opts->has('noopt')) {
|
| + if (debarch_eq(get_host_arch(), 'ppc64el')) {
|
| + for my $flag (qw(CFLAGS CXXFLAGS GCJFLAGS FFLAGS)) {
|
| + $flags->set($flag, '-g -O3', 'vendor');
|
| + }
|
| + }
|
| + }
|
| + # Per https://wiki.ubuntu.com/DistCompilerFlags
|
| + $flags->set('LDFLAGS', '-Wl,-Bsymbolic-functions', 'vendor');
|
| +
|
| + # Run the Debian hook to add hardening flags
|
| + $self->SUPER::run_hook($hook, $flags);
|
| +
|
| + # Allow control of hardening-wrapper via dpkg-buildpackage DEB_BUILD_OPTIONS
|
| + my $hardening;
|
| + if ($build_opts->has('hardening')) {
|
| + $hardening = $build_opts->get('hardening') // 1;
|
| + }
|
| + if ($build_opts->has('nohardening')) {
|
| + $hardening = 0;
|
| + }
|
| + if (defined $hardening) {
|
| + my $flag = 'DEB_BUILD_HARDENING';
|
| + if ($hardening ne '0') {
|
| + if (!find_command('hardened-cc')) {
|
| + syserr(_g("'hardening' flag found but 'hardening-wrapper' not installed"));
|
| + }
|
| + if ($hardening ne '1') {
|
| + my @options = split(/,\s*/, $hardening);
|
| + $hardening = 1;
|
| +
|
| + my @hardopts = qw(format fortify stackprotector pie relro);
|
| + foreach my $item (@hardopts) {
|
| + my $upitem = uc($item);
|
| + foreach my $option (@options) {
|
| + if ($option =~ /^(no)?$item$/) {
|
| + $flags->set($flag . '_' . $upitem,
|
| + not defined $1 or $1 eq '', 'env');
|
| + }
|
| + }
|
| + }
|
| + }
|
| + }
|
| + if (defined $ENV{$flag}) {
|
| + info(_g('overriding %s in environment: %s'), $flag, $hardening);
|
| + }
|
| + $flags->set($flag, $hardening, 'env');
|
| + }
|
| +
|
| + } else {
|
| + return $self->SUPER::run_hook($hook, @params);
|
| + }
|
| +
|
| +}
|
| +
|
| +=head1 PUBLIC FUNCTIONS
|
| +
|
| +=over
|
| +
|
| +=item $bugs = Dpkg::Vendor::Ubuntu::find_launchpad_closes($changes)
|
| +
|
| +Takes one string as argument and finds "LP: #123456, #654321" statements,
|
| +which are references to bugs on Launchpad. Returns all closed bug
|
| +numbers in an array reference.
|
| +
|
| +=cut
|
| +
|
| +sub find_launchpad_closes {
|
| + my ($changes) = @_;
|
| + my %closes;
|
| +
|
| + while ($changes &&
|
| + ($changes =~ /lp:\s+\#\d+(?:,\s*\#\d+)*/ig)) {
|
| + $closes{$_} = 1 foreach($& =~ /\#?\s?(\d+)/g);
|
| + }
|
| +
|
| + my @closes = sort { $a <=> $b } keys %closes;
|
| +
|
| + return \@closes;
|
| +}
|
| +
|
| +=back
|
| +
|
| +=cut
|
| +
|
| +1;
|
|
|