From 3ae36d1c7fc9787e335c29075cbae5326575b2c3 Mon Sep 17 00:00:00 2001 From: Miklos Vajna Date: Fri, 4 Jan 2008 17:17:39 +0100 Subject: Merge branch 'pacman-g2' Conflicts: Makefile pre-install.d/50uncommitted-changes Additinoal fix: As noted by Joey, we should bail out with an error if git commit fails when using pacman-g2. Signed-off-by: Miklos Vajna --- Makefile | 3 +++ init.d/50git-ignore | 8 ++++++++ pre-install.d/50uncommitted-changes | 37 +++++++++++++++++++++++++------------ 3 files changed, 36 insertions(+), 12 deletions(-) diff --git a/Makefile b/Makefile index 23cb3ea..47cc3c9 100644 --- a/Makefile +++ b/Makefile @@ -13,3 +13,6 @@ install: ifeq ($(HIGHLEVEL_PACKAGE_MANAGER),apt)) install -m 0644 -D apt.conf $(PREFIX)/etc/apt/apt.conf.d/05etckeeper endif +ifeq ($(HIGHLEVEL_PACKAGE_MANAGER),pacman-g2)) + install -m 0644 -D pacman-g2.hook $(PREFIX)/etc/pacman-g2/hooks/etckeeper +endif diff --git a/init.d/50git-ignore b/init.d/50git-ignore index de58ed5..778774e 100755 --- a/init.d/50git-ignore +++ b/init.d/50git-ignore @@ -5,6 +5,14 @@ if [ ! -e .gitignore ]; then cat >.gitignore <.gitignore <>.gitignore <&1 | grep -q "working directory clean"; then - . /usr/share/debconf/confmodule - db_capb escape - db_title etckeeper + RET="true" + if [ "$HIGHLEVEL_PACKAGE_MANAGER" = "apt" ]; then + . /usr/share/debconf/confmodule + db_capb escape + db_title etckeeper - db_reset etckeeper/unclean || true - db_subst etckeeper/unclean STATUS $(git-status | debconf-escape -e) || true - db_input critical etckeeper/unclean || true - db_go || true - db_get etckeeper/unclean + db_reset etckeeper/unclean || true + db_subst etckeeper/unclean STATUS $(git-status | debconf-escape -e) || true + db_input critical etckeeper/unclean || true + db_go || true + db_get etckeeper/unclean + fi if [ "$RET" = true ]; then git add . if ! git commit $GIT_COMMIT_OPTIONS -m "saving uncommitted changes in /etc prior to $HIGHLEVEL_PACKAGE_MANAGER run"; then - db_input critical etckeeper/commit_failed || true - db_go || true - db_reset etckeeper/commit_failed || true + if [ "$HIGHLEVEL_PACKAGE_MANAGER" = "apt" ]; then + db_input critical etckeeper/commit_failed || true + db_go || true + db_reset etckeeper/commit_failed || true + elif [ "$HIGHLEVE_PACKAGE_MANAGER" = "pacman-g2" ]; then + echo "error: etckeeper failed to commit changes in /etc using git (git commit failed)" + exit 1 + fi fi fi - db_reset etckeeper/unclean || true + if [ "$HIGHLEVEL_PACKAGE_MANAGER" = "apt" ]; then + db_reset etckeeper/unclean || true + fi fi -- cgit v1.2.3