summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/build-submodules60
1 files changed, 52 insertions, 8 deletions
diff --git a/scripts/build-submodules b/scripts/build-submodules
index a3a371a1..5dc81e2e 100755
--- a/scripts/build-submodules
+++ b/scripts/build-submodules
@@ -20,8 +20,11 @@ print_help() {
echo "Parameters:"
echo " --init-packages - Initiate all subpackages before building"
echo " --verbose - Enable verbose output"
+ echo " --build-[packagename] - build only selected packages"
}
+BUILDLIST=""
+
while test $# -gt 0
do
case "$1" in
@@ -35,6 +38,10 @@ do
--verbose)
VERBOSE=1
;;
+ --build-*)
+ VAL=$(sed s/^--build-//g <<< $1)
+ BUILDLIST="$BUILDLIST $VAL"
+ ;;
*)
(>&2 echo "Error: Argument $1 is not valid")
echo ""
@@ -57,7 +64,7 @@ status_fail() {
}
status_skip() {
- echo -ne "\r[SKIP] $1\n"
+ echo -ne "\r[SKIP] $1\033[K\n"
}
error_msg() {
@@ -67,9 +74,28 @@ ROOTDIR="$(pwd)"
PKGDIR="$ROOTDIR/packages"
SCRIPTDIR="$ROOTDIR/scripts"
+package_in_buildlist() {
+ # Return true if buildlist is not set
+ if [ -z "$BUILDLIST" ]; then
+ return 0
+ fi
+
+ if [[ $BUILDLIST =~ (^|[[:space:]])$1($|[[:space:]]) ]]; then
+ return 0
+ fi
+
+ return 1
+
+
+}
+
build_package() {
PKG=$1
- status_start "Building package: $PKG"
+ COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD)
+ if ! package_in_buildlist $1; then
+ return 0
+ fi
+ status_start "Building package: $PKG Commit id: $COMMITID"
if [ ! -d "$PKGDIR/$PKG/debian" ]; then
status_skip "No source for: $PKG"
return 1
@@ -90,9 +116,10 @@ echo "Cleaning up buildfiles..."
rm -rf $PKGDIR/*.deb
rm -rf $PKGDIR/*.changes
rm -rf $PKGDIR/*.buildlog
+COMMITID=$(cd $PKGDIR; git rev-parse --short=10 HEAD)
echo "-----------------------------------------------------"
echo "Starting build process for all packages"
-echo ""
+echo "vyos-build Commit ID: $COMMITID"
initialize_packages() {
status_start "Initializing packages"
@@ -117,8 +144,10 @@ fi
build_frr() {
PKG=frr
-
- status_start "Building package: $PKG"
+ if ! package_in_buildlist "frr"; then
+ return 0
+ fi
+ status_start "Building package: $PKG (Git commit/tag: $FRR_VER)"
if [ ! -f "$PKGDIR/$PKG/README.md" ]; then
status_skip "No source for: $PKG"
return 1
@@ -229,7 +258,12 @@ done
# KERNEL
build_kernel() {
- status_start "Building-package: vyos-kernel"
+ PKG="vyos-kernel"
+ if ! package_in_buildlist "vyos-kernel"; then
+ return 0
+ fi
+ COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD)
+ status_start "Building-package: vyos-kernel Commit ID:$COMMITID"
if [ ! -f "$PKGDIR/vyos-kernel/Makefile" ]; then
status_skip "No source for: vyos-kernel"
return 0
@@ -264,7 +298,12 @@ fi
# WIREGUARD
build_wireguard() {
- status_start "Building package: vyos-wireguard"
+ PKG="vyos-wireguard"
+ if ! package_in_buildlist "vyos-wireguard"; then
+ return 0
+ fi
+ COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD)
+ status_start "Building package: vyos-wireguard Commit ID:$COMMITID"
if [ ! -d "$PKGDIR/vyos-wireguard/debian" ]; then
status_skip "No source for: vyos-wireguard"
@@ -311,7 +350,12 @@ fi
# ACCEL-PPP
build_accel-ppp() {
- status_start "Building package: vyos-accel-ppp"
+ PKG="vyos-accel-ppp"
+ if ! package_in_buildlist "accel-ppp"; then
+ return 0
+ fi
+ COMMITID=$(cd $PKGDIR/$PKG; git rev-parse --short=10 HEAD)
+ status_start "Building package: vyos-accel-ppp Commit ID: $COMMITID"
if [ ! -d "$PKGDIR/vyos-accel-ppp/debian" ]; then
status_skip "No source for: vyos-accel-ppp"
return 0