dpkg (1.18.25) stretch; urgency=medium
[dpkg] / scripts / Dpkg / Control / Fields.pm
CommitLineData
1479465f
GJ
1# Copyright © 2007-2009 Raphaël Hertzog <hertzog@debian.org>
2#
3# This program is free software; you can redistribute it and/or modify
4# it under the terms of the GNU General Public License as published by
5# the Free Software Foundation; either version 2 of the License, or
6# (at your option) any later version.
7#
8# This program is distributed in the hope that it will be useful,
9# but WITHOUT ANY WARRANTY; without even the implied warranty of
10# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11# GNU General Public License for more details.
12#
13# You should have received a copy of the GNU General Public License
14# along with this program. If not, see <https://www.gnu.org/licenses/>.
15
16package Dpkg::Control::Fields;
17
18use strict;
19use warnings;
20
21our $VERSION = '1.00';
22our @EXPORT = @Dpkg::Control::FieldsCore::EXPORT;
23
24use Carp;
25use Exporter qw(import);
26
27use Dpkg::Control::FieldsCore;
28use Dpkg::Vendor qw(run_vendor_hook);
29
30# Register vendor specifics fields
31foreach my $op (run_vendor_hook('register-custom-fields')) {
32 next if not (defined $op and ref $op); # Skip when not implemented by vendor
33 my $func = shift @$op;
34 if ($func eq 'register') {
35 &field_register(@$op);
36 } elsif ($func eq 'insert_before') {
37 &field_insert_before(@$op);
38 } elsif ($func eq 'insert_after') {
39 &field_insert_after(@$op);
40 } else {
41 croak "vendor hook register-custom-fields sent bad data: @$op";
42 }
43}
44
45=encoding utf8
46
47=head1 NAME
48
49Dpkg::Control::Fields - manage (list of official) control fields
50
51=head1 DESCRIPTION
52
53The module contains a list of vendor-neutral and vendor-specific fieldnames
54with associated meta-data explaining in which type of control information
55they are allowed. The vendor-neutral fieldnames and all functions are
56inherited from Dpkg::Control::FieldsCore.
57
58=head1 CHANGES
59
60=head2 Version 1.00 (dpkg 1.15.6)
61
62Mark the module as public.
63
64=cut
65
661;