mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
make.bat: bootstrap TCC by default and fix miscellaneous bugs (#7027)
good work
This commit is contained in:
parent
aae5812337
commit
9487578c0c
71
make.bat
71
make.bat
@ -43,7 +43,7 @@ if !shift_counter! LSS 1 (
|
|||||||
)
|
)
|
||||||
|
|
||||||
REM Compiler option
|
REM Compiler option
|
||||||
for %%g in (-gcc -msvc -tcc -fresh-tcc -clang) do (
|
for %%g in (-gcc -msvc -tcc -clang) do (
|
||||||
if "%~1" == "%%g" set compiler=%~1& set compiler=!compiler:~1!& shift& set /a shift_counter+=1& goto :verifyopt
|
if "%~1" == "%%g" set compiler=%~1& set compiler=!compiler:~1!& shift& set /a shift_counter+=1& goto :verifyopt
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -93,6 +93,7 @@ goto :!target!
|
|||||||
|
|
||||||
:cleanall
|
:cleanall
|
||||||
call :clean
|
call :clean
|
||||||
|
if %ERRORLEVEL% NEQ 0 exit /b %ERRORLEVEL%
|
||||||
echo.
|
echo.
|
||||||
echo Cleanup vc
|
echo Cleanup vc
|
||||||
echo ^> Purge TCC binaries
|
echo ^> Purge TCC binaries
|
||||||
@ -119,6 +120,8 @@ if %ERRORLEVEL% NEQ 0 echo Invalid subcommand: !subcmd!
|
|||||||
exit /b %ERRORLEVEL%
|
exit /b %ERRORLEVEL%
|
||||||
|
|
||||||
:build
|
:build
|
||||||
|
call :download_tcc
|
||||||
|
if %ERRORLEVEL% NEQ 0 goto :error
|
||||||
del "!log_file!">NUL 2>&1
|
del "!log_file!">NUL 2>&1
|
||||||
if !flag_local! NEQ 1 (
|
if !flag_local! NEQ 1 (
|
||||||
pushd "%vc_dir%" 2>NUL && (
|
pushd "%vc_dir%" 2>NUL && (
|
||||||
@ -127,12 +130,12 @@ if !flag_local! NEQ 1 (
|
|||||||
call :buildcmd "cd "%vc_dir%"" " "
|
call :buildcmd "cd "%vc_dir%"" " "
|
||||||
call :buildcmd "git pull --quiet" " "
|
call :buildcmd "git pull --quiet" " "
|
||||||
call :buildcmd "cd .." " "
|
call :buildcmd "cd .." " "
|
||||||
|
popd
|
||||||
) || (
|
) || (
|
||||||
echo Cloning vc...
|
echo Cloning vc...
|
||||||
echo ^> Cloning from remote !vc_url!
|
echo ^> Cloning from remote !vc_url!
|
||||||
call :buildcmd "git clone --depth 1 --quiet "%vc_url%"" " "
|
call :buildcmd "git clone --depth 1 --quiet "%vc_url%"" " "
|
||||||
)
|
)
|
||||||
popd
|
|
||||||
echo.
|
echo.
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -151,7 +154,7 @@ echo ^> Attempting to build v.c with Clang
|
|||||||
call :buildcmd "clang -std=c99 -municode -w -o v.exe .\vc\v_win.c" " "
|
call :buildcmd "clang -std=c99 -municode -w -o v.exe .\vc\v_win.c" " "
|
||||||
if %ERRORLEVEL% NEQ 0 (
|
if %ERRORLEVEL% NEQ 0 (
|
||||||
REM In most cases, compile errors happen because the version of Clang installed is too old
|
REM In most cases, compile errors happen because the version of Clang installed is too old
|
||||||
call :buildcmd "clang --version" " "
|
call :buildcmd "clang --version" " " 1
|
||||||
goto :compile_error
|
goto :compile_error
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -172,7 +175,7 @@ echo ^> Attempting to build v.c with GCC
|
|||||||
call :buildcmd "gcc -std=c99 -municode -w -o v.exe .\vc\v_win.c" " "
|
call :buildcmd "gcc -std=c99 -municode -w -o v.exe .\vc\v_win.c" " "
|
||||||
if %ERRORLEVEL% NEQ 0 (
|
if %ERRORLEVEL% NEQ 0 (
|
||||||
REM In most cases, compile errors happen because the version of GCC installed is too old
|
REM In most cases, compile errors happen because the version of GCC installed is too old
|
||||||
call :buildcmd "gcc --version" " "
|
call :buildcmd "gcc --version" " " 1
|
||||||
goto :compile_error
|
goto :compile_error
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -210,7 +213,11 @@ set ObjFile=.v.c.obj
|
|||||||
|
|
||||||
echo ^> Attempting to build v.c with MSVC
|
echo ^> Attempting to build v.c with MSVC
|
||||||
call :buildcmd "cl.exe /volatile:ms /Fo%ObjFile% /O2 /MD /D_VBOOTSTRAP vc\v_win.c user32.lib kernel32.lib advapi32.lib shell32.lib /link /nologo /out:v.exe /incremental:no" " "
|
call :buildcmd "cl.exe /volatile:ms /Fo%ObjFile% /O2 /MD /D_VBOOTSTRAP vc\v_win.c user32.lib kernel32.lib advapi32.lib shell32.lib /link /nologo /out:v.exe /incremental:no" " "
|
||||||
if %ERRORLEVEL% NEQ 0 goto :compile_error
|
if %ERRORLEVEL% NEQ 0 (
|
||||||
|
REM In some cases, compile errors happen because of the MSVC compiler version
|
||||||
|
call :buildcmd "cl.exe 1>NUL" " " 1
|
||||||
|
goto :compile_error
|
||||||
|
)
|
||||||
|
|
||||||
echo ^> Compiling with .\v.exe self
|
echo ^> Compiling with .\v.exe self
|
||||||
call :buildcmd "v.exe -cc msvc self" " "
|
call :buildcmd "v.exe -cc msvc self" " "
|
||||||
@ -218,36 +225,7 @@ del %ObjFile%>>"!log_file!" 2>>&1
|
|||||||
if %ERRORLEVEL% NEQ 0 goto :compile_error
|
if %ERRORLEVEL% NEQ 0 goto :compile_error
|
||||||
goto :success
|
goto :success
|
||||||
|
|
||||||
:fresh-tcc_strap
|
|
||||||
echo ^> Clean TCC directory
|
|
||||||
call :buildcmd "rmdir /s /q "%tcc_dir%"" " "
|
|
||||||
call :tcc_strap
|
|
||||||
exit /b %ERRORLEVEL%
|
|
||||||
|
|
||||||
:tcc_strap
|
:tcc_strap
|
||||||
where /q tcc
|
|
||||||
if %ERRORLEVEL% NEQ 0 (
|
|
||||||
if [!compiler!] == [] set /a invalid_cc=1
|
|
||||||
if not exist %tcc_dir% (
|
|
||||||
echo ^> TCC not found
|
|
||||||
echo ^> Downloading TCC from %tcc_url%
|
|
||||||
call :buildcmd "git clone --depth 1 --quiet --single-branch --branch "!tcc_branch!" "!tcc_url!" "%tcc_dir%"" " "
|
|
||||||
)
|
|
||||||
pushd %tcc_dir% || (
|
|
||||||
echo ^> TCC not found, even after cloning
|
|
||||||
goto :error
|
|
||||||
)
|
|
||||||
popd
|
|
||||||
set "tcc_exe=%tcc_dir%\tcc.exe"
|
|
||||||
) else (
|
|
||||||
for /f "usebackq delims=" %%i in (`where tcc`) do set "tcc_exe=%%i"
|
|
||||||
)
|
|
||||||
|
|
||||||
echo ^> Updating prebuilt TCC...
|
|
||||||
pushd "%tcc_dir%\"
|
|
||||||
call :buildcmd "git pull -q" " "
|
|
||||||
popd
|
|
||||||
|
|
||||||
echo ^> Attempting to build v.c with TCC
|
echo ^> Attempting to build v.c with TCC
|
||||||
call :buildcmd ""!tcc_exe!" -std=c99 -municode -lws2_32 -lshell32 -ladvapi32 -bt10 -w -o v.exe vc\v_win.c" " "
|
call :buildcmd ""!tcc_exe!" -std=c99 -municode -lws2_32 -lshell32 -ladvapi32 -bt10 -w -o v.exe vc\v_win.c" " "
|
||||||
if %ERRORLEVEL% NEQ 0 goto :compile_error
|
if %ERRORLEVEL% NEQ 0 goto :compile_error
|
||||||
@ -257,6 +235,28 @@ call :buildcmd "v.exe -cc "!tcc_exe!" self" " "
|
|||||||
if %ERRORLEVEL% NEQ 0 goto :compile_error
|
if %ERRORLEVEL% NEQ 0 goto :compile_error
|
||||||
goto :success
|
goto :success
|
||||||
|
|
||||||
|
:download_tcc
|
||||||
|
if [!compiler!] == [] set /a invalid_cc=1
|
||||||
|
pushd %tcc_dir% 2>NUL && (
|
||||||
|
echo Updating TCC
|
||||||
|
echo ^> Syncing TCC from !tcc_url!
|
||||||
|
call :buildcmd "git pull --quiet" " "
|
||||||
|
popd
|
||||||
|
) || (
|
||||||
|
echo Bootstraping TCC...
|
||||||
|
echo ^> TCC not found
|
||||||
|
echo ^> Downloading TCC from !tcc_url!
|
||||||
|
call :buildcmd "git clone --depth 1 --quiet --single-branch --branch "!tcc_branch!" "!tcc_url!" "%tcc_dir%"" " "
|
||||||
|
)
|
||||||
|
for /f "usebackq delims=" %%i in (`dir %tcc_dir% /b /a /s tcc.exe`) do (
|
||||||
|
set "attrib=%%~ai"
|
||||||
|
set "dattrib=%attrib:~0,1%"
|
||||||
|
if /I not "%dattrib%" == "d" set "tcc_exe=%%i"
|
||||||
|
)
|
||||||
|
if [!tcc_exe!] == [] echo ^> TCC not found, even after cloning& goto :error
|
||||||
|
echo.
|
||||||
|
exit /b 0
|
||||||
|
|
||||||
:compile_error
|
:compile_error
|
||||||
echo.
|
echo.
|
||||||
type "!log_file!">NUL 2>&1
|
type "!log_file!">NUL 2>&1
|
||||||
@ -293,6 +293,7 @@ if !flag_verbose! EQU 1 (
|
|||||||
echo [Debug] %~1>>"!log_file!"
|
echo [Debug] %~1>>"!log_file!"
|
||||||
echo %~2 %~1
|
echo %~2 %~1
|
||||||
)
|
)
|
||||||
|
if not [%~3] == [] echo.& %~1
|
||||||
%~1>>"!log_file!" 2>>&1
|
%~1>>"!log_file!" 2>>&1
|
||||||
exit /b %ERRORLEVEL%
|
exit /b %ERRORLEVEL%
|
||||||
|
|
||||||
@ -301,7 +302,7 @@ echo Usage:
|
|||||||
echo make.bat [target] [compiler] [options]
|
echo make.bat [target] [compiler] [options]
|
||||||
echo.
|
echo.
|
||||||
echo Compiler:
|
echo Compiler:
|
||||||
echo -msvc ^| -gcc ^| -[fresh-]tcc ^| -clang Set C compiler
|
echo -msvc ^| -gcc ^| -tcc ^| -clang Set C compiler
|
||||||
echo.
|
echo.
|
||||||
echo Target:
|
echo Target:
|
||||||
echo build[default] Compiles V using the given C compiler
|
echo build[default] Compiles V using the given C compiler
|
||||||
|
Loading…
Reference in New Issue
Block a user