aboutsummaryrefslogtreecommitdiff
path: root/src/build_settings.cpp
diff options
context:
space:
mode:
authorJon Lipstate <Jon@Lipstate.com>2023-04-05 22:20:21 -0700
committerJon Lipstate <Jon@Lipstate.com>2023-04-05 22:20:21 -0700
commit41ff7a6010e146a33045e9dca28c4d753835bd0d (patch)
tree0f526d3af99d170b3792b84e3dcd2357827e5d76 /src/build_settings.cpp
parent0570c84a83884bbf5c36dc4a5546c04cf3be3c2d (diff)
parent0234f50da1d5f697e6c180d2d7463a9587cbc7a4 (diff)
Merge branch 'master' into strconv_docs
Diffstat (limited to 'src/build_settings.cpp')
-rw-r--r--src/build_settings.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/build_settings.cpp b/src/build_settings.cpp
index 0aa9977a5..ac033df71 100644
--- a/src/build_settings.cpp
+++ b/src/build_settings.cpp
@@ -7,6 +7,8 @@
// #define DEFAULT_TO_THREADED_CHECKER
// #endif
+#define DEFAULT_MAX_ERROR_COLLECTOR_COUNT (36)
+
enum TargetOsKind : u16 {
TargetOs_Invalid,
@@ -313,6 +315,8 @@ struct BuildContext {
RelocMode reloc_mode;
bool disable_red_zone;
+ isize max_error_count;
+
u32 cmd_doc_flags;
Array<String> extra_packages;
@@ -344,6 +348,14 @@ gb_internal bool global_ignore_warnings(void) {
return build_context.ignore_warnings;
}
+gb_internal isize MAX_ERROR_COLLECTOR_COUNT(void) {
+ if (build_context.max_error_count <= 0) {
+ return DEFAULT_MAX_ERROR_COLLECTOR_COUNT;
+ }
+ return build_context.max_error_count;
+}
+
+
gb_global TargetMetrics target_windows_i386 = {
TargetOs_windows,
@@ -1081,6 +1093,10 @@ gb_internal void init_build_context(TargetMetrics *cross_target) {
bc->ODIN_VERSION = ODIN_VERSION;
bc->ODIN_ROOT = odin_root_dir();
+ if (bc->max_error_count <= 0) {
+ bc->max_error_count = DEFAULT_MAX_ERROR_COLLECTOR_COUNT;
+ }
+
{
char const *found = gb_get_env("ODIN_ERROR_POS_STYLE", permanent_allocator());
if (found) {