aboutsummaryrefslogtreecommitdiff
path: root/src
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
parent0570c84a83884bbf5c36dc4a5546c04cf3be3c2d (diff)
parent0234f50da1d5f697e6c180d2d7463a9587cbc7a4 (diff)
Merge branch 'master' into strconv_docs
Diffstat (limited to 'src')
-rw-r--r--src/build_settings.cpp16
-rw-r--r--src/error.cpp10
-rw-r--r--src/main.cpp36
-rw-r--r--src/parser.cpp8
4 files changed, 57 insertions, 13 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) {
diff --git a/src/error.cpp b/src/error.cpp
index 2974dc039..e3e1381f4 100644
--- a/src/error.cpp
+++ b/src/error.cpp
@@ -14,8 +14,6 @@ struct ErrorCollector {
gb_global ErrorCollector global_error_collector;
-#define MAX_ERROR_COLLECTOR_COUNT (36)
-
gb_internal bool any_errors(void) {
return global_error_collector.count.load() != 0;
@@ -28,6 +26,8 @@ gb_internal void init_global_error_collector(void) {
array_init(&global_files, heap_allocator(), 1, 4096);
}
+gb_internal isize MAX_ERROR_COLLECTOR_COUNT(void);
+
// temporary
// defined in build_settings.cpp
@@ -356,7 +356,7 @@ gb_internal void error_va(TokenPos const &pos, TokenPos end, char const *fmt, va
show_error_on_line(pos, end);
}
mutex_unlock(&global_error_collector.mutex);
- if (global_error_collector.count > MAX_ERROR_COLLECTOR_COUNT) {
+ if (global_error_collector.count > MAX_ERROR_COLLECTOR_COUNT()) {
gb_exit(1);
}
}
@@ -407,7 +407,7 @@ gb_internal void error_no_newline_va(TokenPos const &pos, char const *fmt, va_li
error_out_va(fmt, va);
}
mutex_unlock(&global_error_collector.mutex);
- if (global_error_collector.count > MAX_ERROR_COLLECTOR_COUNT) {
+ if (global_error_collector.count > MAX_ERROR_COLLECTOR_COUNT()) {
gb_exit(1);
}
}
@@ -431,7 +431,7 @@ gb_internal void syntax_error_va(TokenPos const &pos, TokenPos end, char const *
}
mutex_unlock(&global_error_collector.mutex);
- if (global_error_collector.count > MAX_ERROR_COLLECTOR_COUNT) {
+ if (global_error_collector.count > MAX_ERROR_COLLECTOR_COUNT()) {
gb_exit(1);
}
}
diff --git a/src/main.cpp b/src/main.cpp
index bbb28cdf8..33ee65c6b 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -594,13 +594,13 @@ gb_internal Array<String> setup_args(int argc, char const **argv) {
gb_internal void print_usage_line(i32 indent, char const *fmt, ...) {
while (indent --> 0) {
- gb_printf_err("\t");
+ gb_printf("\t");
}
va_list va;
va_start(va, fmt);
- gb_printf_err_va(fmt, va);
+ gb_printf_va(fmt, va);
va_end(va);
- gb_printf_err("\n");
+ gb_printf("\n");
}
gb_internal void usage(String argv0) {
@@ -691,6 +691,7 @@ enum BuildFlagKind {
BuildFlag_TerseErrors,
BuildFlag_VerboseErrors,
BuildFlag_ErrorPosStyle,
+ BuildFlag_MaxErrorCount,
// internal use only
BuildFlag_InternalIgnoreLazy,
@@ -866,6 +867,7 @@ gb_internal bool parse_build_flags(Array<String> args) {
add_flag(&build_flags, BuildFlag_TerseErrors, str_lit("terse-errors"), BuildFlagParam_None, Command_all);
add_flag(&build_flags, BuildFlag_VerboseErrors, str_lit("verbose-errors"), BuildFlagParam_None, Command_all);
add_flag(&build_flags, BuildFlag_ErrorPosStyle, str_lit("error-pos-style"), BuildFlagParam_String, Command_all);
+ add_flag(&build_flags, BuildFlag_MaxErrorCount, str_lit("max-error-count"), BuildFlagParam_Integer, Command_all);
add_flag(&build_flags, BuildFlag_InternalIgnoreLazy, str_lit("internal-ignore-lazy"), BuildFlagParam_None, Command_all);
add_flag(&build_flags, BuildFlag_InternalIgnoreLLVMBuild, str_lit("internal-ignore-llvm-build"),BuildFlagParam_None, Command_all);
@@ -1522,6 +1524,17 @@ gb_internal bool parse_build_flags(Array<String> args) {
}
break;
+ case BuildFlag_MaxErrorCount: {
+ i64 count = big_int_to_i64(&value.value_integer);
+ if (count <= 0) {
+ gb_printf_err("-%.*s must be greater than 0", LIT(bf.name));
+ bad_flags = true;
+ } else {
+ build_context.max_error_count = cast(isize)count;
+ }
+ break;
+ }
+
case BuildFlag_InternalIgnoreLazy:
build_context.ignore_lazy = true;
break;
@@ -2212,8 +2225,21 @@ gb_internal void print_show_help(String const arg0, String const &command) {
print_usage_line(2, "Treats warning messages as error messages");
print_usage_line(0, "");
- print_usage_line(1, "-verbose-errors");
- print_usage_line(2, "Prints verbose error messages showing the code on that line and the location in that line");
+ print_usage_line(1, "-terse-errors");
+ print_usage_line(2, "Prints a terse error message without showing the code on that line and the location in that line");
+ print_usage_line(0, "");
+
+ print_usage_line(1, "-error-pos-style:<string>");
+ print_usage_line(2, "Options are 'unix', 'odin' and 'default' (odin)");
+ print_usage_line(2, "'odin' file/path(45:3)");
+ print_usage_line(2, "'unix' file/path:45:3:");
+ print_usage_line(0, "");
+
+
+ print_usage_line(1, "-max-error-count:<integer>");
+ print_usage_line(2, "Set the maximum number of errors that can be displayed before the compiler terminates");
+ print_usage_line(2, "Must be an integer >0");
+ print_usage_line(2, "If not set, the default max error count is %d", DEFAULT_MAX_ERROR_COLLECTOR_COUNT);
print_usage_line(0, "");
print_usage_line(1, "-foreign-error-procedures");
diff --git a/src/parser.cpp b/src/parser.cpp
index 86f955254..50a9ba766 100644
--- a/src/parser.cpp
+++ b/src/parser.cpp
@@ -3693,9 +3693,11 @@ gb_internal bool allow_field_separator(AstFile *f) {
if (allow_token(f, Token_Comma)) {
return true;
}
- if (ALLOW_NEWLINE && token.kind == Token_Semicolon && !token_is_newline(token)) {
- String p = token_to_string(token);
- syntax_error(token_end_of_line(f, f->prev_token), "Expected a comma, got a %.*s", LIT(p));
+ if (ALLOW_NEWLINE && token.kind == Token_Semicolon) {
+ if (!token_is_newline(token)) {
+ String p = token_to_string(token);
+ syntax_error(token_end_of_line(f, f->prev_token), "Expected a comma, got a %.*s", LIT(p));
+ }
advance_token(f);
return true;
}