# Copyright © 2007-2009 Raphaël Hertzog # # 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 . =encoding utf8 =head1 NAME Dpkg::Control::Fields - manage (list of official) control fields =head1 DESCRIPTION The module contains a list of vendor-neutral and vendor-specific field names with associated meta-data explaining in which type of control information they are allowed. The vendor-neutral field names and all functions are inherited from L. =cut package Dpkg::Control::Fields 1.00; use strict; use warnings; our @EXPORT = @Dpkg::Control::FieldsCore::EXPORT; use Carp; use Exporter qw(import); use Dpkg::Control::FieldsCore; use Dpkg::Vendor qw(run_vendor_hook); # Register vendor specifics fields foreach my $op (run_vendor_hook('register-custom-fields')) { next if not (defined $op and ref $op); # Skip when not implemented by vendor my $func = shift @$op; if ($func eq 'register') { my ($field, $allowed_type, @opts) = @{$op}; field_register($field, $allowed_type, @opts); } elsif ($func eq 'insert_before') { my ($type, $ref, @fields) = @{$op}; field_insert_before($type, $ref, @fields); } elsif ($func eq 'insert_after') { my ($type, $ref, @fields) = @{$op}; field_insert_after($type, $ref, @fields); } else { croak "vendor hook register-custom-fields sent bad data: @$op"; } } =head1 CHANGES =head2 Version 1.00 (dpkg 1.15.6) Mark the module as public. =cut 1;