From 2f1c89629021cda7880f010f6a7e2e484fb92a46 Mon Sep 17 00:00:00 2001 From: gingerBill Date: Sun, 18 Apr 2021 18:33:15 +0100 Subject: Add `-doc-format` command for the new .odin-doc file format (to be used to generate documentation tools) --- src/check_type.cpp | 1 - 1 file changed, 1 deletion(-) (limited to 'src/check_type.cpp') diff --git a/src/check_type.cpp b/src/check_type.cpp index 8420c4687..de81592c8 100644 --- a/src/check_type.cpp +++ b/src/check_type.cpp @@ -2461,7 +2461,6 @@ bool check_procedure_type(CheckerContext *ctx, Type *type, Ast *proc_type_node, type->Proc.specialization_count = specialization_count; type->Proc.diverging = pt->diverging; type->Proc.optional_ok = optional_ok; - type->Proc.tags = pt->tags; if (param_count > 0) { Entity *end = params->Tuple.variables[param_count-1]; -- cgit v1.2.3 From 3baddd4116e84c4f9175f42a074f3d2599aa4979 Mon Sep 17 00:00:00 2001 From: gingerBill Date: Sun, 18 Apr 2021 20:13:20 +0100 Subject: Improve `init_string` determination for constants --- src/check_type.cpp | 3 +++ src/docs_writer.cpp | 20 +++++++++++++++++++- src/entity.cpp | 5 ++++- 3 files changed, 26 insertions(+), 2 deletions(-) (limited to 'src/check_type.cpp') 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 -- cgit v1.2.3