summaryrefslogtreecommitdiff
path: root/pre-install.d
diff options
context:
space:
mode:
authorJoey Hess <joey@kodama.kitenet.net>2008-01-07 13:46:21 -0500
committerJoey Hess <joey@kodama.kitenet.net>2008-01-07 13:46:21 -0500
commit1e4dd3b87be8e06dd0ae1c4b2c250591b615a2e1 (patch)
tree21dae573cc194411593d43afa3025b80b3188891 /pre-install.d
parent82cbf4298c6cc347bd33ce4379cc9234cf2bc926 (diff)
* Separate debconf use from the main flow of the script so the commit
stage can use editors etc. Closes: #459547 * Remove the hint about setting -e to get interactive commits, since I don't want to encourage users to do that. (For one thing, it's unlikely to work if a graphical package manager is used..)
Diffstat (limited to 'pre-install.d')
-rwxr-xr-xpre-install.d/50uncommitted-changes53
1 files changed, 34 insertions, 19 deletions
diff --git a/pre-install.d/50uncommitted-changes b/pre-install.d/50uncommitted-changes
index f4c0f0f..bc33ff9 100755
--- a/pre-install.d/50uncommitted-changes
+++ b/pre-install.d/50uncommitted-changes
@@ -34,34 +34,49 @@ commit() {
fi
}
+if [ "$1" = "ask-debconf" ]; then
+ . /usr/share/debconf/confmodule
+ db_capb escape
+ db_title etckeeper
+
+ db_reset etckeeper/unclean || true
+ db_subst etckeeper/unclean VCS "$VCS"
+ db_subst etckeeper/unclean STATUS $(status | debconf-escape -e) || true
+ db_input critical etckeeper/unclean || true
+ db_go || true
+ db_get etckeeper/unclean
+ val="$RET"
+ db_reset etckeeper/unclean || true
+ if [ "$val" = true ]; then
+ exit 0
+ else
+ exit 1
+ fi
+elif [ "$1" = "fail-debconf" ]; then
+ . /usr/share/debconf/confmodule
+ db_subst etckeeper/commit_failed VCS "$VCS"
+ db_input critical etckeeper/commit_failed || true
+ db_go || true
+ db_reset etckeeper/commit_failed || true
+fi
+
if unclean; then
- RET="true"
+ docommit="true"
if [ -e /usr/share/debconf/confmodule ]; then
- . /usr/share/debconf/confmodule
- db_capb escape
- db_title etckeeper
-
- db_reset etckeeper/unclean || true
- db_subst etckeeper/unclean VCS "$VCS"
- db_subst etckeeper/unclean STATUS $(status | debconf-escape -e) || true
- db_input critical etckeeper/unclean || true
- db_go || true
- db_get etckeeper/unclean
+ if $0 ask-debconf; then
+ docommit=true
+ else
+ docommit=false
+ fi
fi
- if [ "$RET" = true ]; then
+ if [ "$docommit" = true ]; then
if ! commit "saving uncommitted changes in /etc prior to $HIGHLEVEL_PACKAGE_MANAGER run"; then
if [ -e /usr/share/debconf/confmodule ]; then
- db_subst etckeeper/commit_failed VCS "$VCS"
- db_input critical etckeeper/commit_failed || true
- db_go || true
- db_reset etckeeper/commit_failed || true
+ $0 fail-debconf
else
echo "error: etckeeper failed to commit changes in /etc using $VCS"
exit 1
fi
fi
fi
- if [ -e /usr/share/debconf/confmodule ]; then
- db_reset etckeeper/unclean || true
- fi
fi