From 1e3e36af11bafd1f8a6fbdd4b5a6f9c93b3c8a07 Mon Sep 17 00:00:00 2001 From: Andrew Kaster Date: Thu, 6 Jun 2024 14:57:11 -0600 Subject: [PATCH] Meta+CMake: Move vcpkg directives to ladybird.sh and CMakePresets Also add a vcpkg command to ladybird.sh to ensure that vcpkg is setup, and use a local binary cache for vcpkg build and install media to avoid cluttering $XDG_CACHE_HOME. --- CMakeLists.txt | 3 --- Meta/ladybird.sh | 14 +++++++++----- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 6a1016b8b8ea..25cac077b239 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,8 +1,5 @@ cmake_minimum_required(VERSION 3.25) -SET(CMAKE_TOOLCHAIN_FILE "$ENV{VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake") -set(VCPKG_INSTALL_OPTIONS --no-print-usage) - project(ladybird VERSION 0.1.0 LANGUAGES C CXX diff --git a/Meta/ladybird.sh b/Meta/ladybird.sh index 9d7fe2bcfcf4..04a2369ed716 100755 --- a/Meta/ladybird.sh +++ b/Meta/ladybird.sh @@ -16,6 +16,7 @@ Usage: $NAME COMMAND [ARGS...] gdb: Same as run, but also starts a gdb remote session. $NAME gdb EXECUTABLE [-ex 'any gdb command']... Passes through '-ex' commands to gdb + vcpkg: Ensure that dependencies are available test: $NAME test [TEST_NAME_PATTERN] Runs the unit tests on the build host, or if TEST_NAME_PATTERN is specified tests matching it. @@ -68,7 +69,7 @@ get_top_dir() { } create_build_dir() { - cmake -GNinja "${CMAKE_ARGS[@]}" -S "$LADYBIRD_SOURCE_DIR" -B "$BUILD_DIR" + cmake --preset default "${CMAKE_ARGS[@]}" -S "$LADYBIRD_SOURCE_DIR" -B "$BUILD_DIR" } cmd_with_target() { @@ -81,8 +82,7 @@ cmd_with_target() { export LADYBIRD_SOURCE_DIR fi BUILD_DIR="$LADYBIRD_SOURCE_DIR/Build/ladybird" - CMAKE_ARGS+=("-DCMAKE_INSTALL_PREFIX=$LADYBIRD_SOURCE_DIR/Build/lagom-install") - CMAKE_ARGS+=("-DSERENITY_CACHE_DIR=${LADYBIRD_SOURCE_DIR}/Build/caches") + CMAKE_ARGS+=("-DCMAKE_INSTALL_PREFIX=$LADYBIRD_SOURCE_DIR/Build/ladybird-install") export PATH="$LADYBIRD_SOURCE_DIR/Toolchain/Local/cmake/bin:$LADYBIRD_SOURCE_DIR/Toolchain/Local/vcpkg/bin:$PATH" export VCPKG_ROOT="$LADYBIRD_SOURCE_DIR/Toolchain/Tarballs/vcpkg" @@ -94,7 +94,7 @@ ensure_target() { run_tests() { local TEST_NAME="$1" - local CTEST_ARGS=("--output-on-failure" "--test-dir" "$BUILD_DIR") + local CTEST_ARGS=("--preset" "default" "--output-on-failure" "--test-dir" "$BUILD_DIR") if [ -n "$TEST_NAME" ]; then if [ "$TEST_NAME" = "WPT" ]; then CTEST_ARGS+=("-C" "Integration") @@ -149,6 +149,7 @@ run_gdb() { for arg in "${CMD_ARGS[@]}"; do if [ "$PASS_ARG_TO_GDB" != "" ]; then GDB_ARGS+=( "$PASS_ARG_TO_GDB" "$arg" ) + PASS_ARG_TO_GDB="" elif [ "$arg" = "-ex" ]; then PASS_ARG_TO_GDB="$arg" @@ -178,7 +179,7 @@ build_and_run_lagom_target() { build_target "${lagom_target}" if [ "$lagom_target" = "ladybird" ] && [ "$(uname -s)" = "Darwin" ]; then - open --wait-apps --stdout $(tty) --stderr $(tty) "$BUILD_DIR/bin/Ladybird.app" --args "${lagom_args[@]}" + open --wait-apps --stdout "$(tty)" --stderr "$(tty)" "$BUILD_DIR/bin/Ladybird.app" --args "${lagom_args[@]}" else local lagom_bin="$lagom_target" if [ "$lagom_bin" = "ladybird" ]; then @@ -238,6 +239,9 @@ if [[ "$CMD" =~ ^(build|install|run|gdb|test|rebuild|recreate|addr2line)$ ]]; th elif [ "$CMD" = "delete" ]; then cmd_with_target delete_target +elif [ "$CMD" = "vcpkg" ]; then + cmd_with_target + ensure_toolchain else >&2 echo "Unknown command: $CMD" usage