summaryrefslogtreecommitdiff
path: root/packages/keepalived/build.py
diff options
context:
space:
mode:
authorChristian Breunig <christian@breunig.cc>2023-10-27 18:07:32 +0200
committerGitHub <noreply@github.com>2023-10-27 18:07:32 +0200
commitc2e640db50e00ab5ef9de618f8f8393755cf79b2 (patch)
tree895c1f2c42b4ccdc2f5e82fe1cbf0a3415eb19b8 /packages/keepalived/build.py
parent0506fc76632750af74722ca4319ebbb796f59bd0 (diff)
parent86a97880700a42f2416c196ce93853a4e7e18b4d (diff)
downloadvyos-build-c2e640db50e00ab5ef9de618f8f8393755cf79b2.tar.gz
vyos-build-c2e640db50e00ab5ef9de618f8f8393755cf79b2.zip
Merge pull request #442 from aapostoliuk/T5402-current
keepalived:T5402:Added patch with arp_ignore to 1 on IPv6 VMACs
Diffstat (limited to 'packages/keepalived/build.py')
-rwxr-xr-xpackages/keepalived/build.py50
1 files changed, 50 insertions, 0 deletions
diff --git a/packages/keepalived/build.py b/packages/keepalived/build.py
new file mode 100755
index 00000000..04f4791b
--- /dev/null
+++ b/packages/keepalived/build.py
@@ -0,0 +1,50 @@
+#!/usr/bin/env python3
+
+from pathlib import Path
+from shutil import copy as copy_file
+from subprocess import run
+
+
+# copy patches
+def apply_deb_patches() -> None:
+ """Apply patches to sources directory
+ """
+ patches_dir = Path('../patches')
+ current_dir: str = Path.cwd().as_posix()
+ if patches_dir.exists():
+ patches_list = list(patches_dir.iterdir())
+ patches_list.sort()
+ Path(f'{current_dir}/debian/patches').mkdir(parents=True, exist_ok=True)
+ series_file = Path(f'{current_dir}/debian/patches/series')
+ series_data = ''
+ for patch_file in patches_list:
+ print(f'Applying patch: {patch_file.name}')
+ copy_file(patch_file, f'{current_dir}/debian/patches/')
+ if series_file.exists():
+ series_data: str = series_file.read_text()
+ series_data = f'{series_data}\n{patch_file.name}'
+ series_file.write_text(series_data)
+
+
+def build_package() -> bool:
+ """Build a package
+
+ Returns:
+ bool: build status
+ """
+ build_cmd: list[str] = ['dpkg-buildpackage', '-uc', '-us', '-tc', '-b']
+ build_status: int = run(build_cmd).returncode
+
+ if build_status:
+ return False
+ return True
+
+
+# build a package
+if __name__ == '__main__':
+ apply_deb_patches()
+
+ if not build_package():
+ exit(1)
+
+ exit()