On Tue, Sep 01, 2009 at 05:47:21PM -0400, Joey Hess wrote:
> Steve Langasek wrote:
> > That assumes the upstart job file has been installed before calling
> > dh_installinit, which isn't guaranteed in the general case?

> True, but I see no reason to worry about supporting that.

Ok.  I think this updated patch covers everything, then.

Patch dh_installinit to handle upstart job files in preference over init
scripts, and provide compatibility symlinks in /etc/init.d for sysv-rc
implementations.  Closes: #536035.
---
 debian/changelog |    8 ++++
 debian/copyright |    4 ++
 dh_installinit   |   99 ++++++++++++++++++++++++++++++++++++++---------------
 3 files changed, 83 insertions(+), 28 deletions(-)

diff --git a/debian/changelog b/debian/changelog
index 7cd3891..7ed5b0c 100644
--- a/debian/changelog
+++ b/debian/changelog
@@ -1,3 +1,11 @@
+debhelper (7.4.1) UNRELEASED; urgency=low
+
+  * Patch dh_installinit to handle upstart job files in preference over init
+    scripts, and provide compatibility symlinks in /etc/init.d for sysv-rc
+    implementations.  Closes: #536035.
+
+ -- Steve Langasek <vor...@debian.org>  Thu, 06 Aug 2009 03:01:43 -0700
+
 debhelper (7.4.0) unstable; urgency=low
 
   * Optimise -s handling to avoid running dpkg-architecture if a package
diff --git a/debian/copyright b/debian/copyright
index 7b12336..18178a2 100644
--- a/debian/copyright
+++ b/debian/copyright
@@ -58,3 +58,7 @@ License: GPL-2+
 Files: Debian/Debhelper/Buildsystem*, Debian/Debhelper/Dh_Buildsystems.pm
 Copyright: © 2008-2009 Modestas Vainius
 License: GPL-2+
+
+Files: dh_installinit
+Copyright: 1997-2008 Joey Hess <jo...@debian.org>, 2009 Canonical Ltd.
+License: GPL-3
diff --git a/dh_installinit b/dh_installinit
index 2f32b46..edebeaf 100755
--- a/dh_installinit
+++ b/dh_installinit
@@ -2,7 +2,7 @@
 
 =head1 NAME
 
-dh_installinit - install init scripts into package build directories
+dh_installinit - install upstart jobs or init scripts into package build 
directories
 
 =cut
 
@@ -11,21 +11,27 @@ use Debian::Debhelper::Dh_Lib;
 
 =head1 SYNOPSIS
 
-B<dh_installinit> [S<I<debhelper options>>] [B<--name=>I<name>] [B<-n>] 
[B<-R>] [B<-r>] [B<-d>] [S<B<--> I<params>>]
+B<dh_installinit> [S<I<debhelper options>>] [B<--name=>I<name>] [B<-n>] 
[B<-R>] [B<-r>] [B<-d>] [B<-O>] [S<B<--> I<params>>]
 
 =head1 DESCRIPTION
 
 dh_installinit is a debhelper program that is responsible for installing
-init scripts and associated defaults files into package build directories.
+upstart job files or init scripts with associated defaults files into package
+build directories, and in the former case providing compatibility handling
+for non-upstart systems.
 
 It also automatically generates the postinst and postrm and prerm commands
 needed to set up the symlinks in /etc/rc*.d/ and to start and stop the init
 scripts.
 
-If a file named debian/package.init exists, then it is installed into
-etc/init.d/package in the package build directory, with "package" replaced
+If a file named debian/package.upstart exists, then it is installed into
+etc/init/package.conf in the package build directory, with "package" replaced
 by the package name.
 
+Otherwise, if a file named debian/package.init exists, then it is installed
+into etc/init.d/package in the package build directory, with "package"
+replaced by the package name.
+
 If a file named debian/package.default exists, then it is installed into
 etc/default/package in the package build directory, with "package" replaced
 by the package name.
@@ -41,9 +47,14 @@ Do not modify postinst/postrm/prerm scripts.
 =item B<-o>, B<--onlyscripts>
 
 Only modify postinst/postrm/prerm scripts, do not actually install any init
-script or default files. May be useful if the init script is shipped and/or
-installed by upstream in a way that doesn't make it easy to let
-dh_installinit find it.
+script, default files, or upstart job.  May be useful if the init script or
+upstart job is shipped and/or installed by upstream in a way that doesn't
+make it easy to let dh_installinit find it.
+
+If no upstart job file is installed in the target directory when
+dh_installinit --onlyscripts is called, this program will assume that an
+init script is being installed and not provide the compatibility symlinks
+or upstart dependencies.
 
 =item B<-R>, B<--restart-after-upgrade>
 
@@ -68,7 +79,8 @@ Only call update-rc.d. Useful for rcS scripts.
 =item B<-d>, B<--remove-d>
 
 Remove trailing "d" from the name of the package, and use the result for the
-filename the init script is installed as in etc/init.d/ , and the default file
+filename the upstart job file is installed as in etc/init/ , or for the
+filename the init script is installed as in etc/init.d and the default file
 is installed as in etc/default/ . This may be useful for daemons with names
 ending in "d". (Note: this takes precedence over the --init-script parameter
 described below.)
@@ -82,11 +94,12 @@ passed to L<update-rc.d(8)>.
 
 =item B<--name=>I<name>
 
