From 7eb4153d76923f98688d27868be205b2515230ec Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jo=C3=A3o=20Matos?= Date: Thu, 31 Oct 2024 05:20:03 +0000 Subject: [PATCH] Bootstrap improvements (#2291) * Bootstrap improvements * Default to lookup 64-bit MSVC. --- .github/workflows/ci-workflow.yml | 17 +++++++----- BUILD.txt | 12 ++++++++- Bootstrap.bat | 23 +++++++++++----- Bootstrap.sh | 45 +++++++++++++++++++++++++++++++ binmodules/luasocket/premake5.lua | 2 +- 5 files changed, 84 insertions(+), 15 deletions(-) create mode 100755 Bootstrap.sh diff --git a/.github/workflows/ci-workflow.yml b/.github/workflows/ci-workflow.yml index c5efd9c075..fd59e95cbf 100644 --- a/.github/workflows/ci-workflow.yml +++ b/.github/workflows/ci-workflow.yml @@ -13,7 +13,7 @@ jobs: - name: Checkout uses: actions/checkout@v4 - name: Build - run: make -f Bootstrap.mak linux PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }} + run: PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }} ./Bootstrap.sh - name: Test run: bin/${{ matrix.config }}/premake5 test --test-all - name: Docs check @@ -34,7 +34,7 @@ jobs: - name: Checkout uses: actions/checkout@v4 - name: Build - run: make -f Bootstrap.mak macosx PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }} + run: PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }} ./Bootstrap.sh - name: Test run: bin/${{ matrix.config }}/premake5 test --test-all - name: Docs check @@ -51,13 +51,16 @@ jobs: matrix: config: [debug, release] platform: [Win32, x64] + msdev: [vs2022] steps: - name: Checkout uses: actions/checkout@v4 - name: Build - run: | - $vcvarsall_path = vswhere.exe -find VC\Auxiliary\Build\vcvarsall.bat - cmd.exe /c "call ""$vcvarsall_path"" x86_amd64 && nmake -f Bootstrap.mak MSDEV=vs2019 windows-msbuild PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }}" + shell: cmd + env: + PLATFORM: ${{ matrix.platform }} + CONFIG: ${{ matrix.config }} + run: ./Bootstrap.bat ${{ matrix.msdev }} - name: Test run: bin\${{ matrix.config }}\premake5 test --test-all shell: cmd @@ -98,7 +101,7 @@ jobs: pacboy: >- toolchain:p - name: Build - run: make -f Bootstrap.mak mingw PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }} + run: PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }} ./Bootstrap.sh - name: Test run: bin/${{ matrix.config }}/premake5.exe test --test-all - name: Docs check @@ -121,7 +124,7 @@ jobs: with: version: '3.9.2' - name: Build - run: make -f Bootstrap.mak cosmo CONFIG=${{ matrix.config }} + run: PLATFORM=${{ matrix.platform }} CONFIG=${{ matrix.config }} ./Bootstrap.sh -cosmo - name: Test run: bin/${{ matrix.config }}/premake5 test --test-all - name: Docs check diff --git a/BUILD.txt b/BUILD.txt index 45e0d5ce6d..b1a54247e0 100644 --- a/BUILD.txt +++ b/BUILD.txt @@ -27,7 +27,17 @@ BUILDING FROM A SOURCE PACKAGE BUILDING FROM THE REPOSITORY If you have pulled sources from the Premake source repository, you can - use `Bootstrap.mak` to generate your first premake executable: + use `Bootstrap.sh` or `Bootstrap.bat` to generate your first premake executable: + + On Windows: + + $ ./Bootstrap.bat + + On other platforms: + + $ ./Bootstrap.sh + +Alternatively, you may call the Makefile directly: $ make -f Bootstrap.mak PLATFORM diff --git a/Bootstrap.bat b/Bootstrap.bat index 375485a05f..19e3022e1c 100755 --- a/Bootstrap.bat +++ b/Bootstrap.bat @@ -9,6 +9,17 @@ SET VsWherePath="C:/Program Files (x86)/Microsoft Visual Studio/Installer/vswher REM =========================================================================== +SET "PlatformArg=" +SET "ConfigArg=" + +IF NOT "%PLATFORM%" == "" ( + SET "PlatformArg=PLATFORM=%PLATFORM%" +) + +IF NOT "%CONFIG%" == "" ( + SET "ConfigArg=CONFIG=%CONFIG%" +) + SET vsversion=%1 IF "%vsversion%" == "" ( CALL :BootstrapLatest @@ -67,7 +78,7 @@ IF NOT EXIST "%VsPath%vsdevcmd.bat" ( EXIT /B 2 ) -CALL "%VsPath%vsdevcmd.bat" && nmake MSDEV="%~1" -f Bootstrap.mak windows +CALL "%VsPath%vsdevcmd.bat" && nmake MSDEV="%~1" %PlatformArg% %ConfigArg% -f Bootstrap.mak windows EXIT /B %ERRORLEVEL% REM :LegacyVisualBootstrap @@ -94,18 +105,18 @@ SET VsWhereCmdLine="!VsWherePath! -nologo -latest -version [%VsVersionMin%,%VsVe FOR /F "usebackq delims=" %%i in (`!VsWhereCmdLine!`) DO ( - IF EXIST "%%i\VC\Auxiliary\Build\vcvars32.bat" ( - CALL "%%i\VC\Auxiliary\Build\vcvars32.bat" && nmake MSDEV="%PremakeVsVersion%" -f Bootstrap.mak windows + IF EXIST "%%i\VC\Auxiliary\Build\vcvars64.bat" ( + CALL "%%i\VC\Auxiliary\Build\vcvars64.bat" && nmake MSDEV="%PremakeVsVersion%" %PlatformArg% %ConfigArg% -f Bootstrap.mak windows EXIT /B %ERRORLEVEL% ) ELSE ( - IF EXIST "%%i\VC\Auxiliary\Build\vcvars64.bat" ( - CALL "%%i\VC\Auxiliary\Build\vcvars64.bat" && nmake MSDEV="%PremakeVsVersion%" -f Bootstrap.mak windows + IF EXIST "%%i\VC\Auxiliary\Build\vcvars32.bat" ( + CALL "%%i\VC\Auxiliary\Build\vcvars32.bat" && nmake MSDEV="%PremakeVsVersion%" %PlatformArg% %ConfigArg% -f Bootstrap.mak windows EXIT /B %ERRORLEVEL% ) ) ) -ECHO Could not find vcvars32.bat or vcvars64.bat to setup Visual Studio environment +ECHO Could not find vcvars64.bat or vcvars32.bat to setup Visual Studio environment EXIT /B 2 REM :VsWhereVisualBootstrap diff --git a/Bootstrap.sh b/Bootstrap.sh new file mode 100755 index 0000000000..6cb6e2b9f1 --- /dev/null +++ b/Bootstrap.sh @@ -0,0 +1,45 @@ +#!/bin/sh + +DIR=$( cd "$( dirname "$0" )" && pwd ) +cd "$DIR" + +COSMO_FLAG="" +for arg in "$@"; do + if [ "$arg" = "-cosmo" ]; then + COSMO_FLAG="cosmo" + break + fi +done + +PLATFORM_ARG="" +CONFIG_ARG="" + +if [ -n "$PLATFORM" ]; then + PLATFORM_ARG="PLATFORM=$PLATFORM" +fi + +if [ -n "$CONFIG" ]; then + CONFIG_ARG="CONFIG=$CONFIG" +fi + +case "$(uname -s)" in + Linux) + NPROC=$(nproc --all) + make -f Bootstrap.mak ${COSMO_FLAG:-linux} $PLATFORM_ARG $CONFIG_ARG -j$NPROC + ;; + Darwin) + NPROC=$(sysctl -n hw.ncpu) + make -f Bootstrap.mak ${COSMO_FLAG:-osx} $PLATFORM_ARG $CONFIG_ARG -j$NPROC + ;; + FreeBSD|OpenBSD|NetBSD) + NPROC=$(sysctl -n hw.ncpu) + make -f Bootstrap.mak ${COSMO_FLAG:-bsd} $PLATFORM_ARG $CONFIG_ARG -j$NPROC + ;; + CYGWIN*|MINGW32*|MSYS*|MINGW*) + make -f Bootstrap.mak ${COSMO_FLAG:-mingw} $PLATFORM_ARG $CONFIG_ARG -j$NPROC + ;; + *) + echo "Unsupported platform" + exit 1 + ;; +esac diff --git a/binmodules/luasocket/premake5.lua b/binmodules/luasocket/premake5.lua index d761b71bb5..5b2d629a63 100644 --- a/binmodules/luasocket/premake5.lua +++ b/binmodules/luasocket/premake5.lua @@ -32,7 +32,7 @@ project "luasocket" links { 'ws2_32' } characterset "MBCS" - defines { "LUASOCKET_API=__declspec(dllexport)" } + defines { "LUASOCKET_API=__declspec(dllexport)", "_WINSOCK_DEPRECATED_NO_WARNINGS" } filter "system:not windows" removefiles