aboutsummaryrefslogtreecommitdiff
path: root/src/build_settings.cpp
diff options
context:
space:
mode:
authorMatias Fernandez <matiasfmolinari@gmail.com>2023-05-08 23:52:21 -0400
committerMatias Fernandez <matiasfmolinari@gmail.com>2023-05-08 23:52:21 -0400
commit1ed105205c23910b8f017fa8de09caca29a3781f (patch)
treecbeb73d7c8fdac621df9d683acd5868b1c04d371 /src/build_settings.cpp
parent46da53ba151b410efb8f4646008e1ebdcfa6ad40 (diff)
parent182b269e4642be2e40afbb39f7d8a9ac0a5aeed5 (diff)
Merge branch 'master' of https://github.com/matias-eduardo/Odin
Diffstat (limited to 'src/build_settings.cpp')
-rw-r--r--src/build_settings.cpp10
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)