aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/parser.cpp7
-rw-r--r--src/parser.hpp1
2 files changed, 8 insertions, 0 deletions
diff --git a/src/parser.cpp b/src/parser.cpp
index 78120507d..aa8969103 100644
--- a/src/parser.cpp
+++ b/src/parser.cpp
@@ -4183,6 +4183,8 @@ gb_internal Ast *parse_when_stmt(AstFile *f) {
syntax_error(f->curr_token, "Expected condition for when statement");
}
+ bool was_in_when_statement = f->in_when_statement;
+ f->in_when_statement = true;
if (allow_token(f, Token_do)) {
body = parse_do_body(f, cond ? ast_token(cond) : token, "then when statement");
} else {
@@ -4209,6 +4211,7 @@ gb_internal Ast *parse_when_stmt(AstFile *f) {
break;
}
}
+ f->in_when_statement = was_in_when_statement;
return ast_when_stmt(f, token, cond, body, else_stmt);
}
@@ -4470,6 +4473,10 @@ gb_internal Ast *parse_import_decl(AstFile *f, ImportDeclKind kind) {
array_add(&f->imports, s);
}
+ if (f->in_when_statement) {
+ syntax_error(import_name, "Cannot use 'import' within a 'when' statement. Prefer using the file suffixes (e.g. foo_windows.odin) or '//+build' tags");
+ }
+
if (kind != ImportDecl_Standard) {
syntax_error(import_name, "'using import' is not allowed, please use the import name explicitly");
}
diff --git a/src/parser.hpp b/src/parser.hpp
index fa169d3ad..109068da7 100644
--- a/src/parser.hpp
+++ b/src/parser.hpp
@@ -116,6 +116,7 @@ struct AstFile {
bool allow_in_expr; // NOTE(bill): in expression are only allowed in certain cases
bool in_foreign_block;
bool allow_type;
+ bool in_when_statement;
isize total_file_decl_count;
isize delayed_decl_count;