X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=dh_installudev;h=fa369a026d6286d3642adb8b3512394ed2c0bb24;hb=18a0da8092ea9f3dc48bca92b36f592af25a608d;hp=2c6ea4188281cc5dba04e2f70aa0e32509a98fec;hpb=f859c23a77b93368b96630b4b0ff79f039b87a2f;p=debhelper.git diff --git a/dh_installudev b/dh_installudev index 2c6ea41..fa369a0 100755 --- a/dh_installudev +++ b/dh_installudev @@ -4,7 +4,6 @@ dh_installudev - install udev rules files - =cut use strict; @@ -17,40 +16,45 @@ B [S>] [B<-n>] [B<--name=>I] [B<--pri =head1 DESCRIPTION -dh_installudev is a debhelper program that is responsible for -installing udev rules files. - -Files named debian/package.udev will be installed as -etc/udev/package.rules in the package build directory. +B is a debhelper program that is responsible for +installing B rules files. -Then postinst and postrm commands are automatically generated to enable -the rules file when the package is first installed, by creating a symlink -to it in the /etc/udev/rules.d/ directory. See L for an -explanation of how this works. +Code is added to the F and F to handle the upgrade from the +old B rules file location. -=head1 OPTIONS +=head1 FILES =over 4 -=item B<-n>, B<--noscripts> +=item debian/I.udev + +Installed into F in the package build directory. -Do not modify postinst/postrm scripts. +=back + +=head1 OPTIONS + +=over 4 =item B<--name=>I -When this parameter is used, dh_installudev looks for and -installs files named debian/package.name.udev instead of the usual -debian/package.udev. +When this parameter is used, B looks for and +installs files named debian/I.I.udev instead of the usual +debian/I.udev. =item B<--priority=>I -Sets the priority string of the rules.d symlink. Default is z60. +Sets the priority string of the F symlink. Default is 60. + +=item B<-n>, B<--noscripts> + +Do not modify F/F scripts. =back =head1 NOTES -Note that this command is not idempotent. "dh_clean -k" should be called +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. @@ -58,30 +62,52 @@ instances of the same text to be added to maintainer scripts. init(); +# The priority used to look like z60_; +# we need to calculate that old value to handle +# conffile moves correctly. +my $old_priority=$dh{PRIORITY}; + +# In case a caller still uses the `z` prefix, remove it. +if (defined $dh{PRIORITY}) { + $dh{PRIORITY}=~s/^z//; +} + if (! defined $dh{PRIORITY}) { - $dh{PRIORITY}="z60"; + $dh{PRIORITY}="60"; + $old_priority="z60"; } if ($dh{PRIORITY}) { - $dh{PRIORITY}.="_"; + $dh{PRIORITY}.="-"; + $old_priority.="_"; } foreach my $package (@{$dh{DOPACKAGES}}) { my $tmp=tmpdir($package); my $rules_file=pkgfile($package,"udev"); my $filename=basename($rules_file); + if ($filename eq 'udev') { + $filename = "$package.udev"; + } $filename=~s/\.udev$/.rules/; + my $oldfilename=$filename; + if (defined $dh{NAME}) { + $filename="$dh{NAME}.rules"; + } if ($rules_file) { - if (! -e "$tmp/etc/udev") { - doit("install","-d","$tmp/etc/udev"); + if (! -e "$tmp/lib/udev/rules.d") { + doit("install","-d","$tmp/lib/udev/rules.d"); } - doit("install","-m","0644",$rules_file,"$tmp/etc/udev/$filename"); - + my $rule="/lib/udev/rules.d/$dh{PRIORITY}$filename"; + doit("install","-m","0644",$rules_file,$tmp.$rule); if (! $dh{NOSCRIPTS}) { - autoscript($package,"postinst","postinst-udev", - "s/#FILE#/$filename/g;s/#PRIO#/$dh{PRIORITY}/g"); - autoscript($package,"postrm","postrm-udev", - "s/#FILE#/$filename/g;s/#PRIO#/$dh{PRIORITY}/g"); + # Remove old rule from /etc, unless it's modified, + # in which case we rename it to match the new + # file in /lib, so it will override. + my $old="/etc/udev/rules.d/$old_priority$oldfilename"; + $rule=~s/^\/lib/\/etc/; + autoscript($package,"preinst","preinst-moveconffile","s!#OLD#!$old!g;s!#NEW#!$rule!g;s!#PACKAGE#!$package!g"); + autoscript($package,"postinst","postinst-moveconffile","s!#OLD#!$old!g;s!#NEW#!$rule!g"); } } }