blob: 7cfb1cbbea78bbb6aa99bea9e534c687b7f3f252 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
#!/usr/bin/perl
=head1 NAME
dh_installinitramfs - install initramfs hooks and setup maintscripts
=cut
use strict;
use warnings;
use Debian::Debhelper::Dh_Lib;
our $VERSION = DH_BUILTIN_VERSION;
=head1 SYNOPSIS
B<dh_installinitramfs> [S<B<debhelper options>>] [B<-n>]
=head1 DESCRIPTION
B<dh_installinitramfs> is a debhelper program that is responsible for
installing Debian package provided initramfs hooks.
If B<dh_installinitramfs> installs or (in compat 12 or later) detects
one or more initramfs hooks in the package, then it also automatically
generates the F<postinst> and F<postrm> commands needed to interface
with the Debian initramfs system. These commands are inserted into
the maintainer scripts by L<dh_installdeb(1)>.
=head1 FILES
=over 4
=item debian/I<package>.initramfs-hook
Assumed to be an initramfs hook that will be installed into F<<
usr/share/initramfs-tools/hooks/I<package> >> in the package build
directory. See B<HOOK SCRIPTS> in L<initramfs-tools(8)> for more
information about initramfs hooks.
=back
=head1 OPTIONS
=over 4
=item B<-n>, B<--no-scripts>
Do not modify F<postinst>/F<postrm> scripts.
=back
=head1 NOTES
Note that this command is not idempotent. L<dh_prep(1)> should be called
between invocations of this command. Otherwise, it may cause multiple
instances of the same text to be added to maintainer scripts.
=cut
init();
# PROMISE: DH NOOP WITHOUT initramfs-hook tmp(usr/share/initramfs-tools/hooks) cli-options()
foreach my $package (@{$dh{DOPACKAGES}}) {
my $tmp = tmpdir($package);
my $hook_script = pkgfile($package, 'initramfs-hook');
my $has_hooks;
my $hook_dir = "${tmp}/usr/share/initramfs-tools/hooks";
if ($hook_script ne '') {
install_dir($hook_dir);
install_prog($hook_script, "${hook_dir}/${package}");
$has_hooks = 1;
} elsif (-d $hook_dir and not is_empty_dir($hook_dir)) {
$has_hooks = 1;
}
if ($has_hooks && ! $dh{NOSCRIPTS}) {
autoscript($package, 'postinst', 'postinst-initramfs-hook');
autoscript($package, 'postrm', 'postrm-initramfs-hook')
}
}
=head1 SEE ALSO
L<debhelper(7)>
L<update-initramfs(8)>
L<initramfs-tools(8)>
This program is a part of debhelper.
=head1 AUTHOR
Niels Thykier <niels@thykier.net>
=cut
|