]> git.saurik.com Git - apt.git/commitdiff
* debian/apt.conf.autoremove: don't include linux-image*,
authorSteve Langasek <steve.langasek@canonical.com>
Fri, 2 Nov 2012 23:39:19 +0000 (00:39 +0100)
committerSteve Langasek <steve.langasek@canonical.com>
Fri, 2 Nov 2012 23:39:19 +0000 (00:39 +0100)
  linux-restricted-modules*, and linux-ubuntu-modules* packages in the
  list to never be autoremoved.
* debian/apt.auto-removal.sh, debian/rules, debian/apt.dirs: install new
  script to /etc/kernel/postinst.d/ which ensures we only automatically
  keep the currently-running kernel, the being-installed kernel, and the
  newest kernel, so we don't fill /boot up with an unlimited number of
  kernels.  LP: #923876.

debian/apt.auto-removal.sh [new file with mode: 0644]
debian/apt.conf.autoremove
debian/apt.dirs
debian/changelog
debian/rules

diff --git a/debian/apt.auto-removal.sh b/debian/apt.auto-removal.sh
new file mode 100644 (file)
index 0000000..8f6fc2e
--- /dev/null
@@ -0,0 +1,67 @@
+#!/bin/sh
+
+set -e
+
+# Author: Steve Langasek <steve.langasek@canonical.com>
+#
+# Mark as not-for-autoremoval those kernel packages that are:
+#  - the currently booted version
+#  - the kernel version we've been called for
+#  - the latest kernel version (determined using rules copied from the grub
+#    package for deciding which kernel to boot)
+# In the common case, this results in exactly two kernels saved, but it can
+# result in three kernels being saved.  It's better to err on the side of
+# saving too many kernels than saving too few.
+#
+# We generate this list and save it to /etc/apt/apt.conf.d instead of marking
+# packages in the database because this runs from a postinst script, and apt
+# will overwrite the db when it exits.
+
+config_file=/etc/apt/apt.conf.d/01autoremove-kernels
+
+installed_version="$1"
+running_version="$(uname -r)"
+
+
+version_test_gt ()
+{
+       local version_test_gt_sedexp="s/[._-]\(pre\|rc\|test\|git\|old\|trunk\)/~\1/g"
+       local version_a="`echo "$1" | sed -e "$version_test_gt_sedexp"`"
+       local version_b="`echo "$2" | sed -e "$version_test_gt_sedexp"`"
+       dpkg --compare-versions "$version_a" gt "$version_b"
+       return "$?"
+}
+
+list=$(dpkg -l 'linux-image-[0-9]*'|awk '/^ii/ { print $2 }' | sed -e's/linux-image-//')
+
+latest_version=""
+for i in $list; do
+       if version_test_gt "$i" "$latest_version"; then
+               latest_version="$i"
+       fi
+done
+
+kernels=$(sort -u <<EOF
+$latest_version
+$installed_version
+$running_version
+EOF
+)
+
+cat > "$config_file".dpkg-new <<EOF
+# File autogenerated by $0, do not edit
+APT
+{
+  NeverAutoRemove
+  {
+EOF
+for kernel in $kernels; do
+       echo "    \"^linux-image-$kernel.*\";" >> "$config_file".dpkg-new
+       echo "    \"^linux-image-extra-$kernel.*\";" >> "$config_file".dpkg-new
+       echo "    \"^linux-signed-image-$kernel.*\";" >> "$config_file".dpkg-new
+done
+cat >> "$config_file".dpkg-new <<EOF
+  };
+};
+EOF
+mv "$config_file".dpkg-new "$config_file"
index c7ad51e66d21acf752bd1693d567f69664ec7586..9684c9c7db0a1f8d35bc6cd089a9387cc7617611 100644 (file)
@@ -4,10 +4,7 @@ APT
   {
        "^firmware-linux.*";
        "^linux-firmware$";
-       "^linux-image.*";
        "^kfreebsd-image.*";
-       "^linux-restricted-modules.*";
-       "^linux-ubuntu-modules-.*";
        "^gnumach$";
        "^gnumach-image.*";
   };
index 8284536557e669e0470854dd48d7e5a9f8a24d48..ecbcdbc0a5bdcc6f21d63abfd46833b3d53afe58 100644 (file)
@@ -7,6 +7,7 @@ etc/apt/apt.conf.d
 etc/apt/preferences.d
 etc/apt/sources.list.d
 etc/apt/trusted.gpg.d
+etc/kernel/postinst.d
 etc/logrotate.d
 var/cache/apt/archives/partial
 var/lib/apt/lists/partial
index 37fa5977bb1545c9ff390eef3403b28b9007e9b3..e4a27c604ca02a1503773157b6ae7a96de07bf5f 100644 (file)
@@ -54,6 +54,19 @@ apt (0.9.7.6) unstable; urgency=low
 
  -- Michael Vogt <mvo@debian.org>  Tue, 16 Oct 2012 18:08:53 +0200
 
+apt (0.9.7.5ubuntu6) UNRELEASED; urgency=low
+
+  * debian/apt.conf.autoremove: don't include linux-image*,
+    linux-restricted-modules*, and linux-ubuntu-modules* packages in the
+    list to never be autoremoved.
+  * debian/apt.auto-removal.sh, debian/rules, debian/apt.dirs: install new
+    script to /etc/kernel/postinst.d/ which ensures we only automatically
+    keep the currently-running kernel, the being-installed kernel, and the
+    newest kernel, so we don't fill /boot up with an unlimited number of
+    kernels.  LP: #923876.
+
+ -- Steve Langasek <steve.langasek@ubuntu.com>  Fri, 02 Nov 2012 23:13:00 +0000
+
 apt (0.9.7.5ubuntu5) quantal; urgency=low
 
   * Revert "missing remap registration" change from 0.9.7.5ubuntu4; this
index 8da5ae79092486a00b9a05e37880fd5d70ee908b..618c7f8d0e7ea7742c98c5fae32d59f1da1ab264 100755 (executable)
@@ -186,6 +186,8 @@ apt: build build-manpages
 #
        cp debian/apt.conf.autoremove debian/$@/etc/apt/apt.conf.d/01autoremove
        cp debian/apt.conf.changelog debian/$@/etc/apt/apt.conf.d/20changelog
+       cp debian/apt.auto-removal.sh debian/$@/etc/kernel/postinst.d/apt-auto-removal
+       chmod 755 debian/$@/etc/kernel/postinst.d/apt-auto-removal
        cp share/ubuntu-archive.gpg debian/$@/usr/share/$@
 
        # make rosetta happy and remove pot files in po/ (but leave stuff