#!/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 [S>] [B<-n>] =head1 DESCRIPTION B is a debhelper program that is responsible for installing Debian package provided initramfs hooks. If B installs or (in compat 12 or later) detects one or more initramfs hooks in the package, then it also automatically generates the F and F commands needed to interface with the Debian initramfs system. These commands are inserted into the maintainer scripts by L. =head1 FILES =over 4 =item debian/I.initramfs-hook Assumed to be an initramfs hook that will be installed into F<< usr/share/initramfs-tools/hooks/I >> in the package build directory. See B in L for more information about initramfs hooks. =back =head1 OPTIONS =over 4 =item B<-n>, B<--no-scripts> Do not modify F/F scripts. =back =head1 NOTES Note that this command is not idempotent. L 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 L L This program is a part of debhelper. =head1 AUTHOR Niels Thykier =cut