Add #warning(<string>) builtin compile time procedure

This commit is contained in:
gingerBill
2024-06-20 15:32:30 +01:00
parent 94a8c38d86
commit dab3c832e0
3 changed files with 22 additions and 2 deletions

View File

@@ -1438,7 +1438,7 @@ parse_stmt :: proc(p: ^Parser) -> ^ast.Stmt {
case: error(p, stmt.pos, "#partial can only be applied to a switch statement")
}
return stmt
case "assert", "panic":
case "assert", "panic", "warning":
bd := ast.new(ast.Basic_Directive, tok.pos, end_pos(tag))
bd.tok = tok
bd.name = name

View File

@@ -1714,6 +1714,26 @@ gb_internal bool check_builtin_procedure_directive(CheckerContext *c, Operand *o
operand->type = t_untyped_bool;
operand->mode = Addressing_Constant;
} else if (name == "warning") {
ERROR_BLOCK();
if (ce->args.count != 1) {
error(call, "'#warning' expects 1 argument, got %td", ce->args.count);
return false;
}
if (!is_type_string(operand->type) && operand->mode != Addressing_Constant) {
gbString str = expr_to_string(ce->args[0]);
error(call, "'%s' is not a constant string", str);
gb_string_free(str);
return false;
}
warning(call, "%.*s", LIT(operand->value.value_string));
if (c->proc_name != "") {
gbString str = type_to_string(c->curr_proc_sig);
error_line("\tCalled within '%.*s' :: %s\n", LIT(c->proc_name), str);
gb_string_free(str);
}
operand->type = t_invalid;
operand->mode = Addressing_NoValue;
} else if (name == "panic") {
ERROR_BLOCK();
if (ce->args.count != 1) {

View File

@@ -5167,7 +5167,7 @@ gb_internal Ast *parse_stmt(AstFile *f) {
break;
}
return s;
} else if (tag == "assert" || tag == "panic") {
} else if (tag == "assert" || tag == "panic" || tag == "warning") {
Ast *t = ast_basic_directive(f, hash_token, name);
Ast *stmt = ast_expr_stmt(f, parse_call_expr(f, t));
expect_semicolon(f);