summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Baumann <daniel@debian.org>2013-02-21 19:07:41 +0100
committerDaniel Baumann <mail@daniel-baumann.ch>2013-05-06 14:50:06 +0200
commitd4f8b95cdf4eaf51c63312f081c54a0f7d6f13ed (patch)
tree1971f110f099413e4fec3f2fa1c220dd524bcc97
parent212e5bedd3ad9f875ea9428b9befc602c3819e3f (diff)
downloadvyos-live-build-d4f8b95cdf4eaf51c63312f081c54a0f7d6f13ed.tar.gz
vyos-live-build-d4f8b95cdf4eaf51c63312f081c54a0f7d6f13ed.zip
Adding source_hooks for hooks on source images like already supported on binary images.
-rwxr-xr-xscripts/build/source1
-rwxr-xr-xscripts/build/source_hooks78
2 files changed, 79 insertions, 0 deletions
diff --git a/scripts/build/source b/scripts/build/source
index 0dc9780da..4296c2750 100755
--- a/scripts/build/source
+++ b/scripts/build/source
@@ -51,6 +51,7 @@ lb chroot_archives source install ${@}
lb source_debian-live ${@}
lb source_debian ${@}
lb source_disk ${@}
+lb source_hooks ${@}
lb source_checksums ${@}
# Building images
diff --git a/scripts/build/source_hooks b/scripts/build/source_hooks
new file mode 100755
index 000000000..f3316bd97
--- /dev/null
+++ b/scripts/build/source_hooks
@@ -0,0 +1,78 @@
+#!/bin/sh
+
+## live-build(7) - System Build Scripts
+## Copyright (C) 2006-2013 Daniel Baumann <daniel@debian.org>
+##
+## This program comes with ABSOLUTELY NO WARRANTY; for details see COPYING.
+## This is free software, and you are welcome to redistribute it
+## under certain conditions; see COPYING for details.
+
+
+set -e
+
+# Including common functions
+[ -e "${LIVE_BUILD}/scripts/build.sh" ] && . "${LIVE_BUILD}/scripts/build.sh" || . /usr/lib/live/build.sh
+
+# Setting static variables
+DESCRIPTION="$(Echo 'execute hooks in source')"
+HELP=""
+USAGE="${PROGRAM} [--force]"
+
+Arguments "${@}"
+
+# Reading configuration files
+Read_conffiles config/all config/common config/bootstrap config/chroot config/source config/source
+Set_defaults
+
+Echo_message "Begin executing hooks..."
+
+# Requiring stage file
+Require_stagefile .build/config .build/bootstrap
+
+# Checking stage file
+Check_stagefile .build/source_hooks
+
+# Checking lock file
+Check_lockfile .lock
+
+# Creating lock file
+Create_lockfile .lock
+
+## Processing distribution hooks
+
+# Running hooks
+for _HOOK in ${LB_BINARY_HOOKS}
+do
+ for LOCATION in "${LIVE_BUILD}/hooks" /usr/share/live/build/hooks
+ do
+ for FILE in "${LOCATION}"/????-"${_HOOK}".source
+ do
+ if [ -e "${FILE}" ]
+ then
+ cd source
+ "${FILE}" || { Echo_error "${_HOOK} failed (exit non-zero). You should check for errors."; exit 1 ;}
+ cd "${OLDPWD}"
+ fi
+ done
+ done
+done
+
+## Processing local hooks
+
+if Find_files config/hooks/*.source
+then
+ for HOOK in config/hooks/*.source
+ do
+ # Making hook executable
+ if [ ! -x "${HOOK}" ]
+ then
+ chmod +x "${HOOK}"
+ fi
+
+ # Executing hook
+ ./"${HOOK}" || { Echo_error "${HOOK} failed (exit non-zero). You should check for errors."; exit 1 ;}
+ done
+
+ # Creating stage file
+ Create_stagefile .build/source_hooks
+fi