From a29a4de6f4171d040a1e5ad9192a799967da7163 Mon Sep 17 00:00:00 2001 From: "alexey.lysiuk" Date: Sat, 31 Jul 2021 12:06:19 +0300 Subject: [PATCH] aedi: add cmake build target --- aedi/target/__init__.py | 1 + aedi/target/tools.py | 38 ++++++++++++++++++++++++++++++++++++++ deps/.gitignore | 1 + 3 files changed, 40 insertions(+) diff --git a/aedi/target/__init__.py b/aedi/target/__init__.py index c8973b2d..f5711776 100644 --- a/aedi/target/__init__.py +++ b/aedi/target/__init__.py @@ -97,6 +97,7 @@ def targets(): ZstdTarget(), # Tools + CMakeBuildTarget(), GmakeTarget(), MesonTarget(), NasmTarget(), diff --git a/aedi/target/tools.py b/aedi/target/tools.py index dd1afb25..403d0ef4 100644 --- a/aedi/target/tools.py +++ b/aedi/target/tools.py @@ -24,6 +24,44 @@ from .base import * from ..state import BuildState +class CMakeBuildTarget(CMakeTarget): + def __init__(self, name='cmake'): + super().__init__(name) + + # The following variables are needed for cross-compilation + opts = self.options + opts['HAVE_POLL_FINE_EXITCODE'] = '0' + opts['HAVE_POLL_FINE_EXITCODE__TRYRUN_OUTPUT'] = '0' + + def prepare_source(self, state: BuildState): + state.download_source( + 'https://github.com/Kitware/CMake/releases/download/v3.21.1/cmake-3.21.1.tar.gz', + 'fac3915171d4dff25913975d712f76e69aef44bf738ba7b976793a458b4cfed4') + + def configure(self, state: BuildState): + # Bootstrap native CMake binary + boostrap_path = state.native_build_path / '__bootstrap__' + boostrap_cmk_path = boostrap_path / 'Bootstrap.cmk' + boostrap_cmake = boostrap_cmk_path / 'cmake' + + if state.architecture() == machine(): + if not boostrap_cmake.exists(): + os.makedirs(boostrap_path, exist_ok=True) + + args = (state.source / 'configure', '--parallel=' + state.jobs) + subprocess.run(args, cwd=boostrap_path) + + assert boostrap_cmake.exists() + + env = self.environment + env['PATH'] = os.pathsep.join([str(boostrap_cmk_path), env['PATH']]) + + super().configure(state) + + def post_build(self, state: BuildState): + self.install(state) + + class GmakeTarget(ConfigureMakeDependencyTarget): def __init__(self, name='gmake'): super().__init__(name) diff --git a/deps/.gitignore b/deps/.gitignore index 0d592897..af89bcc7 100644 --- a/deps/.gitignore +++ b/deps/.gitignore @@ -60,6 +60,7 @@ # Tools /cmake/bin/* !/cmake/bin/cmake +/cmake/doc/ !/cmake/share/ /cmake/share/bash-completion /cmake/share/cmake-*/Help