From: Brendan Hansen Date: Fri, 29 Oct 2021 03:18:56 +0000 (-0500) Subject: added 'onyx run' to windows (using wasmer) X-Git-Url: https://git.brendanfh.com/?a=commitdiff_plain;h=b2b9187f07d92ff6b4d7d321b905ef2038b8fc83;p=onyx.git added 'onyx run' to windows (using wasmer) --- diff --git a/.github/workflows/windows-build.yml b/.github/workflows/windows-build.yml index eb476574..d6aa4d0d 100644 --- a/.github/workflows/windows-build.yml +++ b/.github/workflows/windows-build.yml @@ -30,7 +30,7 @@ jobs: # Runs a single command using the runners shell - name: Build a release build - run: cmd.exe /c 'build.bat 1' + run: cmd.exe /c 'build.bat' - name: Upload executable file uses: actions/upload-artifact@v2 diff --git a/build.bat b/build.bat index cea0527d..2b7dcebd 100644 --- a/build.bat +++ b/build.bat @@ -3,14 +3,24 @@ set SOURCE_FILES=src/onyx.c src/astnodes.c src/builtins.c src/checker.c src/clone.c src/doc.c src/entities.c src/errors.c src/lex.c src/parser.c src/symres.c src/types.c src/utils.c src/wasm_emit.c if "%1" == "1" ( - set FLAGS=/Od /MDd /Z7 + set FLAGS=/Od /MTd /Z7 ) else ( set FLAGS=/O2 /MT /Z7 ) +if "%ONYX_ENABLE_RUN_WITH_WASMER%" == "1" ( + for /f "delims=" %%i in ('wasmer config --includedir') do set WASMER_INCLUDE_DIR=%%i + for /f "delims=" %%i in ('wasmer config --libdir') do set WASMER_LIBRARY_DIR=%%i + + set SOURCE_FILES=%SOURCE_FILES% src/wasm_runtime.c + + set LINK_OPTIONS="%WASMER_LIBRARY_DIR%\wasmer.lib" ws2_32.lib Advapi32.lib userenv.lib bcrypt.lib /NODEFAULTLIB:msvcrt.lib /NODEFAULTLIB:libcmtd.lib /NODEFAULTLIB:msvcrtd.lib + set FLAGS=%FLAGS% /I"%WASMER_INCLUDE_DIR%" /DENABLE_RUN_WITH_WASMER=1 +) + del *.pdb > NUL 2> NUL del *.ilk > NUL 2> NUL -cl.exe %FLAGS% /I include /std:c17 /Tc %SOURCE_FILES% /link /DEBUG /OUT:onyx.exe /incremental:no /opt:ref /subsystem:console +cl.exe %FLAGS% /Iinclude /std:c17 /Tc %SOURCE_FILES% /link %LINK_OPTIONS% /DEBUG /OUT:onyx.exe /incremental:no /opt:ref /subsystem:console del *.obj > NUL 2> NUL