diff options
| author | Andrew Kelley <superjoe30@gmail.com> | 2018-04-12 16:26:23 -0400 |
|---|---|---|
| committer | Andrew Kelley <superjoe30@gmail.com> | 2018-04-12 16:26:23 -0400 |
| commit | 373b3586a1b1d6a3989220a8aac0d1c30f9fdb3a (patch) | |
| tree | 751447d115b473b7794bd14583cc2d9c0ea353ae /src/ir.cpp | |
| parent | 0d8646d262ebc3db6631421db8fc79228b6622f8 (diff) | |
| download | zig-373b3586a1b1d6a3989220a8aac0d1c30f9fdb3a.tar.gz zig-373b3586a1b1d6a3989220a8aac0d1c30f9fdb3a.zip | |
inline functions must be stored in const or comptime var
closes #913
Diffstat (limited to 'src/ir.cpp')
| -rw-r--r-- | src/ir.cpp | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/src/ir.cpp b/src/ir.cpp index 7d8088d5ed..3ba58a09bd 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -11395,7 +11395,19 @@ static TypeTableEntry *ir_analyze_instruction_decl_var(IrAnalyze *ira, IrInstruc } break; case VarClassRequiredAny: - // OK + if (casted_init_value->value.special == ConstValSpecialStatic && + casted_init_value->value.type->id == TypeTableEntryIdFn && + casted_init_value->value.data.x_ptr.data.fn.fn_entry->fn_inline == FnInlineAlways) + { + var_class_requires_const = true; + if (!var->src_is_const && !is_comptime_var) { + ErrorMsg *msg = ir_add_error_node(ira, source_node, + buf_sprintf("functions marked inline must be stored in const or comptime var")); + AstNode *proto_node = casted_init_value->value.data.x_ptr.data.fn.fn_entry->proto_node; + add_error_note(ira->codegen, msg, proto_node, buf_sprintf("declared here")); + result_type = ira->codegen->builtin_types.entry_invalid; + } + } break; } } |