-Install the init script (and default file) using the filename I<name>
-instead of the default filename, which is the package name. When this
-parameter is used, dh_installinit looks for and installs files named
-debian/package.name.init and debian/package.name.default, instead of the
-usual debian/package.init and debian/package.default.
+Install the upstart job file or the init script (and default file) using the
+filename I<name> instead of the default filename, which is the package name.
+When this parameter is used, dh_installinit looks for and installs files
+named debian/package.name.upstart, debian/package.name.init and
+debian/package.name.default, instead of the usual debian/package.upstart,
+debian/package.init and debian/package.default.
 
 =item B<--init-script=>I<scriptname>
 
@@ -97,7 +110,8 @@ if a file in the debian/ directory exists that looks like
 "package.scriptname" and if so will install it as the init script in
 preference to the files it normally installs.
 
-This parameter is deprecated, use the --name parameter instead.
+This parameter is deprecated, use the --name parameter instead.  This
+parameter will be ignored completely for upstart jobs.
 
 =item B<--error-handler=>I<function>
 
@@ -130,8 +144,9 @@ foreach my $package (@{$dh{DOPACKAGES}}) {
 
        # Figure out what filename to install it as.
        my $script;
+       my $jobfile=$package;
        if (defined $dh{NAME}) {
-               $script=$dh{NAME};
+               $jobfile=$script=$dh{NAME};
        }
        elsif ($dh{D_FLAG}) {
                # -d on the command line sets D_FLAG. We will 
@@ -139,7 +154,7 @@ foreach my $package (@{$dh{DOPACKAGES}}) {
                # use that as the name.
                $script=$package;
                if ($script=~m/(.*)d$/) {
-                       $script=$1;
+                       $jobfile=$script=$1;
                }
                else {
                        warning("\"$package\" has no final d' in its name, but 
-d was specified.");
@@ -152,9 +167,31 @@ foreach my $package (@{$dh{DOPACKAGES}}) {
                $script=$package;
        }       
        
-       my $init=pkgfile($package,$script) || pkgfile($package,"init") ||
-             pkgfile($package,"init.d");
-       my $default=pkgfile($package,'default');
+       my $job=pkgfile($package,"upstart");
+       my ($init,$default) = ('','');
+
+       if ($job ne '' || ($dh{ONLYSCRIPTS} && -e 
"$tmp/etc/init/$jobfile.conf")) {
+               if (! $dh{ONLYSCRIPTS}) {
+                       if (! -d "$tmp/etc/init") {
+                               doit("install","-d","$tmp/etc/init");
+                       }
+               
+                       
doit("install","-p","-m644",$job,"$tmp/etc/init/$jobfile.conf");
+               }
+               
+               # ensures that our /etc/init.d/ symlink points to a valid
+               # implementation
+               addsubstvar($package, "misc:Depends", "upstart-job");
+
+               if (! -d "$tmp/etc/init.d") {
+                       doit("install","-d","$tmp/etc/init.d");
+               }
+               
doit("ln","-sf","/lib/init/upstart-job","$tmp/etc/init.d/$jobfile");
+       } else {
+               $init=pkgfile($package,$script) || pkgfile($package,"init") ||
+                       pkgfile($package,"init.d");
+               $default=pkgfile($package,'default');
+       }
 
        if ($default ne '' && ! $dh{ONLYSCRIPTS}) {
                if (! -d "$tmp/etc/default") {
@@ -163,15 +200,20 @@ foreach my $package (@{$dh{DOPACKAGES}}) {
                
doit("install","-p","-m644",$default,"$tmp/etc/default/$script");
        }
 
-       if ($init ne '' || $dh{ONLYSCRIPTS}) {
-               if (! $dh{ONLYSCRIPTS}) {
-                       if (! -d "$tmp/etc/init.d") {
-                               doit("install","-d","$tmp/etc/init.d");
-                       }
-               
-                       
doit("install","-p","-m755",$init,"$tmp/etc/init.d/$script");
+       if ($init ne '' && ! $dh{ONLYSCRIPTS}) {
+               if (! -d "$tmp/etc/init.d") {
+                       doit("install","-d","$tmp/etc/init.d");
                }
                
+               doit("install","-p","-m755",$init,"$tmp/etc/init.d/$script");
+       }
+
+       if ($job ne '' || $init ne '' || $dh{ONLYSCRIPTS})
+       {
+               if (-e "$tmp/etc/init/$jobfile.conf") {
+                       $script=$jobfile;
+               }
+
                # This is set by the -u "foo" command line switch, it's
                # the parameters to pass to update-rc.d. If not set,
                # we have to say "defaults".
@@ -227,8 +269,9 @@ L<debhelper(7)>
 
 This program is a part of debhelper.
 
-=head1 AUTHOR
+=head1 AUTHORS
 
 Joey Hess <jo...@debian.org>
+Steve Langasek <steve.langa...@canonical.com>
 
 =cut
-- 
1.6.3.3

-- 
Steve Langasek                   Give me a lever long enough and a Free OS
Debian Developer                   to set it on, and I can move the world.
Ubuntu Developer                                    http://www.debian.org/
slanga...@ubuntu.com                                     vor...@debian.org

Attachment: signature.asc
Description: Digital signature

Reply via email to