summaryrefslogtreecommitdiff
path: root/packages/frr/build-frr.sh
diff options
context:
space:
mode:
Diffstat (limited to 'packages/frr/build-frr.sh')
-rwxr-xr-xpackages/frr/build-frr.sh41
1 files changed, 41 insertions, 0 deletions
diff --git a/packages/frr/build-frr.sh b/packages/frr/build-frr.sh
new file mode 100755
index 00000000..59134832
--- /dev/null
+++ b/packages/frr/build-frr.sh
@@ -0,0 +1,41 @@
+#!/bin/sh
+CWD=$(pwd)
+set -e
+
+FRR_SRC=frr
+
+if [ ! -d ${FRR_SRC} ]; then
+ echo "FRR source directory does not exists, please 'git clone'"
+ exit 1
+fi
+
+# VyOS requires some small FRR Patches - apply them here
+# It's easier to habe them here and make use of the upstream
+# repository instead of maintaining a full Fork.
+# Saving time/resources is essential :-)
+cd ${FRR_SRC}
+
+PATCH_DIR=${CWD}/patches
+
+for patch in $(ls ${PATCH_DIR})
+do
+ echo "I: Apply FRR patch: ${PATCH_DIR}/${patch}"
+ patch -p1 < ${PATCH_DIR}/${patch}
+ git add $(lsdiff ${PATCH_DIR}/${patch} | sed -e 's#^[ab]/##')
+ if [ -z "$(git config --list | grep -e user.name -e user.email)" ]; then
+ # if git user.name and user.email is not set, -c sets temorary user.name and
+ # user.email variables as these is not set in the build container by default.
+ git -c user.name="VyOS CI" -c user.email="ci@vyos.io" commit -m "Applied patch: ${patch}" --author "VyOS CI <ci@vyos.io>"
+ else
+ git commit -m "Applied patch: ${patch}" --author "VyOS CI <ci@vyos.io>"
+ fi
+
+done
+
+# Prepare FRR source for building
+echo "I: Prepare FRR source for building"
+./tools/tarsource.sh -V
+
+# Build Debian FRR package
+echo "I: Build Debian FRR Package"
+dpkg-buildpackage -us -uc -Ppkg.frr.rtrlib