]> git.saurik.com Git - apt.git/blobdiff - dselect/update
merged from debian-sid branch
[apt.git] / dselect / update
index ec5e78cc232d4874a6d720ca12bb5b6097e8f7c9..411033ca99b7788ae8fa242c76fa8446387c4bc7 100755 (executable)
@@ -1,29 +1,48 @@
-#!/bin/sh
+#!/bin/bash
 set -e
 
+# Set the textdomain for the translations using $"..."
+TEXTDOMAIN="apt"
+
 # Get the configuration from /etc/apt/apt.conf
+CLEAN="prompt"
 OPTS="-f"
 APTGET="/usr/bin/apt-get"
 APTCACHE="/usr/bin/apt-cache"
 DPKG="/usr/bin/dpkg"
+DPKG_OPTS="--admindir=$1"
+APT_OPT0="-oDir::State::status=$1/status"
+APT_OPT1="-oDPkg::Options::=$DPKG_OPTS"
 CACHEDIR="/var/cache/apt"
-PROMPT="no"
-RES=`apt-config shell OPTS DSelect::UpdateOptions \
-      DPKG Dir::Bin::dpkg APTGET Dir::Bin::apt-get \
-      APTCACHE Dir::Bin::apt-cache CACHEDIR Dir::Cache \
-      PROMPT DSelect::PromptAfterUpdate`
+PROMPT="false"
+RES=`apt-config shell CLEAN DSelect::Clean OPTS DSelect::UpdateOptions \
+                     DPKG Dir::Bin::dpkg/f APTGET Dir::Bin::apt-get/f \
+                     APTCACHE Dir::Bin::apt-cache/f CACHEDIR Dir::Cache/d \
+                     PROMPT DSelect::PromptAfterUpdate/b`
 eval $RES
 
-$APTGET $OPTS update
+# It looks slightly ugly to have a double / in the dpkg output
+CACHEDIR=`echo $CACHEDIR | sed -e "s|/$||"`
+
+STATUS=1
+if $APTGET $OPTS "$APT_OPT0" "$APT_OPT1" update
+then
+    echo $"Merging available information"
+    rm -f $CACHEDIR/available
+    $APTCACHE dumpavail > $CACHEDIR/available
+    $DPKG "$DPKG_OPTS" --update-avail $CACHEDIR/available
+    rm -f $CACHEDIR/available
 
-echo "Merging Available information"
-rm -f /var/cache/apt/available
-$APTCACHE dumpavail > $CACHEDIR/available
-$DPKG --update-avail $CACHEDIR/available
-rm -f $CACHEDIR/available
+    case "$CLEAN" in
+       Pre-Auto|PreAuto|pre-auto)
+           $APTGET "$APT_OPT0" "$APT_OPT1" autoclean;;
+    esac
+
+    STATUS=0
+fi
 
-if [ $PROMPT = "yes" ]; then
-   echo "Press enter to continue." && read RES;
+if [ x$PROMPT = "xtrue" ]; then
+   echo $"Press enter to continue." && read RES;
 fi
 
-exit 0
+exit $STATUS