mirror of
https://github.com/Ed94/gencpp.git
synced 2024-11-10 02:54:53 -08:00
New build script works for clang and msvc!
Need to update singleheader and test to use it.
This commit is contained in:
parent
8985f0a4d9
commit
11679ba8b4
@ -112,16 +112,11 @@
|
|||||||
<None Include="test\Readme.md" />
|
<None Include="test\Readme.md" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<ClInclude Include="project\auxillary\builder.hpp" />
|
||||||
|
<ClInclude Include="project\auxillary\editor.hpp" />
|
||||||
|
<ClInclude Include="project\auxillary\scanner.hpp" />
|
||||||
<ClInclude Include="project\components\ast.hpp" />
|
<ClInclude Include="project\components\ast.hpp" />
|
||||||
<ClInclude Include="project\components\ast_types.hpp" />
|
<ClInclude Include="project\components\ast_types.hpp" />
|
||||||
<ClInclude Include="project\components\gen.data_structures.hpp" />
|
|
||||||
<ClInclude Include="project\components\gen.ecode.hpp" />
|
|
||||||
<ClInclude Include="project\components\gen.eoperator.hpp" />
|
|
||||||
<ClInclude Include="project\components\gen.especifier.hpp" />
|
|
||||||
<ClInclude Include="project\components\gen.header_end.hpp" />
|
|
||||||
<ClInclude Include="project\components\gen.header_start.hpp" />
|
|
||||||
<ClInclude Include="project\components\gen.interface.hpp" />
|
|
||||||
<ClInclude Include="project\components\gen.types.hpp" />
|
|
||||||
<ClInclude Include="project\components\header_end.hpp" />
|
<ClInclude Include="project\components\header_end.hpp" />
|
||||||
<ClInclude Include="project\components\header_start.hpp" />
|
<ClInclude Include="project\components\header_start.hpp" />
|
||||||
<ClInclude Include="project\components\inlines.hpp" />
|
<ClInclude Include="project\components\inlines.hpp" />
|
||||||
@ -135,19 +130,6 @@
|
|||||||
<ClInclude Include="project\dependencies\containers.hpp" />
|
<ClInclude Include="project\dependencies\containers.hpp" />
|
||||||
<ClInclude Include="project\dependencies\debug.hpp" />
|
<ClInclude Include="project\dependencies\debug.hpp" />
|
||||||
<ClInclude Include="project\dependencies\filesystem.hpp" />
|
<ClInclude Include="project\dependencies\filesystem.hpp" />
|
||||||
<ClInclude Include="project\dependencies\gen.basic_types.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.containers.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.debug.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.file_handling.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.hashing.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.header_start.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.macros.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.memory.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.parsing.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.printing.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.string.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.string_ops.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\gen.timing.hpp" />
|
|
||||||
<ClInclude Include="project\dependencies\hashing.hpp" />
|
<ClInclude Include="project\dependencies\hashing.hpp" />
|
||||||
<ClInclude Include="project\dependencies\header_start.hpp" />
|
<ClInclude Include="project\dependencies\header_start.hpp" />
|
||||||
<ClInclude Include="project\dependencies\macros.hpp" />
|
<ClInclude Include="project\dependencies\macros.hpp" />
|
||||||
@ -157,19 +139,13 @@
|
|||||||
<ClInclude Include="project\dependencies\strings.hpp" />
|
<ClInclude Include="project\dependencies\strings.hpp" />
|
||||||
<ClInclude Include="project\dependencies\string_ops.hpp" />
|
<ClInclude Include="project\dependencies\string_ops.hpp" />
|
||||||
<ClInclude Include="project\dependencies\timing.hpp" />
|
<ClInclude Include="project\dependencies\timing.hpp" />
|
||||||
<ClInclude Include="project\filesystem\gen.builder.hpp" />
|
|
||||||
<ClInclude Include="project\filesystem\gen.editor.hpp" />
|
|
||||||
<ClInclude Include="project\filesystem\gen.scanner.hpp" />
|
|
||||||
<ClInclude Include="project\gen.dep.hpp" />
|
<ClInclude Include="project\gen.dep.hpp" />
|
||||||
<ClInclude Include="project\gen.hpp" />
|
<ClInclude Include="project\gen.hpp" />
|
||||||
<ClInclude Include="project\helpers\gen.pop_ignores.inline.hpp" />
|
|
||||||
<ClInclude Include="project\helpers\gen.push_ignores.inline.hpp" />
|
|
||||||
<ClInclude Include="project\helpers\gen.undef.macros.hpp" />
|
|
||||||
<ClInclude Include="project\helpers\helper.hpp" />
|
<ClInclude Include="project\helpers\helper.hpp" />
|
||||||
<ClInclude Include="project\helpers\pop_ignores.inline.hpp" />
|
<ClInclude Include="project\helpers\pop_ignores.inline.hpp" />
|
||||||
<ClInclude Include="project\helpers\push_ignores.inline.hpp" />
|
<ClInclude Include="project\helpers\push_ignores.inline.hpp" />
|
||||||
<ClInclude Include="project\helpers\undef.macros.hpp" />
|
<ClInclude Include="project\helpers\undef.macros.hpp" />
|
||||||
<ClInclude Include="singleheader\components\gen.header_start.hpp" />
|
<ClInclude Include="singleheader\components\header_start.hpp" />
|
||||||
<ClInclude Include="test\DummyInclude.hpp" />
|
<ClInclude Include="test\DummyInclude.hpp" />
|
||||||
<ClInclude Include="test\Parsed\Buffer.Parsed.hpp" />
|
<ClInclude Include="test\Parsed\Buffer.Parsed.hpp" />
|
||||||
<ClInclude Include="test\Parsed\HashTable.Parsed.hpp" />
|
<ClInclude Include="test\Parsed\HashTable.Parsed.hpp" />
|
||||||
@ -186,18 +162,11 @@
|
|||||||
<ClInclude Include="test\Parsed\Sanity.Parsed.hpp" />
|
<ClInclude Include="test\Parsed\Sanity.Parsed.hpp" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
|
<ClCompile Include="project\auxillary\builder.cpp" />
|
||||||
|
<ClCompile Include="project\auxillary\scanner.cpp" />
|
||||||
<ClCompile Include="project\bootstrap.cpp" />
|
<ClCompile Include="project\bootstrap.cpp" />
|
||||||
<ClCompile Include="project\components\ast.cpp" />
|
<ClCompile Include="project\components\ast.cpp" />
|
||||||
<ClCompile Include="project\components\ast_case_macros.cpp" />
|
<ClCompile Include="project\components\ast_case_macros.cpp" />
|
||||||
<ClCompile Include="project\components\gen.ast.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.ast_case_macros.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.data.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.etoktype.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.impl_start.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.interface.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.interface.parsing.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.interface.upfront.cpp" />
|
|
||||||
<ClCompile Include="project\components\gen.untyped.cpp" />
|
|
||||||
<ClCompile Include="project\components\interface.cpp" />
|
<ClCompile Include="project\components\interface.cpp" />
|
||||||
<ClCompile Include="project\components\interface.parsing.cpp" />
|
<ClCompile Include="project\components\interface.parsing.cpp" />
|
||||||
<ClCompile Include="project\components\interface.upfront.cpp" />
|
<ClCompile Include="project\components\interface.upfront.cpp" />
|
||||||
@ -207,16 +176,6 @@
|
|||||||
<ClCompile Include="project\components\untyped.cpp" />
|
<ClCompile Include="project\components\untyped.cpp" />
|
||||||
<ClCompile Include="project\dependencies\debug.cpp" />
|
<ClCompile Include="project\dependencies\debug.cpp" />
|
||||||
<ClCompile Include="project\dependencies\filesystem.cpp" />
|
<ClCompile Include="project\dependencies\filesystem.cpp" />
|
||||||
<ClCompile Include="project\dependencies\gen.debug.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.file_handling.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.hashing.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.impl_start.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.memory.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.parsing.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.printing.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.string.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.string_ops.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\gen.timing.cpp" />
|
|
||||||
<ClCompile Include="project\dependencies\hashing.cpp" />
|
<ClCompile Include="project\dependencies\hashing.cpp" />
|
||||||
<ClCompile Include="project\dependencies\memory.cpp" />
|
<ClCompile Include="project\dependencies\memory.cpp" />
|
||||||
<ClCompile Include="project\dependencies\parsing.cpp" />
|
<ClCompile Include="project\dependencies\parsing.cpp" />
|
||||||
@ -225,10 +184,9 @@
|
|||||||
<ClCompile Include="project\dependencies\strings.cpp" />
|
<ClCompile Include="project\dependencies\strings.cpp" />
|
||||||
<ClCompile Include="project\dependencies\string_ops.cpp" />
|
<ClCompile Include="project\dependencies\string_ops.cpp" />
|
||||||
<ClCompile Include="project\dependencies\timing.cpp" />
|
<ClCompile Include="project\dependencies\timing.cpp" />
|
||||||
<ClCompile Include="project\gen.bootstrap.cpp" />
|
|
||||||
<ClCompile Include="project\gen.cpp" />
|
<ClCompile Include="project\gen.cpp" />
|
||||||
<ClCompile Include="project\gen.dep.cpp" />
|
<ClCompile Include="project\gen.dep.cpp" />
|
||||||
<ClCompile Include="singleheader\gen.singleheader.cpp" />
|
<ClCompile Include="singleheader\singleheader.cpp" />
|
||||||
<ClCompile Include="test\parsing.cpp" />
|
<ClCompile Include="test\parsing.cpp" />
|
||||||
<ClCompile Include="test\sanity.cpp" />
|
<ClCompile Include="test\sanity.cpp" />
|
||||||
<ClCompile Include="test\SOA.cpp" />
|
<ClCompile Include="test\SOA.cpp" />
|
||||||
@ -242,21 +200,19 @@
|
|||||||
<Natvis Include="scripts\gencpp.natvis" />
|
<Natvis Include="scripts\gencpp.natvis" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Content Include="project\components\AttributeTokens.csv" />
|
<Content Include="project\enums\AttributeTokens.csv" />
|
||||||
<Content Include="project\components\ECode.csv" />
|
<Content Include="project\enums\ECode.csv" />
|
||||||
<Content Include="project\components\EOperator.csv" />
|
<Content Include="project\enums\EOperator.csv" />
|
||||||
<Content Include="project\components\ESpecifier.csv" />
|
<Content Include="project\enums\ESpecifier.csv" />
|
||||||
<Content Include="project\components\ETokType.csv" />
|
<Content Include="project\enums\ETokType.csv" />
|
||||||
<Content Include="project\meson.build" />
|
|
||||||
<Content Include="scripts\.clang-format" />
|
<Content Include="scripts\.clang-format" />
|
||||||
<Content Include="scripts\bootstrap.ci.ps1" />
|
<Content Include="scripts\bootstrap.ci.ps1" />
|
||||||
<Content Include="scripts\bootstrap.ps1" />
|
<Content Include="scripts\bootstrap.ps1" />
|
||||||
<Content Include="scripts\msvc\build_msvc.ps1" />
|
<Content Include="scripts\helpers\devshell.ps1" />
|
||||||
<Content Include="scripts\msvc\devshell.ps1" />
|
<Content Include="scripts\helpers\target_arch.psm1" />
|
||||||
<Content Include="scripts\refactor.ps1" />
|
<Content Include="scripts\refactor.ps1" />
|
||||||
<Content Include="scripts\singleheader.ci.ps1" />
|
<Content Include="scripts\singleheader.ci.ps1" />
|
||||||
<Content Include="scripts\singleheader.ps1" />
|
<Content Include="scripts\singleheader.ps1" />
|
||||||
<Content Include="singleheader\meson.build" />
|
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
|
||||||
<ImportGroup Label="ExtensionTargets">
|
<ImportGroup Label="ExtensionTargets">
|
||||||
|
@ -214,7 +214,7 @@ struct AST
|
|||||||
- sizeof(ModuleFlag)
|
- sizeof(ModuleFlag)
|
||||||
- sizeof(u32)
|
- sizeof(u32)
|
||||||
)
|
)
|
||||||
/ sizeof(SpecifierT) - 1; // -1 for 4 extra bytes
|
/ sizeof(SpecifierT); // -1 for 4 extra bytes
|
||||||
|
|
||||||
union {
|
union {
|
||||||
struct
|
struct
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
# That or just rewrite it in an sh script and call it a day.
|
# That or just rewrite it in an sh script and call it a day.
|
||||||
|
|
||||||
Import-Module ./helpers/target_arch.psm1
|
Import-Module ./helpers/target_arch.psm1
|
||||||
|
$devshell = Join-Path $PSScriptRoot 'helpers/devshell.ps1'
|
||||||
|
|
||||||
cls
|
cls
|
||||||
|
|
||||||
@ -31,16 +32,18 @@ if ( $args ) { $args | ForEach-Object {
|
|||||||
#region Building
|
#region Building
|
||||||
write-host "Building gencpp with $compiler"
|
write-host "Building gencpp with $compiler"
|
||||||
|
|
||||||
if ( $IsWindows ) {
|
if ($IsWindows) {
|
||||||
Invoke-Expression "& $(join-path $PSScriptRoot 'helpers/devshell.ps1')"
|
# This library was really designed to only run on 64-bit systems.
|
||||||
|
# (Its a development tool after all)
|
||||||
|
& $devshell -arch amd64
|
||||||
}
|
}
|
||||||
|
|
||||||
$path_root = git rev-parse --show-toplevel
|
$path_root = git rev-parse --show-toplevel
|
||||||
$path_build = Join-Path $path_root build
|
$path_build = Join-Path $path_root build
|
||||||
$path_project = Join-Path $path_root project
|
$path_project = Join-Path $path_root project
|
||||||
$path_scripts = Join-Path $path_root scripts
|
$path_scripts = Join-Path $path_root scripts
|
||||||
$path_singleheader = Join-Path $path_root singleheader
|
$path_singleheader = Join-Path $path_root singleheader
|
||||||
$path_test = Join-Path $path_root test
|
$path_test = Join-Path $path_root test
|
||||||
|
|
||||||
write-host "Build Type: $(if ($release) {"Release"} else {"Debug"} )"
|
write-host "Build Type: $(if ($release) {"Release"} else {"Debug"} )"
|
||||||
|
|
||||||
@ -62,15 +65,14 @@ function run-compiler
|
|||||||
}
|
}
|
||||||
|
|
||||||
$time_taken = Measure-Command {
|
$time_taken = Measure-Command {
|
||||||
& $compiler $compiler_args
|
& $compiler $compiler_args 2>&1 | ForEach-Object {
|
||||||
| ForEach-Object {
|
$color = 'White'
|
||||||
$color = 'White'
|
switch ($_){
|
||||||
switch ($_){
|
{ $_ -match "error" } { $color = 'Red' ; break }
|
||||||
{ $_ -match "error" } { $color = 'Red' ; break }
|
{ $_ -match "warning" } { $color = 'Yellow'; break }
|
||||||
{ $_ -match "warning" } { $color = 'Yellow'; break }
|
|
||||||
}
|
|
||||||
write-host `t $_ -ForegroundColor $color
|
|
||||||
}
|
}
|
||||||
|
write-host `t $_ -ForegroundColor $color
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( Test-Path($unit) ) {
|
if ( Test-Path($unit) ) {
|
||||||
@ -92,15 +94,14 @@ function run-linker
|
|||||||
}
|
}
|
||||||
|
|
||||||
$time_taken = Measure-Command {
|
$time_taken = Measure-Command {
|
||||||
& $linker $linker_args
|
& $linker $linker_args 2>&1 | ForEach-Object {
|
||||||
| ForEach-Object {
|
$color = 'White'
|
||||||
$color = 'White'
|
switch ($_){
|
||||||
switch ($_){
|
{ $_ -match "error" } { $color = 'Red' ; break }
|
||||||
{ $_ -match "error" } { $color = 'Red' ; break }
|
{ $_ -match "warning" } { $color = 'Yellow'; break }
|
||||||
{ $_ -match "warning" } { $color = 'Yellow'; break }
|
|
||||||
}
|
|
||||||
write-host `t $_ -ForegroundColor $color
|
|
||||||
}
|
}
|
||||||
|
write-host `t $_ -ForegroundColor $color
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( Test-Path($binary) ) {
|
if ( Test-Path($binary) ) {
|
||||||
@ -113,9 +114,10 @@ function run-linker
|
|||||||
|
|
||||||
if ( $compiler -match "clang" )
|
if ( $compiler -match "clang" )
|
||||||
{
|
{
|
||||||
$target_arch = Get-TargetArchClang
|
# https://clang.llvm.org/docs/ClangCommandLineReference.html
|
||||||
|
|
||||||
$flag_compile = '-c'
|
$flag_compile = '-c'
|
||||||
|
$flag_color_diagnostics = '-fcolor-diagnostics'
|
||||||
|
$flag_no_color_diagnostics = '-fno-color-diagnostics'
|
||||||
$flag_debug = '-g'
|
$flag_debug = '-g'
|
||||||
$flag_debug_codeview = '-gcodeview'
|
$flag_debug_codeview = '-gcodeview'
|
||||||
$flag_define = '-D'
|
$flag_define = '-D'
|
||||||
@ -128,63 +130,95 @@ if ( $compiler -match "clang" )
|
|||||||
$flag_link_win_machine_64 = '/MACHINE:X64'
|
$flag_link_win_machine_64 = '/MACHINE:X64'
|
||||||
$flag_link_win_debug = '/DEBUG'
|
$flag_link_win_debug = '/DEBUG'
|
||||||
$flag_link_win_pdb = '/PDB:'
|
$flag_link_win_pdb = '/PDB:'
|
||||||
|
$flag_link_win_path_output = '/OUT:'
|
||||||
$flag_no_optimization = '-O0'
|
$flag_no_optimization = '-O0'
|
||||||
$flag_path_output = '-o'
|
$flag_path_output = '-o'
|
||||||
$flag_preprocess_non_intergrated = '-no-integrated-cpp'
|
$flag_preprocess_non_intergrated = '-no-integrated-cpp'
|
||||||
$flag_profiling_debug = '-fdebug-info-for-profiling'
|
$flag_profiling_debug = '-fdebug-info-for-profiling'
|
||||||
$flag_target_arch = '-target'
|
$flag_target_arch = '-target'
|
||||||
$flag_x_linker = '-Xlinker'
|
|
||||||
$flag_wall = '-Wall'
|
$flag_wall = '-Wall'
|
||||||
|
$flag_warning = '-W'
|
||||||
|
$flag_warning_as_error = '-Werror'
|
||||||
$flag_win_nologo = '/nologo'
|
$flag_win_nologo = '/nologo'
|
||||||
|
|
||||||
# $library_paths = @(
|
$ignore_warning_ms_include = 'no-microsoft-include'
|
||||||
# 'C:\Windows\System32'
|
|
||||||
|
|
||||||
# )
|
$target_arch = Get-TargetArchClang
|
||||||
|
|
||||||
|
$env:CLANG_FORCE_COLOR_DIAGNOSTICS = 1
|
||||||
|
|
||||||
if ( $bootstrap )
|
if ( $bootstrap )
|
||||||
{
|
{
|
||||||
$path_build = join-path $path_project build
|
$path_build = join-path $path_project build
|
||||||
$path_gen = join-path $path_project gen
|
$path_gen = join-path $path_project gen
|
||||||
|
|
||||||
|
if ( -not(Test-Path($path_build) )) {
|
||||||
|
New-Item -ItemType Directory -Path $path_build
|
||||||
|
}
|
||||||
|
if ( -not(Test-Path($path_gen) )) {
|
||||||
|
New-Item -ItemType Directory -Path $path_gen
|
||||||
|
}
|
||||||
|
|
||||||
$include = $path_project
|
$include = $path_project
|
||||||
$unit = join-path $path_project "bootstrap.cpp"
|
$unit = join-path $path_project "bootstrap.cpp"
|
||||||
$object = join-path $path_build "bootstrap.o"
|
$object = join-path $path_build "bootstrap.obj"
|
||||||
$executable = join-path $path_build "bootstrap.exe"
|
$executable = join-path $path_build "bootstrap.exe"
|
||||||
|
|
||||||
|
$warning_ignores = @(
|
||||||
|
$ignore_warning_ms_include
|
||||||
|
)
|
||||||
|
|
||||||
$compiler_args = @(
|
$compiler_args = @(
|
||||||
|
$flag_no_color_diagnostics,
|
||||||
$flag_target_arch, $target_arch,
|
$flag_target_arch, $target_arch,
|
||||||
$flag_wall,
|
$flag_wall,
|
||||||
$flag_preprocess_non_intergrated,
|
$flag_preprocess_non_intergrated,
|
||||||
$( $flag_define + 'GEN_TIME' ),
|
( $flag_define + 'GEN_TIME' ),
|
||||||
$flag_path_output, $executable,
|
( $flag_path_output + $object ),
|
||||||
$( $flag_include + $include )
|
( $flag_include + $include )
|
||||||
)
|
)
|
||||||
|
|
||||||
|
$warning_ignores | ForEach-Object {
|
||||||
|
$compiler_args += $flag_warning + $_
|
||||||
|
}
|
||||||
|
|
||||||
if ( $release -eq $false ) {
|
if ( $release -eq $false ) {
|
||||||
$compiler_args += $( $flag_define + 'Build_Debug' )
|
$compiler_args += ( $flag_define + 'Build_Debug' )
|
||||||
$compiler_args += $flag_debug, $flag_debug_codeview, $flag_profiling_debug
|
$compiler_args += $flag_debug, $flag_debug_codeview, $flag_profiling_debug
|
||||||
}
|
}
|
||||||
|
|
||||||
$compiler_args += $flag_compile, $unit
|
$compiler_args += $flag_compile, $unit
|
||||||
run-compiler clang++ $executable $path_build $path_gen $compiler_args
|
run-compiler clang++ $unit $compiler_args
|
||||||
|
|
||||||
$linker_args = @(
|
$linker_args = @(
|
||||||
$flag_x_linker,
|
$flag_link_win_subsystem_console,
|
||||||
$( $flag_linker + $flag_win_subsystem_console ),
|
$flag_link_win_machine_64,
|
||||||
$( $flag_linker + $flag_machine_64 )
|
$( $flag_link_win_path_output + $executable )
|
||||||
)
|
)
|
||||||
|
if ( $release -eq $false ) {
|
||||||
|
$linker_args += $flag_link_win_debug
|
||||||
|
$linker_args += $flag_link_win_pdb + $pdb
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
}
|
||||||
|
|
||||||
|
# https://learn.microsoft.com/en-us/cpp/c-runtime-library/crt-library-features?view=msvc-170
|
||||||
$libraries = @(
|
$libraries = @(
|
||||||
'Kernel32', # For Windows API
|
'Kernel32' # For Windows API
|
||||||
# 'msvcrt', # For the C Runtime (Dynamically Linked)
|
# 'msvcrt', # For the C Runtime (Dynamically Linked)
|
||||||
'libucrt',
|
# 'libucrt',
|
||||||
'libcmt' # For the C Runtime (Static Linkage)
|
'libcmt' # For the C Runtime (Static Linkage)
|
||||||
)
|
)
|
||||||
|
|
||||||
# $compiler_args += $linker_args
|
$libraries | ForEach-Object {
|
||||||
# $compiler_args += $libraries | ForEach-Object { $flag_library + $_ }
|
$linker_args += $_ + '.lib'
|
||||||
|
}
|
||||||
|
|
||||||
|
$linker_args += $object
|
||||||
|
run-linker lld-link $executable $linker_args
|
||||||
|
|
||||||
Push-Location $path_project
|
Push-Location $path_project
|
||||||
if ( Test-Path($executable) ) {
|
if ( Test-Path( $executable ) ) {
|
||||||
write-host "`nRunning bootstrap"
|
write-host "`nRunning bootstrap"
|
||||||
$time_taken = Measure-Command { & $executable
|
$time_taken = Measure-Command { & $executable
|
||||||
| ForEach-Object {
|
| ForEach-Object {
|
||||||
@ -208,12 +242,12 @@ if ( $compiler -match "clang" )
|
|||||||
$compiler_args = @(
|
$compiler_args = @(
|
||||||
$flag_target_arch, $target_arch,
|
$flag_target_arch, $target_arch,
|
||||||
$flag_preprocess_non_intergrated,
|
$flag_preprocess_non_intergrated,
|
||||||
$( $flag_define + 'GEN_TIME' ),
|
( $flag_define + 'GEN_TIME' ),
|
||||||
$flag_path_output, $executable,
|
$flag_path_output, $executable,
|
||||||
$( $flag_include + $include )
|
( $flag_include + $include )
|
||||||
)
|
)
|
||||||
if ( $release -eq $false ) {
|
if ( $release -eq $false ) {
|
||||||
$compiler_args += $( $flag_define + 'Build_Debug' )
|
$compiler_args += ( $flag_define + 'Build_Debug' )
|
||||||
$compiler_args += $flag_debug, $flag_debug_codeview, $flag_profiling_debug
|
$compiler_args += $flag_debug, $flag_debug_codeview, $flag_profiling_debug
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -221,7 +255,7 @@ if ( $compiler -match "clang" )
|
|||||||
run-compiler clang $executable $path_build $path_gen $compiler_args
|
run-compiler clang $executable $path_build $path_gen $compiler_args
|
||||||
|
|
||||||
Push-Location $path_singleheader
|
Push-Location $path_singleheader
|
||||||
if ( Test-Path($executable) ) {
|
if ( Test-Path( $executable ) ) {
|
||||||
write-host "`nRunning singleheader generator"
|
write-host "`nRunning singleheader generator"
|
||||||
$time_taken = Measure-Command { & $executable
|
$time_taken = Measure-Command { & $executable
|
||||||
| ForEach-Object {
|
| ForEach-Object {
|
||||||
@ -241,6 +275,7 @@ if ( $compiler -match "clang" )
|
|||||||
|
|
||||||
if ( $compiler -match "msvc" )
|
if ( $compiler -match "msvc" )
|
||||||
{
|
{
|
||||||
|
# https://learn.microsoft.com/en-us/cpp/build/reference/compiler-options-listed-by-category?view=msvc-170
|
||||||
$flag_compile = '/c'
|
$flag_compile = '/c'
|
||||||
$flag_debug = '/Zi'
|
$flag_debug = '/Zi'
|
||||||
$flag_define = '/D'
|
$flag_define = '/D'
|
||||||
@ -250,6 +285,8 @@ if ( $compiler -match "msvc" )
|
|||||||
$flag_dll = '/LD'
|
$flag_dll = '/LD'
|
||||||
$flag_dll_debug = '/LDd'
|
$flag_dll_debug = '/LDd'
|
||||||
$flag_linker = '/link'
|
$flag_linker = '/link'
|
||||||
|
$flag_link_debug = '/DEBUG'
|
||||||
|
$flag_link_pdb = '/PDB:'
|
||||||
$flag_link_machine_32 = '/MACHINE:X86'
|
$flag_link_machine_32 = '/MACHINE:X86'
|
||||||
$flag_link_machine_64 = '/MACHINE:X64'
|
$flag_link_machine_64 = '/MACHINE:X64'
|
||||||
$flag_link_path_output = '/OUT:'
|
$flag_link_path_output = '/OUT:'
|
||||||
@ -266,6 +303,7 @@ if ( $compiler -match "msvc" )
|
|||||||
$flag_preprocess_conform = '/Zc:preprocessor'
|
$flag_preprocess_conform = '/Zc:preprocessor'
|
||||||
|
|
||||||
[array] $compiler_args = $null
|
[array] $compiler_args = $null
|
||||||
|
[array] $linker_args = $null
|
||||||
|
|
||||||
if ( $bootstrap )
|
if ( $bootstrap )
|
||||||
{
|
{
|
||||||
@ -283,21 +321,22 @@ if ( $compiler -match "msvc" )
|
|||||||
$unit = join-path $path_project "bootstrap.cpp"
|
$unit = join-path $path_project "bootstrap.cpp"
|
||||||
$object = join-path $path_build "bootstrap.obj"
|
$object = join-path $path_build "bootstrap.obj"
|
||||||
$executable = join-path $path_build "bootstrap.exe"
|
$executable = join-path $path_build "bootstrap.exe"
|
||||||
|
$pdb = join-path $path_build "bootstrap.pdb"
|
||||||
|
|
||||||
$compiler_args = @(
|
$compiler_args = @(
|
||||||
$flag_nologo,
|
$flag_nologo,
|
||||||
$flag_debug,
|
|
||||||
$flag_preprocess_conform,
|
$flag_preprocess_conform,
|
||||||
$( $flag_define + 'GEN_TIME' ),
|
$flag_define + 'GEN_TIME',
|
||||||
$flag_full_src_path,
|
$flag_full_src_path,
|
||||||
$( $flag_path_interm + $path_build + '\' ),
|
( $flag_path_interm + $path_build + '\' ),
|
||||||
$( $flag_path_output + $path_build + '\' ),
|
( $flag_path_output + $path_build + '\' ),
|
||||||
$( $flag_include + $include )
|
( $flag_include + $include )
|
||||||
)
|
)
|
||||||
|
|
||||||
if ( $release -eq $false ) {
|
if ( $release -eq $false ) {
|
||||||
$compiler_args += $( $flag_define + 'Build_Debug' )
|
$compiler_args += ( $flag_define + 'Build_Debug' )
|
||||||
$compiler_args += $( $flag_path_debug + $path_build + '\' )
|
$compiler_args += $flag_debug
|
||||||
|
$compiler_args += ( $flag_path_debug + $path_build + '\' )
|
||||||
$compiler_args += $flag_link_rt_static_debug
|
$compiler_args += $flag_link_rt_static_debug
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
@ -311,17 +350,20 @@ if ( $compiler -match "msvc" )
|
|||||||
$flag_nologo,
|
$flag_nologo,
|
||||||
$flag_link_machine_64,
|
$flag_link_machine_64,
|
||||||
$flag_link_subsystem_console,
|
$flag_link_subsystem_console,
|
||||||
$( $flag_link_path_output + $executable ),
|
( $flag_link_path_output + $executable )
|
||||||
$object
|
|
||||||
)
|
)
|
||||||
if ( $release -eq $false ) {
|
if ( $release -eq $false ) {
|
||||||
|
$linker_args += $flag_link_debug
|
||||||
|
$linker_args += $flag_link_pdb + $pdb
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$linker_args += $object
|
||||||
run-linker link $executable $linker_args
|
run-linker link $executable $linker_args
|
||||||
|
|
||||||
Push-Location $path_project
|
Push-Location $path_project
|
||||||
if ( Test-Path($executable) ) {
|
if ( Test-Path( $executable ) ) {
|
||||||
write-host "`nRunning bootstrap"
|
write-host "`nRunning bootstrap"
|
||||||
$time_taken = Measure-Command { & $executable
|
$time_taken = Measure-Command { & $executable
|
||||||
| ForEach-Object {
|
| ForEach-Object {
|
||||||
@ -353,16 +395,16 @@ if ( $compiler -match "msvc" )
|
|||||||
$flag_nologo,
|
$flag_nologo,
|
||||||
$flag_debug,
|
$flag_debug,
|
||||||
$flag_preprocess_conform,
|
$flag_preprocess_conform,
|
||||||
$( $flag_define + 'GEN_TIME' ),
|
( $flag_define + 'GEN_TIME' ),
|
||||||
$flag_full_src_path,
|
$flag_full_src_path,
|
||||||
$( $flag_path_interm + $path_build + '\' ),
|
( $flag_path_interm + $path_build + '\' ),
|
||||||
$( $flag_path_output + $path_build + '\' ),
|
( $flag_path_output + $path_build + '\' ),
|
||||||
$( $flag_include + $include )
|
( $flag_include + $include )
|
||||||
)
|
)
|
||||||
|
|
||||||
if ( $release -eq $false ) {
|
if ( $release -eq $false ) {
|
||||||
$compiler_args += $( $flag_define + 'Build_Debug' )
|
$compiler_args += ( $flag_define + 'Build_Debug' )
|
||||||
$compiler_args += $( $flag_path_debug + $path_build + '\' )
|
$compiler_args += ( $flag_path_debug + $path_build + '\' )
|
||||||
}
|
}
|
||||||
|
|
||||||
$compiler_args += $unit
|
$compiler_args += $unit
|
||||||
|
@ -1,8 +1,3 @@
|
|||||||
param (
|
|
||||||
[ValidateSet("amd64", "x86", "arm", "arm64")]
|
|
||||||
[string]$arch = "amd64"
|
|
||||||
)
|
|
||||||
|
|
||||||
$ErrorActionPreference = "Stop"
|
$ErrorActionPreference = "Stop"
|
||||||
|
|
||||||
# Use vswhere to find the latest Visual Studio installation
|
# Use vswhere to find the latest Visual Studio installation
|
||||||
@ -22,10 +17,7 @@ if ( -not (Test-Path $vs_devshell) ) {
|
|||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
# Set the target architecture based on the parameter
|
|
||||||
# $env:VSCMD_ARG_TGT_ARCH=$arch
|
|
||||||
|
|
||||||
# Launch the Visual Studio Developer Shell
|
# Launch the Visual Studio Developer Shell
|
||||||
Push-Location
|
Push-Location
|
||||||
& $vs_devshell -Arch amd64
|
& $vs_devshell @args
|
||||||
Pop-Location
|
Pop-Location
|
Loading…
Reference in New Issue
Block a user