From e37dd256e5bca4caf819d18c73cd2d11e06683df Mon Sep 17 00:00:00 2001 From: 杨宇千 Date: Wed, 10 Jul 2019 00:33:07 +0800 Subject: ... --- tools/win_build.py | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) (limited to 'tools') diff --git a/tools/win_build.py b/tools/win_build.py index 6850d82a..c3f1ec57 100644 --- a/tools/win_build.py +++ b/tools/win_build.py @@ -5,32 +5,35 @@ import subprocess import sys parser = argparse.ArgumentParser() +parser.add_argument('command', choices=[ + 'configure', 'build'], nargs='?', default='build', help='specify command to execute') parser.add_argument('-a', '--arch', choices=['x86', 'x64'], default='x64', help='specify target cpu architecture') parser.add_argument('-c', '--config', choices=['Debug', 'Release'], - required=True, help='specify build configuration') + default='Debug', help='specify build configuration') args = parser.parse_args() project_root = os.path.abspath(os.path.join(os.path.dirname(__file__), '..')) -def build_cru_ui(): - os.chdir(project_root) - - os.environ['PreferredToolArchitecture'] = 'x64' # use vs x64 toolchain - +def configure(): generater_vs_arch_map = { 'x86': 'Win32', 'x64': 'x64' } + subprocess.check_call('cmake -S . -B build -G "Visual Studio 16 2019" -A {arch} -T host=x64 -DCMAKE_EXPORT_COMPILE_COMMANDS=ON' + .format(arch=generater_vs_arch_map[args.arch]), + stdout=sys.stdout, stderr=sys.stderr) - subprocess.check_call('cmake -S . -B build -G "Visual Studio 16 2019" -A {arch}' - .format(arch=generater_vs_arch_map[args.arch]), - stdout=sys.stdout, stderr=sys.stderr) +def build(): subprocess.check_call('cmake --build build --target ALL_BUILD --config {config}'.format(config=args.config), - stdout=sys.stdout, stderr=sys.stderr) + stdout=sys.stdout, stderr=sys.stderr) + +os.chdir(project_root) +configure() -build_cru_ui() +if args.command == 'build': + build() -- cgit v1.2.3