diff options
-rw-r--r-- | Meta/CMake/processor-count.cmake | 3 | ||||
-rwxr-xr-x | Meta/serenity.sh | 8 |
2 files changed, 9 insertions, 2 deletions
diff --git a/Meta/CMake/processor-count.cmake b/Meta/CMake/processor-count.cmake new file mode 100644 index 0000000000..d77786de4c --- /dev/null +++ b/Meta/CMake/processor-count.cmake @@ -0,0 +1,3 @@ +include(ProcessorCount) +ProcessorCount(N) +message("${N}") diff --git a/Meta/serenity.sh b/Meta/serenity.sh index a4b75f8409..0bb9bab652 100755 --- a/Meta/serenity.sh +++ b/Meta/serenity.sh @@ -218,12 +218,16 @@ build_target() { # invoked superbuild for serenity target that doesn't set -DBUILD_LAGOM=ON cmake -S "$SERENITY_SOURCE_DIR/Meta/Lagom" -B "$BUILD_DIR" -DBUILD_LAGOM=ON fi + + # Get either the environement MAKEJOBS or all processors via CMake + [ -z "$MAKEJOBS" ] && MAKEJOBS=$(cmake -P "$SERENITY_SOURCE_DIR/Meta/CMake/processor-count.cmake") + # With zero args, we are doing a standard "build" # With multiple args, we are doing an install/image/run if [ $# -eq 0 ]; then - cmake --build "$SUPER_BUILD_DIR" + CMAKE_BUILD_PARALLEL_LEVEL="$MAKEJOBS" cmake --build "$SUPER_BUILD_DIR" else - ninja -C "$BUILD_DIR" -- "$@" + ninja -j "$MAKEJOBS" -C "$BUILD_DIR" -- "$@" fi } |