Merge with new build technique
This commit is contained in:
commit
9e235a310c
|
@ -1,19 +0,0 @@
|
||||||
@echo off
|
|
||||||
rem build_all [clean]
|
|
||||||
|
|
||||||
set build_type=build
|
|
||||||
|
|
||||||
IF NOT "%~1" == "" (
|
|
||||||
set build_type=%~1
|
|
||||||
)
|
|
||||||
|
|
||||||
mkdir bin\
|
|
||||||
cd src\Tools\
|
|
||||||
call build_all.bat update
|
|
||||||
call build_all.bat %build_type%
|
|
||||||
|
|
||||||
cd ..\Library\
|
|
||||||
call run_make.bat %build_type% release
|
|
||||||
|
|
||||||
cd ..\..\
|
|
||||||
PAUSE
|
|
|
@ -11,7 +11,12 @@
|
||||||
{
|
{
|
||||||
"label": "build",
|
"label": "build",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
|
"windows": { // v re-export for WSL v re-export for WSL
|
||||||
"command": "wsl make ${input:project}_${input:target} BUILD_PROFILE=${input:build profile} PSX_LICENSE_PATH=$(wslpath ${env:PSX_LICENSE_PATH}) JABY_ENGINE_DIR=$(wslpath ${env:JABY_ENGINE_PATH})",
|
"command": "wsl make ${input:project}_${input:target} BUILD_PROFILE=${input:build profile} PSX_LICENSE_PATH=$(wslpath ${env:PSX_LICENSE_PATH}) JABY_ENGINE_DIR=$(wslpath ${env:JABY_ENGINE_PATH})",
|
||||||
|
},
|
||||||
|
"linux": {
|
||||||
|
"command": "make ${input:project}_${input:target} BUILD_PROFILE=${input:build profile}",
|
||||||
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"kind": "build",
|
"kind": "build",
|
||||||
"isDefault": true
|
"isDefault": true
|
||||||
|
|
|
@ -19,18 +19,14 @@
|
||||||
{
|
{
|
||||||
"label": "make",
|
"label": "make",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"command": "./run_make.bat ${input:target} ${input:build cfg}",
|
"windows": {
|
||||||
|
"command": "wsl make ${input:target} BUILD_PROFILE=${input:build cfg}",
|
||||||
|
},
|
||||||
|
"linux": {
|
||||||
|
"command": "make ${input:target} BUILD_PROFILE=${input:build cfg}",
|
||||||
|
},
|
||||||
"group": "build"
|
"group": "build"
|
||||||
},
|
|
||||||
{
|
|
||||||
"label": "Build Libary and Tools",
|
|
||||||
"type": "shell",
|
|
||||||
"command": "./build_all.bat ${input:target}",
|
|
||||||
"group": "build",
|
|
||||||
"options": {
|
|
||||||
"cwd": "../.."
|
|
||||||
}
|
}
|
||||||
},
|
|
||||||
],
|
],
|
||||||
"inputs": [
|
"inputs": [
|
||||||
{
|
{
|
||||||
|
@ -43,8 +39,8 @@
|
||||||
{
|
{
|
||||||
"id": "target",
|
"id": "target",
|
||||||
"type": "pickString",
|
"type": "pickString",
|
||||||
"options": ["build", "clean", "rebuild"],
|
"options": ["all", "clean", "rebuild"],
|
||||||
"default": "build",
|
"default": "all",
|
||||||
"description": "build target",
|
"description": "build target",
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
@ -1,11 +0,0 @@
|
||||||
@echo off
|
|
||||||
rem run_make.bat build|clean|rebuild debug|release
|
|
||||||
|
|
||||||
IF %1 == build (
|
|
||||||
set make_target=all
|
|
||||||
) else (
|
|
||||||
set make_target=%1
|
|
||||||
)
|
|
||||||
|
|
||||||
@echo make %make_target% BUILD_PROFILE=%2
|
|
||||||
wsl make %make_target% BUILD_PROFILE=%2
|
|
|
@ -1,4 +0,0 @@
|
||||||
set bin_linux_projects=%bin_projects% %bin_linux_projects%
|
|
||||||
set clean_projects_linux=%clean_projects% %clean_projects_linux%
|
|
||||||
set bin_projects=
|
|
||||||
set clean_projects=
|
|
|
@ -1,4 +0,0 @@
|
||||||
set bin_projects=psxcdgen psxcdgen_ex psxcdread psxreadmap wslpath
|
|
||||||
set bin_linux_projects=cpp_out psxcdgen_ex jaby_engine_fconv mkoverlay wslpath
|
|
||||||
set clean_projects=cdtypes
|
|
||||||
set clean_projects_linux=tool_helper
|
|
|
@ -1,4 +0,0 @@
|
||||||
set bin_projects=%bin_projects% %bin_linux_projects%
|
|
||||||
set clean_projects=%clean_projects% %clean_projects_linux%
|
|
||||||
set bin_linux_projects=
|
|
||||||
set clean_projects_linux=
|
|
|
@ -4,22 +4,40 @@
|
||||||
"path": "."
|
"path": "."
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"settings": {},
|
"settings": {
|
||||||
|
},
|
||||||
"tasks": {
|
"tasks": {
|
||||||
"version": "2.0.0",
|
"version": "2.0.0",
|
||||||
"tasks": [
|
"tasks": [
|
||||||
{
|
{
|
||||||
"label": "all",
|
"label": "all",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"command": "./build_all.bat ${input:cargo cmd}",
|
"windows": {
|
||||||
|
"command": "./build_all.bat ${input:cargo cmd}"
|
||||||
|
},
|
||||||
|
"linux": {
|
||||||
|
"command": "./build_all.sh ${input:cargo cmd}"
|
||||||
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"kind": "build"
|
"kind": "build"
|
||||||
|
},
|
||||||
|
"options": {
|
||||||
|
"env": {
|
||||||
|
"win_tools": "psxcdgen_ex psxcdread psxreadmap wslpath",
|
||||||
|
"linux_tools": "cpp_out psxcdgen_ex jaby_engine_fconv mkoverlay",
|
||||||
|
"clean_tools": "cdtypes tool_helper"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"label": "cargo",
|
"label": "cargo",
|
||||||
"type": "shell",
|
"type": "shell",
|
||||||
"command": "./run_cargo ${input:project} ${input:cargo cmd} ${input:build cfg} ${input:cargo target}",
|
"windows": {
|
||||||
|
"command": "./run_cargo.bat ${input:project} ${input:cargo cmd} ${input:build cfg} ${input:cargo target}",
|
||||||
|
},
|
||||||
|
"linux": {
|
||||||
|
"command": "./run_cargo.sh ${input:project} ${input:cargo cmd} ${input:build cfg} ${input:cargo target}",
|
||||||
|
},
|
||||||
"group": {
|
"group": {
|
||||||
"kind": "build",
|
"kind": "build",
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,39 +1,20 @@
|
||||||
@echo off
|
@echo off
|
||||||
setlocal EnableDelayedExpansion
|
setlocal EnableDelayedExpansion
|
||||||
rem build_all [clean] [recommended|windows|linux]
|
rem build_all {build|check|clean}
|
||||||
|
|
||||||
call .config_build_all/recommended.bat
|
if %1 == clean (
|
||||||
IF NOT "%~2" == "" (
|
for %%a in (%clean_tools%) do (
|
||||||
set config_path=.config_build_all/%~2.bat
|
call .\run_cargo %%a %1 release windows
|
||||||
IF exist "!config_path!" (
|
cd %cur_dir%
|
||||||
call !config_path!
|
|
||||||
) ELSE (
|
|
||||||
@echo "Configuration !config_path! not found"
|
|
||||||
exit -1
|
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
set projects=%bin_projects%
|
for %%a in (%win_tools%) do (
|
||||||
set linux_projects=%bin_linux_projects%
|
call .\run_cargo %%a %1 release windows
|
||||||
set build_type=build
|
|
||||||
set cur_dir=%cd%
|
|
||||||
|
|
||||||
IF NOT "%~1" == "" (
|
|
||||||
IF "%~1" == "clean" (
|
|
||||||
set build_type=clean
|
|
||||||
set projects=%projects% %clean_projects%
|
|
||||||
set linux_projects=%linux_projects% %clean_projects_linux%
|
|
||||||
) ELSE (
|
|
||||||
set build_type=%~1
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
for %%a in (%projects%) do (
|
|
||||||
call .\run_cargo %%a %build_type% release windows
|
|
||||||
cd %cur_dir%
|
cd %cur_dir%
|
||||||
)
|
)
|
||||||
|
|
||||||
for %%a in (%linux_projects%) do (
|
for %%a in (%linux_tools%) do (
|
||||||
call .\run_cargo %%a %build_type% release linux
|
call .\run_cargo %%a %1 release linux
|
||||||
cd %cur_dir%
|
cd %cur_dir%
|
||||||
)
|
)
|
|
@ -0,0 +1,12 @@
|
||||||
|
#!/bin/bash
|
||||||
|
# build_all {build|check|clean}
|
||||||
|
|
||||||
|
if [ $1 = clean ]; then
|
||||||
|
all_project="$win_tools $linux_tools $clean_tools"
|
||||||
|
else
|
||||||
|
all_project="$win_tools $linux_tools"
|
||||||
|
fi
|
||||||
|
|
||||||
|
for prj in ${all_project[@]}; do
|
||||||
|
./run_cargo.sh $prj $1 release
|
||||||
|
done
|
|
@ -1,30 +1,25 @@
|
||||||
@echo off
|
@echo off
|
||||||
setlocal EnableDelayedExpansion
|
setlocal EnableDelayedExpansion
|
||||||
rem run_cargo.bat project {build|check|clean|test} {debug|release} [linux|windows]
|
rem run_cargo.bat project {build|check|clean} {debug|release} [linux|windows]
|
||||||
|
|
||||||
set org_dir=%cd%
|
set org_dir=%cd%
|
||||||
set bin_ext=.exe
|
|
||||||
set target=x86_64-pc-windows-msvc
|
set target=x86_64-pc-windows-msvc
|
||||||
set wsl=
|
set wsl=
|
||||||
|
|
||||||
IF %4 == linux (
|
IF %4 == linux (
|
||||||
set bin_ext=
|
wsl --shell-type login ./run_cargo.sh %1 %2 %3
|
||||||
set target=x86_64-unknown-linux-gnu
|
exit /B %ERRORLEVEL%
|
||||||
set wsl=wsl $HOME/.cargo/bin/
|
|
||||||
)
|
)
|
||||||
|
|
||||||
IF defined CARGO_RUN_ARGS set run_args=-- %CARGO_RUN_ARGS%
|
IF defined CARGO_RUN_ARGS set run_args=-- %CARGO_RUN_ARGS%
|
||||||
|
|
||||||
IF %2 == build set run_build=1
|
|
||||||
IF %2 == test set run_build=1
|
|
||||||
|
|
||||||
cd %1
|
cd %1
|
||||||
IF defined run_build (
|
IF %2 == build (
|
||||||
echo cargo build %1 --%3
|
echo cargo build %1 --%3
|
||||||
%wsl%cargo build --%3 --target=%target%
|
%wsl%cargo build --%3 --target=%target%
|
||||||
|
|
||||||
IF %2 == build IF %ERRORLEVEL% == 0 (
|
IF %ERRORLEVEL% == 0 (
|
||||||
xcopy target\%target%\%3\%1%bin_ext% %org_dir%\..\..\bin /y
|
xcopy target\%target%\%3\%1.exe %org_dir%\..\..\bin /y
|
||||||
)
|
)
|
||||||
|
|
||||||
exit /B %ERRORLEVEL%
|
exit /B %ERRORLEVEL%
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
#!/bin/sh
|
||||||
|
# run_cargo.sh project {build|check|clean|test} {debug|release}
|
||||||
|
|
||||||
|
target=x86_64-unknown-linux-gnu
|
||||||
|
|
||||||
|
if [ -n "${CARGO_RUN_ARGS}" ]; then
|
||||||
|
run_args=-- ${CARGO_RUN_ARGS}
|
||||||
|
fi
|
||||||
|
|
||||||
|
cd $1
|
||||||
|
if [ $2 = build ]; then
|
||||||
|
echo "cargo build $1 --$3"
|
||||||
|
$HOME/.cargo/bin/cargo build --$3 --target=$target
|
||||||
|
|
||||||
|
if [ $? = 0 ]; then
|
||||||
|
cp target/$target/$3/$1 ../../../bin
|
||||||
|
echo "1 File(s) copied"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit $?
|
||||||
|
elif [ $2 = run ]; then
|
||||||
|
echo "cargo run $1 --$3"
|
||||||
|
$HOME/.cargo/bin/cargo run --$3 --target=$target
|
||||||
|
|
||||||
|
exit $?
|
||||||
|
elif [ $2 = check ]; then
|
||||||
|
echo "cargo check $1 --$3"
|
||||||
|
$HOME/.cargo/bin/cargo check --$3 --target=$target $run_args
|
||||||
|
|
||||||
|
exit $?
|
||||||
|
elif [ $2 = clean ]; then
|
||||||
|
echo "cargo clean $1"
|
||||||
|
$HOME/.cargo/bin/cargo clean
|
||||||
|
|
||||||
|
exit $?
|
||||||
|
else
|
||||||
|
echo "Unkown cargo command $2 for project $1"
|
||||||
|
fi
|
Loading…
Reference in New Issue