diff options
| author | gingerBill <bill@gingerbill.org> | 2021-04-18 20:13:20 +0100 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2021-04-18 20:13:20 +0100 |
| commit | 3baddd4116e84c4f9175f42a074f3d2599aa4979 (patch) | |
| tree | e9af03b7e2602ace1812f1b9fce34f692addac6b /src | |
| parent | 6ae468828cc0aa4f7cff54919f9c3eca0850f931 (diff) | |
Improve `init_string` determination for constants
Diffstat (limited to 'src')
| -rw-r--r-- | src/check_type.cpp | 3 | ||||
| -rw-r--r-- | src/docs_writer.cpp | 20 | ||||
| -rw-r--r-- | src/entity.cpp | 5 |
3 files changed, 26 insertions, 2 deletions
diff --git a/src/check_type.cpp b/src/check_type.cpp index de81592c8..39fea75db 100644 --- a/src/check_type.cpp +++ b/src/check_type.cpp @@ -731,6 +731,7 @@ void check_enum_type(CheckerContext *ctx, Type *enum_type, Type *named_type, Ast Ast *field = et->fields[i]; Ast *ident = nullptr; Ast *init = nullptr; + u32 entity_flags = 0; if (field->kind == Ast_FieldValue) { ast_node(fv, FieldValue, field); if (fv->field == nullptr || fv->field->kind != Ast_Ident) { @@ -764,6 +765,7 @@ void check_enum_type(CheckerContext *ctx, Type *enum_type, Type *named_type, Ast } } else { iota = exact_binary_operator_value(Token_Add, iota, exact_value_i64(1)); + entity_flags |= EntityConstantFlag_ImplicitEnumValue; } @@ -800,6 +802,7 @@ void check_enum_type(CheckerContext *ctx, Type *enum_type, Type *named_type, Ast e->identifier = ident; e->flags |= EntityFlag_Visited; e->state = EntityState_Resolved; + e->Constant.flags |= entity_flags; if (scope_lookup_current(ctx->scope, name) != nullptr) { error(ident, "'%.*s' is already declared in this enumeration", LIT(name)); diff --git a/src/docs_writer.cpp b/src/docs_writer.cpp index b5a9161dd..57bc4ec66 100644 --- a/src/docs_writer.cpp +++ b/src/docs_writer.cpp @@ -831,13 +831,31 @@ OdinDocEntityIndex odin_doc_add_entity(OdinDocWriter *w, Entity *e) { break; } + OdinDocString init_string = {}; + if (init_expr) { + init_string = odin_doc_expr_string(w, init_expr); + } else { + if (e->kind == Entity_Constant) { + if (e->Constant.flags & EntityConstantFlag_ImplicitEnumValue) { + init_string = {}; // Blank + } else if (e->Constant.param_value.original_ast_expr) { + init_string = odin_doc_expr_string(w, e->Constant.param_value.original_ast_expr); + } else { + init_string = odin_doc_write_string(w, make_string_c(exact_value_to_string(e->Constant.value))); + } + } else if (e->kind == Entity_Variable) { + if (e->Variable.param_expr) { + init_string = odin_doc_expr_string(w, e->Variable.param_expr); + } + } + } doc_entity.kind = kind; doc_entity.flags = flags; doc_entity.pos = odin_doc_token_pos_cast(w, e->token.pos); doc_entity.name = odin_doc_write_string(w, e->token.string); doc_entity.type = 0; // Set later - doc_entity.init_string = odin_doc_expr_string(w, init_expr); + doc_entity.init_string = init_string; doc_entity.comment = odin_doc_comment_group_string(w, comment); doc_entity.docs = odin_doc_comment_group_string(w, docs); doc_entity.foreign_library = 0; // Set later diff --git a/src/entity.cpp b/src/entity.cpp index a27b7cb37..3926678fd 100644 --- a/src/entity.cpp +++ b/src/entity.cpp @@ -93,7 +93,9 @@ struct ParameterValue { }; }; - +enum EntityConstantFlags : u32 { + EntityConstantFlag_ImplicitEnumValue = 1<<0, +}; // An Entity is a named "thing" in the language struct Entity { @@ -126,6 +128,7 @@ struct Entity { struct { ExactValue value; ParameterValue param_value; + u32 flags; } Constant; struct { Ast *init_expr; // only used for some variables within procedure bodies |