diff options
author | xengineering <me@xengineering.eu> | 2025-04-06 20:02:56 +0200 |
---|---|---|
committer | xengineering <me@xengineering.eu> | 2025-04-06 20:02:56 +0200 |
commit | ee1dea051b0a43c02cf56dfc6a812c1a32910bc6 (patch) | |
tree | 6f555191efc74f7ada207990a233466e953175b8 /tools/build_zephyr.py | |
parent | d19fc7e34f783b343e77b757c4f37aaadb5b66ca (diff) | |
parent | da27d61588202d6b460e36d29a8789d206495bd6 (diff) | |
download | iot-contact-ee1dea051b0a43c02cf56dfc6a812c1a32910bc6.tar iot-contact-ee1dea051b0a43c02cf56dfc6a812c1a32910bc6.tar.zst iot-contact-ee1dea051b0a43c02cf56dfc6a812c1a32910bc6.zip |
Merge website and CMake to Meson transition
Building a website to structure and deploy the artifacts was planned and
requires a well set-up build system to handle all the file paths targets
and dependencies.
Since multiple CMake Zephyr builds are required for the application
firmware, bootloader firmware and the native_sim application firmware
simulation CMake external project was used.
Since this generates a build tree with a confusing structure Meson was
evaluated.
Finally the Meson build system was a good fit as top-level build system
and allows external projects as an experimental feature if they can
configure a Make-based build system which is given for Zephyr.
Diffstat (limited to 'tools/build_zephyr.py')
-rwxr-xr-x | tools/build_zephyr.py | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/tools/build_zephyr.py b/tools/build_zephyr.py new file mode 100755 index 0000000..1d9e783 --- /dev/null +++ b/tools/build_zephyr.py @@ -0,0 +1,48 @@ +#!/usr/bin/env python3 + + +# This Source Code Form is subject to the terms of the Mozilla Public License, +# v. 2.0. If a copy of the MPL was not distributed with this file, You can +# obtain one at https://mozilla.org/MPL/2.0/. + + +import argparse +import multiprocessing +import shutil +import subprocess +import pathlib + + +def main() -> None: + parser = argparse.ArgumentParser( + description="Build a Zephyr GNU Make build", + ) + + parser.add_argument("-B", "--build-tree", required=True) + parser.add_argument("-b", "--binary-name", required=True) + parser.add_argument("-n", "--target-name", required=True) + + args = parser.parse_args() + + build_tree = pathlib.Path(args.build_tree) + output_dir = build_tree.parent + + subprocess.run( + [ + "make", + f"-j{multiprocessing.cpu_count()}", + "-C", + f"{str(build_tree)}", + ], + shell=False, + check=True, + ) + + shutil.copy( + build_tree / "zephyr" / args.binary_name, + output_dir / args.target_name + ) + + +if __name__ == "__main__": + main() |