diff options
| author | Matias Fernandez <matiasfmolinari@gmail.com> | 2023-05-08 23:52:21 -0400 |
|---|---|---|
| committer | Matias Fernandez <matiasfmolinari@gmail.com> | 2023-05-08 23:52:21 -0400 |
| commit | 1ed105205c23910b8f017fa8de09caca29a3781f (patch) | |
| tree | cbeb73d7c8fdac621df9d683acd5868b1c04d371 /src/build_settings.cpp | |
| parent | 46da53ba151b410efb8f4646008e1ebdcfa6ad40 (diff) | |
| parent | 182b269e4642be2e40afbb39f7d8a9ac0a5aeed5 (diff) | |
Merge branch 'master' of https://github.com/matias-eduardo/Odin
Diffstat (limited to 'src/build_settings.cpp')
| -rw-r--r-- | src/build_settings.cpp | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/src/build_settings.cpp b/src/build_settings.cpp index ac033df71..78b1bd6c4 100644 --- a/src/build_settings.cpp +++ b/src/build_settings.cpp @@ -262,6 +262,7 @@ struct BuildContext { String microarch; BuildModeKind build_mode; bool generate_docs; + bool custom_optimization_level; i32 optimization_level; bool show_timings; TimingsExportFormat export_timings_format; @@ -1272,6 +1273,12 @@ gb_internal void init_build_context(TargetMetrics *cross_target) { gb_exit(1); } + if (bc->ODIN_DEBUG && !bc->custom_optimization_level) { + // NOTE(bill): when building with `-debug` but not specifying an optimization level + // default to `-o:none` to improve the debug symbol generation by default + bc->optimization_level = -1; // -o:none + } + bc->optimization_level = gb_clamp(bc->optimization_level, -1, 2); // ENFORCE DYNAMIC MAP CALLS @@ -1285,9 +1292,6 @@ gb_internal void init_build_context(TargetMetrics *cross_target) { break; } } - - #undef LINK_FLAG_X64 - #undef LINK_FLAG_386 } #if defined(GB_SYSTEM_WINDOWS) |