From e24d055ddca7a1210f260c6e1271141c57807b4e Mon Sep 17 00:00:00 2001 From: Steven Conway Date: Wed, 4 Sep 2024 22:11:25 +1000 Subject: [PATCH] Fixes issue where interfaces were not being added to the symbol table. --- verilog/analysis/symbol_table.cc | 600 +++++------ verilog/analysis/symbol_table_test.cc | 1380 ++++++++++++++----------- 2 files changed, 1092 insertions(+), 888 deletions(-) diff --git a/verilog/analysis/symbol_table.cc b/verilog/analysis/symbol_table.cc index e22a983fb..707558026 100644 --- a/verilog/analysis/symbol_table.cc +++ b/verilog/analysis/symbol_table.cc @@ -81,7 +81,7 @@ static absl::string_view StripOuterQuotes(absl::string_view text) { return absl::StripSuffix(absl::StripPrefix(text, "\""), "\""); } -static const verible::EnumNameMap& SymbolMetaTypeNames() { +static const verible::EnumNameMap &SymbolMetaTypeNames() { static const verible::EnumNameMap kSymbolMetaTypeNames({ // short-hand annotation for identifier reference type {"", SymbolMetaType::kRoot}, @@ -103,7 +103,7 @@ static const verible::EnumNameMap& SymbolMetaTypeNames() { return kSymbolMetaTypeNames; } -std::ostream& operator<<(std::ostream& stream, SymbolMetaType symbol_type) { +std::ostream &operator<<(std::ostream &stream, SymbolMetaType symbol_type) { return SymbolMetaTypeNames().Unparse(symbol_type, stream); } @@ -114,8 +114,8 @@ absl::string_view SymbolMetaTypeAsString(SymbolMetaType type) { // Root SymbolTableNode has no key, but we identify it as "$root" static constexpr absl::string_view kRoot("$root"); -std::ostream& SymbolTableNodeFullPath(std::ostream& stream, - const SymbolTableNode& node) { +std::ostream &SymbolTableNodeFullPath(std::ostream &stream, + const SymbolTableNode &node) { if (node.Parent() != nullptr) { SymbolTableNodeFullPath(stream, *node.Parent()) << "::" << *node.Key(); } else { @@ -124,14 +124,14 @@ std::ostream& SymbolTableNodeFullPath(std::ostream& stream, return stream; } -static std::string ContextFullPath(const SymbolTableNode& context) { +static std::string ContextFullPath(const SymbolTableNode &context) { std::ostringstream stream; SymbolTableNodeFullPath(stream, context); return stream.str(); } -std::ostream& ReferenceNodeFullPath(std::ostream& stream, - const ReferenceComponentNode& node) { +std::ostream &ReferenceNodeFullPath(std::ostream &stream, + const ReferenceComponentNode &node) { if (node.Parent() != nullptr) { ReferenceNodeFullPath(stream, *node.Parent()); // recursive } @@ -139,27 +139,25 @@ std::ostream& ReferenceNodeFullPath(std::ostream& stream, } static std::string ReferenceNodeFullPathString( - const ReferenceComponentNode& node) { + const ReferenceComponentNode &node) { std::ostringstream stream; ReferenceNodeFullPath(stream, node); return stream.str(); } -static std::ostream& operator<<(std::ostream& stream, - const ReferenceComponentNode& ref_node) { - PrintTree( - ref_node, &stream, - [](std::ostream& s, const ReferenceComponent& ref_comp) -> std::ostream& { - return s << ref_comp; - }); +static std::ostream &operator<<(std::ostream &stream, + const ReferenceComponentNode &ref_node) { + PrintTree(ref_node, &stream, + [](std::ostream &s, const ReferenceComponent &ref_comp) + -> std::ostream & { return s << ref_comp; }); return stream; } // Validates iterator/pointer stability when appending new child. // Detects unwanted reallocation. -static ReferenceComponentNode* CheckedNewChildReferenceNode( - ReferenceComponentNode* parent, const ReferenceComponent& component) { - auto& siblings = parent->Children(); +static ReferenceComponentNode *CheckedNewChildReferenceNode( + ReferenceComponentNode *parent, const ReferenceComponent &component) { + auto &siblings = parent->Children(); if (!siblings.empty()) { CHECK_LT(siblings.size(), siblings.capacity()) << "\nReallocation would invalidate pointers to reference nodes at:\n" @@ -172,7 +170,7 @@ static ReferenceComponentNode* CheckedNewChildReferenceNode( } static absl::Status DiagnoseMemberSymbolResolutionFailure( - absl::string_view name, const SymbolTableNode& context) { + absl::string_view name, const SymbolTableNode &context) { const absl::string_view context_name = context.Parent() == nullptr ? kRoot : *context.Key(); return absl::NotFoundError( @@ -181,13 +179,13 @@ static absl::Status DiagnoseMemberSymbolResolutionFailure( context_name, ".")); } -static const SymbolTableNode* LookupSymbolUpwards( - const SymbolTableNode& context, absl::string_view symbol); +static const SymbolTableNode *LookupSymbolUpwards( + const SymbolTableNode &context, absl::string_view symbol); class SymbolTable::Builder : public TreeContextVisitor { public: - Builder(const VerilogSourceFile& source, SymbolTable* symbol_table, - VerilogProject* project) + Builder(const VerilogSourceFile &source, SymbolTable *symbol_table, + VerilogProject *project) : source_(&source), token_context_(MakeTokenContext()), symbol_table_(symbol_table), @@ -198,7 +196,7 @@ class SymbolTable::Builder : public TreeContextVisitor { } private: // methods - void Visit(const SyntaxTreeNode& node) final { + void Visit(const SyntaxTreeNode &node) final { const auto tag = static_cast(node.Tag().tag); VLOG(2) << __FUNCTION__ << " [node]: " << tag; switch (tag) { @@ -217,6 +215,9 @@ class SymbolTable::Builder : public TreeContextVisitor { case NodeEnum::kClassDeclaration: DeclareClass(node); break; + case NodeEnum::kInterfaceDeclaration: + DeclareInterface(node); + break; case NodeEnum::kFunctionPrototype: // fall-through case NodeEnum::kFunctionDeclaration: DeclareFunction(node); @@ -313,12 +314,12 @@ class SymbolTable::Builder : public TreeContextVisitor { // This overload enters 'scope' for the duration of the call. // New declared symbols will belong to that scope. - void Descend(const SyntaxTreeNode& node, SymbolTableNode* scope) { - const ValueSaver save_scope(¤t_scope_, scope); + void Descend(const SyntaxTreeNode &node, SymbolTableNode *scope) { + const ValueSaver save_scope(¤t_scope_, scope); Descend(node); } - void Descend(const SyntaxTreeNode& node) { + void Descend(const SyntaxTreeNode &node) { TreeContextVisitor::Visit(node); // maintains syntax tree Context() stack. } @@ -327,7 +328,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // the destructor. class CaptureDependentReference { public: - explicit CaptureDependentReference(Builder* builder) + explicit CaptureDependentReference(Builder *builder) : builder_(builder), saved_branch_point_(builder_->reference_branch_point_) { // Push stack space to capture references. @@ -341,7 +342,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // This completes the capture of a chain of dependent references. // Ref() can be empty if the subtree doesn't reference any identifiers. // Empty refs are non-actionable and must be excluded. - DependentReferences& ref(Ref()); + DependentReferences &ref(Ref()); if (!ref.Empty()) { builder_->current_scope_->Value().local_references_to_bind.emplace_back( std::move(ref)); @@ -351,16 +352,16 @@ class SymbolTable::Builder : public TreeContextVisitor { } // Returns the chain of dependent references that were built. - DependentReferences& Ref() const { + DependentReferences &Ref() const { return builder_->reference_builders_.top(); } private: - Builder* builder_; - ReferenceComponentNode* saved_branch_point_; + Builder *builder_; + ReferenceComponentNode *saved_branch_point_; }; - void DescendReferenceExpression(const SyntaxTreeNode& reference) { + void DescendReferenceExpression(const SyntaxTreeNode &reference) { // capture expressions referenced from the current scope if (!Context().DirectParentIs(NodeEnum::kReferenceCallBase)) { const CaptureDependentReference capture(this); @@ -372,14 +373,14 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void DescendExtends(const SyntaxTreeNode& extends) { + void DescendExtends(const SyntaxTreeNode &extends) { VLOG(2) << __FUNCTION__ << " from: " << CurrentScopeFullPath(); { // At this point we are already inside the scope of the class declaration, // however, the base classes should be resolved starting from the scope // that *contains* this class declaration. - const ValueSaver save(¤t_scope_, - current_scope_->Parent()); + const ValueSaver save(¤t_scope_, + current_scope_->Parent()); // capture the one base class type referenced by 'extends' const CaptureDependentReference capture(this); @@ -388,11 +389,11 @@ class SymbolTable::Builder : public TreeContextVisitor { // Link this new type reference as the base type of the current class being // declared. - const DependentReferences& recent_ref = + const DependentReferences &recent_ref = current_scope_->Parent()->Value().local_references_to_bind.back(); - const ReferenceComponentNode* base_type_ref = + const ReferenceComponentNode *base_type_ref = recent_ref.LastTypeComponent(); - SymbolInfo& current_declared_class_info = current_scope_->Value(); + SymbolInfo ¤t_declared_class_info = current_scope_->Value(); current_declared_class_info.parent_type.user_defined_type = base_type_ref; } @@ -413,7 +414,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // \- ::G // E -+- ::F // - void DescendDataType(const SyntaxTreeNode& data_type_node) { + void DescendDataType(const SyntaxTreeNode &data_type_node) { VLOG(2) << __FUNCTION__ << ": " << StringSpanOfSymbol(data_type_node); const CaptureDependentReference capture(this); @@ -422,7 +423,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // from this reference branch point. Start this out as nullptr, and set // it once an unqualified identifier is encountered that starts a // reference tree. - const ValueSaver set_branch( + const ValueSaver set_branch( &reference_branch_point_, nullptr); Descend(data_type_node); @@ -439,7 +440,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // std::endl; } - const DependentReferences& type_ref(capture.Ref()); + const DependentReferences &type_ref(capture.Ref()); if (!type_ref.Empty()) { // then some user-defined type was referenced declaration_type_info_->user_defined_type = @@ -453,7 +454,7 @@ class SymbolTable::Builder : public TreeContextVisitor { VLOG(2) << "end of " << __FUNCTION__; } - void DescendActualParameterList(const SyntaxTreeNode& node) { + void DescendActualParameterList(const SyntaxTreeNode &node) { if (reference_branch_point_ != nullptr) { // Pre-allocate siblings to guarantee pointer/iterator stability. // FindAll* will also catch actual port connections inside preprocessing @@ -466,7 +467,7 @@ class SymbolTable::Builder : public TreeContextVisitor { Descend(node); } - void DescendPortActualList(const SyntaxTreeNode& node) { + void DescendPortActualList(const SyntaxTreeNode &node) { if (reference_branch_point_ != nullptr) { // Pre-allocate siblings to guarantee pointer/iterator stability. // FindAll* will also catch actual port connections inside preprocessing @@ -477,7 +478,7 @@ class SymbolTable::Builder : public TreeContextVisitor { Descend(node); } - void DescendCallArgumentList(const SyntaxTreeNode& node) { + void DescendCallArgumentList(const SyntaxTreeNode &node) { if (reference_branch_point_ != nullptr) { // Pre-allocate siblings to guarantee pointer/iterator stability. // FindAll* will also catch call arguments inside preprocessing @@ -492,13 +493,13 @@ class SymbolTable::Builder : public TreeContextVisitor { Descend(node); } - void DescendStructType(const SyntaxTreeNode& struct_type) { + void DescendStructType(const SyntaxTreeNode &struct_type) { CHECK(struct_type.MatchesTag(NodeEnum::kStructType)); // Structs do not inherently have names, so they are all anonymous. // Type declarations (typedefs) create named alias elsewhere. const absl::string_view anon_name = current_scope_->Value().CreateAnonymousScope("struct"); - SymbolTableNode* new_struct = DeclareScopedElementAndDescend( + SymbolTableNode *new_struct = DeclareScopedElementAndDescend( struct_type, anon_name, SymbolMetaType::kStruct); // Create a self-reference to this struct type so that it can be linked @@ -519,11 +520,11 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void DescendEnumType(const SyntaxTreeNode& enum_type) { + void DescendEnumType(const SyntaxTreeNode &enum_type) { CHECK(enum_type.MatchesTag(NodeEnum::kEnumType)); const absl::string_view anon_name = current_scope_->Value().CreateAnonymousScope("enum"); - SymbolTableNode* new_enum = DeclareScopedElementAndDescend( + SymbolTableNode *new_enum = DeclareScopedElementAndDescend( enum_type, anon_name, SymbolMetaType::kEnumType); const ReferenceComponent anon_type_ref{ @@ -542,10 +543,10 @@ class SymbolTable::Builder : public TreeContextVisitor { } // Iterate over enumeration constants - for (const auto& itr : *new_enum) { + for (const auto &itr : *new_enum) { const auto enum_constant_name = itr.first; - const auto& symbol = itr.second; - const auto& syntax_origin = + const auto &symbol = itr.second; + const auto &syntax_origin = *ABSL_DIE_IF_NULL(symbol.Value().syntax_origin); const ReferenceComponent itr_ref{ @@ -564,8 +565,8 @@ class SymbolTable::Builder : public TreeContextVisitor { // Create default DeclarationTypeInfo DeclarationTypeInfo decl_type_info; - const ValueSaver save_type(&declaration_type_info_, - &decl_type_info); + const ValueSaver save_type(&declaration_type_info_, + &decl_type_info); declaration_type_info_->syntax_origin = &syntax_origin; declaration_type_info_->user_defined_type = cap.Ref().LastLeaf(); @@ -580,7 +581,7 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void HandlePossibleImplicitDeclaration(const SyntaxTreeNode& node) { + void HandlePossibleImplicitDeclaration(const SyntaxTreeNode &node) { VLOG(2) << __FUNCTION__; // Only left-hand side of continuous assignment statements are allowed to @@ -591,8 +592,8 @@ class SymbolTable::Builder : public TreeContextVisitor { CHECK(node.MatchesTag(NodeEnum::kLPValue)); DeclarationTypeInfo decl_type_info; - const ValueSaver save_type(&declaration_type_info_, - &decl_type_info); + const ValueSaver save_type(&declaration_type_info_, + &decl_type_info); declaration_type_info_->implicit = true; Descend(node); } else { @@ -601,7 +602,7 @@ class SymbolTable::Builder : public TreeContextVisitor { } // stores the direction of the port in the current declaration type info - void HandleDirection(const SyntaxTreeLeaf& leaf) { + void HandleDirection(const SyntaxTreeLeaf &leaf) { if (!declaration_type_info_) return; if (Context().DirectParentIs(NodeEnum::kModulePortDeclaration) || Context().DirectParentIs(NodeEnum::kPortDeclaration)) { @@ -609,7 +610,7 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void HandleIdentifier(const SyntaxTreeLeaf& leaf) { + void HandleIdentifier(const SyntaxTreeLeaf &leaf) { const absl::string_view text = leaf.get().text(); VLOG(2) << __FUNCTION__ << ": " << text; VLOG(2) << "current context: " << CurrentScopeFullPath(); @@ -666,13 +667,13 @@ class SymbolTable::Builder : public TreeContextVisitor { // Note that this excludes the out-of-line definition case, // which is handled in DescendThroughOutOfLineDefinition(). - const SyntaxTreeNode* decl_syntax = - Context().NearestParentMatching([](const SyntaxTreeNode& node) { + const SyntaxTreeNode *decl_syntax = + Context().NearestParentMatching([](const SyntaxTreeNode &node) { return node.MatchesTagAnyOf( {NodeEnum::kFunctionDeclaration, NodeEnum::kFunctionPrototype}); }); if (decl_syntax == nullptr) return; - SymbolTableNode* declared_function = &EmplaceTypedElementInCurrentScope( + SymbolTableNode *declared_function = &EmplaceTypedElementInCurrentScope( *decl_syntax, text, SymbolMetaType::kFunction); // After this point, we've registered the new function with its return // type, so we can switch context over to the newly declared function @@ -685,8 +686,8 @@ class SymbolTable::Builder : public TreeContextVisitor { // This is a constructor or its prototype. // From verilog.y, the "new" token is directly under this prototype node, // and the full constructor definition also contains its prototype. - const SyntaxTreeNode* decl_syntax = &Context().top(); - SymbolTableNode* declared_function = &EmplaceTypedElementInCurrentScope( + const SyntaxTreeNode *decl_syntax = &Context().top(); + SymbolTableNode *declared_function = &EmplaceTypedElementInCurrentScope( *decl_syntax, text, SymbolMetaType::kFunction); current_scope_ = declared_function; return; @@ -699,13 +700,13 @@ class SymbolTable::Builder : public TreeContextVisitor { // Note that this excludes the out-of-line definition case, // which is handled in DescendThroughOutOfLineDefinition(). - const SyntaxTreeNode* decl_syntax = - Context().NearestParentMatching([](const SyntaxTreeNode& node) { + const SyntaxTreeNode *decl_syntax = + Context().NearestParentMatching([](const SyntaxTreeNode &node) { return node.MatchesTagAnyOf( {NodeEnum::kTaskDeclaration, NodeEnum::kTaskPrototype}); }); if (decl_syntax == nullptr) return; - SymbolTableNode* declared_task = EmplaceElementInCurrentScope( + SymbolTableNode *declared_task = EmplaceElementInCurrentScope( *decl_syntax, text, SymbolMetaType::kTask); // After this point, we've registered the new task, // so we can switch context over to the newly declared function @@ -759,7 +760,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // Building a reference, possible part of a chain or qualified // reference. - DependentReferences& ref(reference_builders_.top()); + DependentReferences &ref(reference_builders_.top()); const ReferenceComponent new_ref{ .identifier = text, @@ -779,11 +780,11 @@ class SymbolTable::Builder : public TreeContextVisitor { // Handle possible implicit declarations here if (declaration_type_info_ != nullptr && declaration_type_info_->implicit) { - const SymbolTableNode* resolved = + const SymbolTableNode *resolved = LookupSymbolUpwards(*ABSL_DIE_IF_NULL(current_scope_), text); if (resolved == nullptr) { // No explicit declaration found, declare here - SymbolTableNode& implicit_declaration = + SymbolTableNode &implicit_declaration = EmplaceTypedElementInCurrentScope( leaf, text, SymbolMetaType::kDataNetVariableInstance); @@ -812,7 +813,7 @@ class SymbolTable::Builder : public TreeContextVisitor { reference_branch_point_ = ref.PushReferenceComponent(new_ref); } - void Visit(const SyntaxTreeLeaf& leaf) final { + void Visit(const SyntaxTreeLeaf &leaf) final { const auto tag = leaf.Tag().tag; VLOG(2) << __FUNCTION__ << " [leaf]: " << VerboseToken(leaf.get()); switch (tag) { @@ -844,7 +845,7 @@ class SymbolTable::Builder : public TreeContextVisitor { ReferenceType InferReferenceType() const { CHECK(!reference_builders_.empty()) << "Not currently in a reference context."; - const DependentReferences& ref(reference_builders_.top()); + const DependentReferences &ref(reference_builders_.top()); if (ref.Empty() || last_hierarchy_operator_ == nullptr) { // The root component is always treated as unqualified. @@ -876,18 +877,18 @@ class SymbolTable::Builder : public TreeContextVisitor { } bool QualifiedIdComponentInLastPosition() const { - const SyntaxTreeNode* qualified_id = + const SyntaxTreeNode *qualified_id = Context().NearestParentWithTag(NodeEnum::kQualifiedId); - const SyntaxTreeNode* unqualified_id = + const SyntaxTreeNode *unqualified_id = Context().NearestParentWithTag(NodeEnum::kUnqualifiedId); return ABSL_DIE_IF_NULL(qualified_id)->back().get() == unqualified_id; } bool ExtendedCallIsLast() const { - const SyntaxTreeNode* reference_call_base = + const SyntaxTreeNode *reference_call_base = Context().NearestParentWithTag(NodeEnum::kReferenceCallBase); if (reference_call_base == nullptr) return false; - for (auto& child : reference_call_base->children()) { + for (auto &child : reference_call_base->children()) { if (SymbolCastToNode(*child).MatchesTagAnyOf( {NodeEnum::kHierarchyExtension})) { return false; @@ -897,13 +898,13 @@ class SymbolTable::Builder : public TreeContextVisitor { } bool UnextendedCall() const { - const SyntaxTreeNode* rcb = + const SyntaxTreeNode *rcb = Context().NearestParentWithTag(NodeEnum::kReferenceCallBase); if (rcb == nullptr) return false; - for (auto& reference : rcb->children()) { + for (auto &reference : rcb->children()) { if (reference && SymbolCastToNode(*reference) .MatchesTagAnyOf({NodeEnum::kReference})) { - for (auto& child : SymbolCastToNode(*reference).children()) { + for (auto &child : SymbolCastToNode(*reference).children()) { if (SymbolCastToNode(*child).MatchesTagAnyOf( {NodeEnum::kHierarchyExtension})) { return false; @@ -917,7 +918,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // Does the context necessitate that the symbol being referenced have a // particular metatype? SymbolMetaType InferMetaType() const { - const DependentReferences& ref(reference_builders_.top()); + const DependentReferences &ref(reference_builders_.top()); // Out-of-line definitions' base/outer references must be resolved // immediately to a class. // Member references (inner) is a function or task, depending on header @@ -1014,7 +1015,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // Creates a named element in the current scope. // Suitable for SystemVerilog language elements: functions, tasks, packages, // classes, modules, etc... - SymbolTableNode* EmplaceElementInCurrentScope(const verible::Symbol& element, + SymbolTableNode *EmplaceElementInCurrentScope(const verible::Symbol &element, absl::string_view name, SymbolMetaType metatype) { const auto [kv, did_emplace] = current_scope_->TryEmplace( @@ -1036,8 +1037,8 @@ class SymbolTable::Builder : public TreeContextVisitor { // checks if the current first leaf has conflicting information with the // second symbol - bool IsTypeLeafConflicting(const SyntaxTreeLeaf* first, - const verible::Symbol* second) { + bool IsTypeLeafConflicting(const SyntaxTreeLeaf *first, + const verible::Symbol *second) { if (!first || !second) return false; if (IsTagMatching(second->Tag().tag, {static_cast(NodeEnum::kPackedDimensions), @@ -1045,8 +1046,8 @@ class SymbolTable::Builder : public TreeContextVisitor { return false; } if (second->Kind() == verible::SymbolKind::kLeaf) { - const SyntaxTreeLeaf* second_leaf = - verible::down_cast(second); + const SyntaxTreeLeaf *second_leaf = + verible::down_cast(second); // conflict if there are multiple direction specifications const std::initializer_list directiontags = { verilog_tokentype::TK_input, verilog_tokentype::TK_output, @@ -1078,9 +1079,9 @@ class SymbolTable::Builder : public TreeContextVisitor { } } if (second->Kind() == verible::SymbolKind::kNode) { - const SyntaxTreeNode* second_node = - verible::down_cast(second); - for (const auto& child : second_node->children()) { + const SyntaxTreeNode *second_node = + verible::down_cast(second); + for (const auto &child : second_node->children()) { if (IsTypeLeafConflicting(first, child.get())) return true; } } @@ -1088,16 +1089,16 @@ class SymbolTable::Builder : public TreeContextVisitor { } // checks if two nodes have conflicting information - bool DoesConflictingNodeExist(const SyntaxTreeNode* node, - const verible::Symbol* context) { + bool DoesConflictingNodeExist(const SyntaxTreeNode *node, + const verible::Symbol *context) { if (context && context->Kind() == verible::SymbolKind::kNode) { - const SyntaxTreeNode* second_node = - verible::down_cast(context); + const SyntaxTreeNode *second_node = + verible::down_cast(context); if ((node->Tag().tag == second_node->Tag().tag) && !verible::EqualTreesByEnumString(node, second_node)) { return true; } - for (const auto& child : second_node->children()) { + for (const auto &child : second_node->children()) { if (DoesConflictingNodeExist(node, child.get())) return true; } } @@ -1106,30 +1107,30 @@ class SymbolTable::Builder : public TreeContextVisitor { // checks if two kDataTypes have conflicting information, used // in multiline definitions of nodes - bool IsDataTypeNodeConflicting(const verible::Symbol* first, - const verible::Symbol* second) { + bool IsDataTypeNodeConflicting(const verible::Symbol *first, + const verible::Symbol *second) { // if type was not specified for symbol (e.g. implicit) in any case, return // true if (!first || !second) return false; // if the left expression is a leaf, do final checks against the right // expression if (first->Kind() == verible::SymbolKind::kLeaf) { - const SyntaxTreeLeaf* leaf = - verible::down_cast(first); + const SyntaxTreeLeaf *leaf = + verible::down_cast(first); return IsTypeLeafConflicting(leaf, second); } // if the left expression is a node, iterate over its children and check // compatibility if (first->Kind() == verible::SymbolKind::kNode) { - const SyntaxTreeNode* node = - verible::down_cast(first); + const SyntaxTreeNode *node = + verible::down_cast(first); if (IsTagMatching(node->Tag().tag, {static_cast(NodeEnum::kPackedDimensions), static_cast(NodeEnum::kUnpackedDimensions)})) { if (DoesConflictingNodeExist(node, second)) return true; return false; } - for (const auto& child : node->children()) { + for (const auto &child : node->children()) { // run method recursively for each child if (IsDataTypeNodeConflicting(child.get(), second)) return true; } @@ -1139,11 +1140,11 @@ class SymbolTable::Builder : public TreeContextVisitor { // Checks potential multiline declaration of port // against correctness - void CheckMultilinePortDeclarationCorrectness(SymbolTableNode* existing_node, + void CheckMultilinePortDeclarationCorrectness(SymbolTableNode *existing_node, absl::string_view name) { - DeclarationTypeInfo& new_decl_info = + DeclarationTypeInfo &new_decl_info = *ABSL_DIE_IF_NULL(declaration_type_info_); - DeclarationTypeInfo& old_decl_info = existing_node->Value().declared_type; + DeclarationTypeInfo &old_decl_info = existing_node->Value().declared_type; // TODO (glatosinski): currently direction is kept separately from // kDataTypes, that is why it is handled separately. We may want to // include it in kDataType to have a full type information in one place @@ -1159,7 +1160,7 @@ class SymbolTable::Builder : public TreeContextVisitor { DiagnoseSymbolAlreadyExists(name, *existing_node); return; } - for (const auto& type_specification : old_decl_info.type_specifications) { + for (const auto &type_specification : old_decl_info.type_specifications) { if (IsDataTypeNodeConflicting(type_specification, new_decl_info.syntax_origin)) { DiagnoseSymbolAlreadyExists(name, *existing_node); @@ -1174,8 +1175,8 @@ class SymbolTable::Builder : public TreeContextVisitor { // Creates a named typed element in the current scope. // Suitable for SystemVerilog language elements: nets, parameter, variables, // instances, functions (using their return types). - SymbolTableNode& EmplaceTypedElementInCurrentScope( - const verible::Symbol& element, absl::string_view name, + SymbolTableNode &EmplaceTypedElementInCurrentScope( + const verible::Symbol &element, absl::string_view name, SymbolMetaType metatype) { VLOG(2) << __FUNCTION__ << ": " << name << " in " << CurrentScopeFullPath(); VLOG(3) << " type info: " << *ABSL_DIE_IF_NULL(declaration_type_info_); @@ -1200,8 +1201,8 @@ class SymbolTable::Builder : public TreeContextVisitor { // Creates a port identifier element in the current scope. // Suitable for SystemVerilog module port declarations, where // there are multiple lines defining the symbol. - SymbolTableNode& EmplacePortIdentifierInCurrentScope( - const verible::Symbol& element, absl::string_view name, + SymbolTableNode &EmplacePortIdentifierInCurrentScope( + const verible::Symbol &element, absl::string_view name, SymbolMetaType metatype) { VLOG(2) << __FUNCTION__ << ": " << name << " in " << CurrentScopeFullPath(); VLOG(3) << " type info: " << *ABSL_DIE_IF_NULL(declaration_type_info_); @@ -1224,26 +1225,26 @@ class SymbolTable::Builder : public TreeContextVisitor { // Creates a named element in the current scope, and traverses its subtree // inside the new element's scope. // Returns the new scope. - SymbolTableNode* DeclareScopedElementAndDescend(const SyntaxTreeNode& element, + SymbolTableNode *DeclareScopedElementAndDescend(const SyntaxTreeNode &element, absl::string_view name, SymbolMetaType type) { - SymbolTableNode* enter_scope = + SymbolTableNode *enter_scope = EmplaceElementInCurrentScope(element, name, type); Descend(element, enter_scope); return enter_scope; } - void DeclareModule(const SyntaxTreeNode& module) { - const SyntaxTreeLeaf* module_name = GetModuleName(module); + void DeclareModule(const SyntaxTreeNode &module) { + const SyntaxTreeLeaf *module_name = GetModuleName(module); if (!module_name) return; DeclareScopedElementAndDescend(module, module_name->get().text(), SymbolMetaType::kModule); } - absl::string_view GetScopeNameFromGenerateBody(const SyntaxTreeNode& body) { + absl::string_view GetScopeNameFromGenerateBody(const SyntaxTreeNode &body) { if (body.MatchesTag(NodeEnum::kGenerateBlock)) { - const SyntaxTreeNode* gen_block = GetGenerateBlockBegin(body); - const TokenInfo* label = + const SyntaxTreeNode *gen_block = GetGenerateBlockBegin(body); + const TokenInfo *label = gen_block ? GetBeginLabelTokenInfo(*gen_block) : nullptr; if (label != nullptr) { // TODO: Check for a matching end-label here, and if its name matches @@ -1256,8 +1257,8 @@ class SymbolTable::Builder : public TreeContextVisitor { return current_scope_->Value().CreateAnonymousScope("generate"); } - void DeclareGenerateIf(const SyntaxTreeNode& generate_if) { - const SyntaxTreeNode* body(GetIfClauseGenerateBody(generate_if)); + void DeclareGenerateIf(const SyntaxTreeNode &generate_if) { + const SyntaxTreeNode *body(GetIfClauseGenerateBody(generate_if)); if (body) { DeclareScopedElementAndDescend(generate_if, GetScopeNameFromGenerateBody(*body), @@ -1265,8 +1266,8 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void DeclareGenerateElse(const SyntaxTreeNode& generate_else) { - const SyntaxTreeNode* body(GetElseClauseGenerateBody(generate_else)); + void DeclareGenerateElse(const SyntaxTreeNode &generate_else) { + const SyntaxTreeNode *body(GetElseClauseGenerateBody(generate_else)); if (!body) return; if (body->MatchesTag(NodeEnum::kConditionalGenerateConstruct)) { @@ -1281,44 +1282,51 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void DeclarePackage(const SyntaxTreeNode& package) { - const auto* token = GetPackageNameToken(package); + void DeclarePackage(const SyntaxTreeNode &package) { + const auto *token = GetPackageNameToken(package); if (!token) return; DeclareScopedElementAndDescend(package, token->text(), SymbolMetaType::kPackage); } - void DeclareClass(const SyntaxTreeNode& class_node) { - const SyntaxTreeLeaf* class_name = GetClassName(class_node); + void DeclareClass(const SyntaxTreeNode &class_node) { + const SyntaxTreeLeaf *class_name = GetClassName(class_node); if (!class_name) return; DeclareScopedElementAndDescend(class_node, class_name->get().text(), SymbolMetaType::kClass); } - void DeclareTask(const SyntaxTreeNode& task_node) { - const ValueSaver reserve_for_task_decl( + void DeclareInterface(const SyntaxTreeNode &interface) { + const auto *token = GetInterfaceNameToken(interface); + if (!token) return; + DeclareScopedElementAndDescend(interface, token->text(), + SymbolMetaType::kInterface); + } + + void DeclareTask(const SyntaxTreeNode &task_node) { + const ValueSaver reserve_for_task_decl( ¤t_scope_); // no scope change yet Descend(task_node); } - void DeclareFunction(const SyntaxTreeNode& function_node) { + void DeclareFunction(const SyntaxTreeNode &function_node) { // Reserve a slot for the function's scope on the stack, but do not set it // until we add it in HandleIdentifier(). This deferral allows us to // evaluate the return type of the declared function as a reference in the // current context. - const ValueSaver reserve_for_function_decl( + const ValueSaver reserve_for_function_decl( ¤t_scope_); // no scope change yet Descend(function_node); } - void DeclareConstructor(const SyntaxTreeNode& constructor_node) { + void DeclareConstructor(const SyntaxTreeNode &constructor_node) { // Reserve a slot for the constructor's scope on the stack, but do not set // it until we add it in HandleIdentifier(). The effective return type of // the constructor is the class type. - const ValueSaver reserve_for_function_decl( + const ValueSaver reserve_for_function_decl( ¤t_scope_); // no scope change yet - const SyntaxTreeLeaf* new_keyword = + const SyntaxTreeLeaf *new_keyword = GetConstructorPrototypeNewKeyword(constructor_node); // Create a self-reference to this class. const ReferenceComponent class_type_ref{ @@ -1339,13 +1347,13 @@ class SymbolTable::Builder : public TreeContextVisitor { .syntax_origin = new_keyword, .user_defined_type = capture.Ref().LastLeaf(), }; - const ValueSaver function_return_type( + const ValueSaver function_return_type( &declaration_type_info_, &decl_type_info); Descend(constructor_node); } - void DeclarePorts(const SyntaxTreeNode& port_list) { + void DeclarePorts(const SyntaxTreeNode &port_list) { // For out-of-line function declarations, do not re-declare ports that // already came from the method prototype. // We designate the prototype as the source-of-truth because in Verilog, @@ -1354,12 +1362,12 @@ class SymbolTable::Builder : public TreeContextVisitor { // LRM 8.24: "The out-of-block method declaration shall match the prototype // declaration exactly, with the following exceptions..." { - const SyntaxTreeNode* function_header = - Context().NearestParentMatching([](const SyntaxTreeNode& node) { + const SyntaxTreeNode *function_header = + Context().NearestParentMatching([](const SyntaxTreeNode &node) { return node.MatchesTag(NodeEnum::kFunctionHeader); }); if (function_header != nullptr) { - const SyntaxTreeNode& id = verible::SymbolCastToNode( + const SyntaxTreeNode &id = verible::SymbolCastToNode( *ABSL_DIE_IF_NULL(GetFunctionHeaderId(*function_header))); if (id.MatchesTag(NodeEnum::kQualifiedId)) { // For now, ignore the out-of-line port declarations. @@ -1370,12 +1378,12 @@ class SymbolTable::Builder : public TreeContextVisitor { } } { - const SyntaxTreeNode* task_header = - Context().NearestParentMatching([](const SyntaxTreeNode& node) { + const SyntaxTreeNode *task_header = + Context().NearestParentMatching([](const SyntaxTreeNode &node) { return node.MatchesTag(NodeEnum::kTaskHeader); }); if (task_header != nullptr) { - const SyntaxTreeNode& id = verible::SymbolCastToNode( + const SyntaxTreeNode &id = verible::SymbolCastToNode( *ABSL_DIE_IF_NULL(GetTaskHeaderId(*task_header))); if (id.MatchesTag(NodeEnum::kQualifiedId)) { // For now, ignore the out-of-line port declarations. @@ -1390,9 +1398,9 @@ class SymbolTable::Builder : public TreeContextVisitor { } // Capture the declared function's return type. - void SetupFunctionHeader(const SyntaxTreeNode& function_header) { + void SetupFunctionHeader(const SyntaxTreeNode &function_header) { DeclarationTypeInfo decl_type_info; - const ValueSaver function_return_type( + const ValueSaver function_return_type( &declaration_type_info_, &decl_type_info); Descend(function_header); // decl_type_info will be safely copied away in HandleIdentifier(). @@ -1400,24 +1408,24 @@ class SymbolTable::Builder : public TreeContextVisitor { // TODO: functions and tasks, which could appear as out-of-line definitions. - void DeclareParameter(const SyntaxTreeNode& param_decl_node) { + void DeclareParameter(const SyntaxTreeNode ¶m_decl_node) { CHECK(param_decl_node.MatchesTag(NodeEnum::kParamDeclaration)); DeclarationTypeInfo decl_type_info; // Set declaration_type_info_ to capture any user-defined type used to // declare data/variables/instances. - const ValueSaver save_type(&declaration_type_info_, - &decl_type_info); + const ValueSaver save_type(&declaration_type_info_, + &decl_type_info); Descend(param_decl_node); } // Declares one or more variables/instances/nets. - void DeclareData(const SyntaxTreeNode& data_decl_node) { + void DeclareData(const SyntaxTreeNode &data_decl_node) { VLOG(2) << __FUNCTION__; DeclarationTypeInfo decl_type_info; // Set declaration_type_info_ to capture any user-defined type used to // declare data/variables/instances. - const ValueSaver save_type(&declaration_type_info_, - &decl_type_info); + const ValueSaver save_type(&declaration_type_info_, + &decl_type_info); // reset port direction Descend(data_decl_node); VLOG(2) << "end of " << __FUNCTION__; @@ -1425,12 +1433,12 @@ class SymbolTable::Builder : public TreeContextVisitor { // Declare one (of potentially multiple) instances in a single declaration // statement. - void DeclareInstance(const SyntaxTreeNode& instance) { - const verible::TokenInfo* instance_name_token = + void DeclareInstance(const SyntaxTreeNode &instance) { + const verible::TokenInfo *instance_name_token = GetModuleInstanceNameTokenInfoFromGateInstance(instance); if (!instance_name_token) return; const absl::string_view instance_name(instance_name_token->text()); - const SymbolTableNode& new_instance(EmplaceTypedElementInCurrentScope( + const SymbolTableNode &new_instance(EmplaceTypedElementInCurrentScope( instance, instance_name, SymbolMetaType::kDataNetVariableInstance)); // Also create a DependentReferences chain starting with this named instance @@ -1447,7 +1455,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // Inform that named port identifiers will yield parallel children from // this reference branch point. - const ValueSaver set_branch( + const ValueSaver set_branch( &reference_branch_point_, capture.Ref().components.get()); // No change of scope, but named ports will be resolved with respect to the @@ -1455,8 +1463,8 @@ class SymbolTable::Builder : public TreeContextVisitor { Descend(instance); // visit parameter/port connections, etc. } - void DeclareNet(const SyntaxTreeNode& net_variable) { - const SyntaxTreeLeaf* net_variable_name = + void DeclareNet(const SyntaxTreeNode &net_variable) { + const SyntaxTreeLeaf *net_variable_name = GetNameLeafOfNetVariable(net_variable); if (!net_variable_name) return; const absl::string_view net_name(net_variable_name->get().text()); @@ -1465,8 +1473,8 @@ class SymbolTable::Builder : public TreeContextVisitor { Descend(net_variable); } - void DeclareRegister(const SyntaxTreeNode& reg_variable) { - const SyntaxTreeLeaf* register_variable_name = + void DeclareRegister(const SyntaxTreeNode ®_variable) { + const SyntaxTreeLeaf *register_variable_name = GetNameLeafOfRegisterVariable(reg_variable); if (!register_variable_name) return; const absl::string_view net_name(register_variable_name->get().text()); @@ -1475,8 +1483,8 @@ class SymbolTable::Builder : public TreeContextVisitor { Descend(reg_variable); } - void DeclareVariable(const SyntaxTreeNode& variable) { - const SyntaxTreeLeaf* unqualified_id = + void DeclareVariable(const SyntaxTreeNode &variable) { + const SyntaxTreeLeaf *unqualified_id = GetUnqualifiedIdFromVariableDeclarationAssignment(variable); if (unqualified_id) { const absl::string_view var_name(unqualified_id->get().text()); @@ -1487,7 +1495,7 @@ class SymbolTable::Builder : public TreeContextVisitor { } void DiagnoseSymbolAlreadyExists(absl::string_view name, - const SymbolTableNode& previous_symbol) { + const SymbolTableNode &previous_symbol) { std::ostringstream here_print; here_print << source_->GetTextStructure()->GetRangeForText(name); @@ -1503,15 +1511,15 @@ class SymbolTable::Builder : public TreeContextVisitor { previous_print.str()))); } - absl::StatusOr LookupOrInjectOutOfLineDefinition( - const SyntaxTreeNode& qualified_id, SymbolMetaType metatype, - const SyntaxTreeNode* definition_syntax) { + absl::StatusOr LookupOrInjectOutOfLineDefinition( + const SyntaxTreeNode &qualified_id, SymbolMetaType metatype, + const SyntaxTreeNode *definition_syntax) { // e.g. "function int class_c::func(...); ... endfunction" // Use a DependentReference object to establish a self-reference. CaptureDependentReference capture(this); Descend(qualified_id); - DependentReferences& ref(capture.Ref()); + DependentReferences &ref(capture.Ref()); // Expecting only two-level reference "outer::inner". CHECK_EQ(ABSL_DIE_IF_NULL(ref.components)->Children().size(), 1); @@ -1523,16 +1531,16 @@ class SymbolTable::Builder : public TreeContextVisitor { if (!outer_scope_or_status.ok()) { return outer_scope_or_status.status(); } - SymbolTableNode* outer_scope = ABSL_DIE_IF_NULL(*outer_scope_or_status); + SymbolTableNode *outer_scope = ABSL_DIE_IF_NULL(*outer_scope_or_status); // Lookup inner symbol in outer_scope, but also allow injection of the // inner symbol name into the outer_scope (with diagnostic). - ReferenceComponent& inner_ref = ref.components->Children().front().Value(); + ReferenceComponent &inner_ref = ref.components->Children().front().Value(); const absl::string_view inner_key = inner_ref.identifier; const auto p = outer_scope->TryEmplace( inner_key, SymbolInfo{metatype, source_, definition_syntax}); - SymbolTableNode* inner_symbol = &p.first->second; + SymbolTableNode *inner_symbol = &p.first->second; if (p.second) { // If injection succeeded, then the outer_scope did not already contain a // forward declaration of the inner symbol to be defined. @@ -1556,9 +1564,9 @@ class SymbolTable::Builder : public TreeContextVisitor { return inner_symbol; // mutable for purpose of constructing definition } - void DescendThroughOutOfLineDefinition(const SyntaxTreeNode& qualified_id, + void DescendThroughOutOfLineDefinition(const SyntaxTreeNode &qualified_id, SymbolMetaType type, - const SyntaxTreeNode* decl_syntax) { + const SyntaxTreeNode *decl_syntax) { const auto inner_symbol_or_status = LookupOrInjectOutOfLineDefinition(qualified_id, type, decl_syntax); // Change the current scope (which was set up on the stack by @@ -1574,11 +1582,11 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void HandleQualifiedId(const SyntaxTreeNode& qualified_id) { + void HandleQualifiedId(const SyntaxTreeNode &qualified_id) { switch (static_cast(Context().top().Tag().tag)) { case NodeEnum::kFunctionHeader: { - const SyntaxTreeNode* decl_syntax = - Context().NearestParentMatching([](const SyntaxTreeNode& node) { + const SyntaxTreeNode *decl_syntax = + Context().NearestParentMatching([](const SyntaxTreeNode &node) { return node.MatchesTagAnyOf({NodeEnum::kFunctionDeclaration, NodeEnum::kFunctionPrototype}); }); @@ -1588,8 +1596,8 @@ class SymbolTable::Builder : public TreeContextVisitor { break; } case NodeEnum::kTaskHeader: { - const SyntaxTreeNode* decl_syntax = - Context().NearestParentMatching([](const SyntaxTreeNode& node) { + const SyntaxTreeNode *decl_syntax = + Context().NearestParentMatching([](const SyntaxTreeNode &node) { return node.MatchesTagAnyOf( {NodeEnum::kTaskDeclaration, NodeEnum::kTaskPrototype}); }); @@ -1604,8 +1612,8 @@ class SymbolTable::Builder : public TreeContextVisitor { } } - void EnterIncludeFile(const SyntaxTreeNode& preprocessor_include) { - const SyntaxTreeLeaf* included_filename = + void EnterIncludeFile(const SyntaxTreeNode &preprocessor_include) { + const SyntaxTreeLeaf *included_filename = GetFileFromPreprocessorInclude(preprocessor_include); if (included_filename == nullptr) return; @@ -1617,7 +1625,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // Opening included file requires a VerilogProject. // Open this file (could be first time, or previously opened). - VerilogProject* project = symbol_table_->project_; + VerilogProject *project = symbol_table_->project_; if (project == nullptr) return; // Without project, ignore. const auto status_or_file = project->OpenIncludedFile(filename_unquoted); @@ -1627,7 +1635,7 @@ class SymbolTable::Builder : public TreeContextVisitor { return; } - VerilogSourceFile* const included_file = *status_or_file; + VerilogSourceFile *const included_file = *status_or_file; if (included_file == nullptr) return; VLOG(3) << "opened include file: " << included_file->ResolvedPath(); @@ -1643,8 +1651,8 @@ class SymbolTable::Builder : public TreeContextVisitor { // included file. If desired, add logic to return early here. { // Traverse included file's syntax tree. - const ValueSaver includer(&source_, - included_file); + const ValueSaver includer(&source_, + included_file); const ValueSaver save_context_text( &token_context_, MakeTokenContext()); included_file->GetTextStructure()->SyntaxTree()->Accept(this); @@ -1655,21 +1663,21 @@ class SymbolTable::Builder : public TreeContextVisitor { return ContextFullPath(*current_scope_); } - verible::TokenWithContext VerboseToken(const TokenInfo& token) const { + verible::TokenWithContext VerboseToken(const TokenInfo &token) const { return verible::TokenWithContext{token, token_context_}; } TokenInfo::Context MakeTokenContext() const { return TokenInfo::Context( source_->GetTextStructure()->Contents(), - [](std::ostream& stream, int e) { stream << verilog_symbol_name(e); }); + [](std::ostream &stream, int e) { stream << verilog_symbol_name(e); }); } private: // data // Points to the source file that is the origin of symbols. // This changes when opening preprocess-included files. // TODO(fangism): maintain a vector/stack of these for richer diagnostics - const VerilogSourceFile* source_; + const VerilogSourceFile *source_; // For human-readable debugging. // This should be constructed using MakeTokenContext(), after setting @@ -1677,7 +1685,7 @@ class SymbolTable::Builder : public TreeContextVisitor { TokenInfo::Context token_context_; // The symbol table to build, never nullptr. - SymbolTable* const symbol_table_; + SymbolTable *const symbol_table_; // The remaining fields are mutable state: @@ -1685,7 +1693,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // symbols, never nullptr. // There is no need to maintain a stack because SymbolTableNodes already link // to their parents. - SymbolTableNode* current_scope_; + SymbolTableNode *current_scope_; // Stack of references. // A stack is needed to support nested type references like "A#(B(#(C)))", @@ -1696,7 +1704,7 @@ class SymbolTable::Builder : public TreeContextVisitor { // set this to the nearest branch point. // This will signal to the reference builder that parallel children // are to be added, as opposed to deeper descendants. - ReferenceComponentNode* reference_branch_point_ = nullptr; + ReferenceComponentNode *reference_branch_point_ = nullptr; // For a data/instance/variable declaration statement, this is the declared // type (could be primitive or named-user-defined). @@ -1705,10 +1713,10 @@ class SymbolTable::Builder : public TreeContextVisitor { // Set this type before traversing declared instances and variables to capture // the type of the declaration. Unset this to prevent type capture. // Such declarations cannot nest, so a stack is not needed. - DeclarationTypeInfo* declaration_type_info_ = nullptr; + DeclarationTypeInfo *declaration_type_info_ = nullptr; // Update to either "::" or '.'. - const TokenInfo* last_hierarchy_operator_ = nullptr; + const TokenInfo *last_hierarchy_operator_ = nullptr; // Collection of findings that might be considered compiler/tool errors in a // real toolchain. For example: attempt to redefine symbol. @@ -1716,7 +1724,7 @@ class SymbolTable::Builder : public TreeContextVisitor { }; void ReferenceComponent::VerifySymbolTableRoot( - const SymbolTableNode* root) const { + const SymbolTableNode *root) const { if (resolved_symbol != nullptr) { CHECK_EQ(resolved_symbol->Root(), root) << "Resolved symbols must point to a node in the same SymbolTable."; @@ -1753,7 +1761,7 @@ absl::Status ReferenceComponent::MatchesMetatype( } absl::Status ReferenceComponent::ResolveSymbol( - const SymbolTableNode& resolved) { + const SymbolTableNode &resolved) { // Verify metatype match. if (auto metatype_match_status = MatchesMetatype(resolved.Value().metatype); !metatype_match_status.ok()) { @@ -1766,25 +1774,25 @@ absl::Status ReferenceComponent::ResolveSymbol( return absl::OkStatus(); } -const ReferenceComponentNode* DependentReferences::LastLeaf() const { +const ReferenceComponentNode *DependentReferences::LastLeaf() const { if (components == nullptr) return nullptr; - const ReferenceComponentNode* node = components.get(); + const ReferenceComponentNode *node = components.get(); while (!is_leaf(*node)) node = &node->Children().front(); return node; } // RefType can be ReferenceComponentNode or const ReferenceComponentNode. template -static RefType* ReferenceLastTypeComponent(RefType* node) { +static RefType *ReferenceLastTypeComponent(RefType *node) { // This references a type that may be nested and have name parameters. // From A#(.B())::C#(.D()), we want C as the desired type component. while (!is_leaf(*node)) { // There should be at most one non-parameter at each branch point, // so stop at the first one found. // In the above example, this would find "C" among {"B", "C"} inside "A". - auto& branches(node->Children()); + auto &branches(node->Children()); const auto found = std::find_if( - branches.begin(), branches.end(), [](const ReferenceComponentNode& n) { + branches.begin(), branches.end(), [](const ReferenceComponentNode &n) { return n.Value().required_metatype != SymbolMetaType::kParameter; }); // If there are only parameters referenced, then this code is the last @@ -1796,31 +1804,31 @@ static RefType* ReferenceLastTypeComponent(RefType* node) { return node; } -const ReferenceComponentNode* DependentReferences::LastTypeComponent() const { +const ReferenceComponentNode *DependentReferences::LastTypeComponent() const { // This references a type that may be nested and have name parameters. // From A#(.B())::C#(.D()), we want C as the desired type component. if (components == nullptr) return nullptr; - const ReferenceComponentNode* node = components.get(); + const ReferenceComponentNode *node = components.get(); return ReferenceLastTypeComponent(node); } -ReferenceComponentNode* DependentReferences::LastTypeComponent() { +ReferenceComponentNode *DependentReferences::LastTypeComponent() { if (components == nullptr) return nullptr; - ReferenceComponentNode* node = components.get(); + ReferenceComponentNode *node = components.get(); return ReferenceLastTypeComponent(node); } -ReferenceComponentNode* DependentReferences::PushReferenceComponent( - const ReferenceComponent& component) { +ReferenceComponentNode *DependentReferences::PushReferenceComponent( + const ReferenceComponent &component) { VLOG(3) << __FUNCTION__ << ", id: " << component.identifier; - ReferenceComponentNode* new_child; + ReferenceComponentNode *new_child; if (Empty()) { components = std::make_unique(component); // copy new_child = components.get(); } else { // Find the last node from which references can be grown. // Exclude type named parameters. - ReferenceComponentNode* node = LastTypeComponent(); + ReferenceComponentNode *node = LastTypeComponent(); new_child = CheckedNewChildReferenceNode(node, component); } VLOG(3) << "end of " << __FUNCTION__ << ":\n" << *this; @@ -1828,29 +1836,29 @@ ReferenceComponentNode* DependentReferences::PushReferenceComponent( } void DependentReferences::VerifySymbolTableRoot( - const SymbolTableNode* root) const { + const SymbolTableNode *root) const { if (components != nullptr) { - ApplyPreOrder(*components, [=](const ReferenceComponent& component) { + ApplyPreOrder(*components, [=](const ReferenceComponent &component) { component.VerifySymbolTableRoot(root); }); } } -std::ostream& operator<<(std::ostream& stream, - const DependentReferences& dep_refs) { +std::ostream &operator<<(std::ostream &stream, + const DependentReferences &dep_refs) { if (dep_refs.components == nullptr) return stream << "(empty-ref)"; return stream << *dep_refs.components; } // Follow type aliases through canonical type. -static const SymbolTableNode* CanonicalizeTypeForMemberLookup( - const SymbolTableNode& context) { +static const SymbolTableNode *CanonicalizeTypeForMemberLookup( + const SymbolTableNode &context) { VLOG(2) << __FUNCTION__; - const SymbolTableNode* current_context = &context; + const SymbolTableNode *current_context = &context; do { VLOG(2) << " -> " << ContextFullPath(*current_context); if (current_context->Value().metatype != SymbolMetaType::kTypeAlias) break; - const ReferenceComponentNode* ref_type = + const ReferenceComponentNode *ref_type = current_context->Value().declared_type.user_defined_type; if (ref_type == nullptr) { // Could be a primitive type. @@ -1867,9 +1875,9 @@ static const SymbolTableNode* CanonicalizeTypeForMemberLookup( } // Search through base class's scopes for a symbol. -static const SymbolTableNode* LookupSymbolThroughInheritedScopes( - const SymbolTableNode& context, absl::string_view symbol) { - const SymbolTableNode* current_context = &context; +static const SymbolTableNode *LookupSymbolThroughInheritedScopes( + const SymbolTableNode &context, absl::string_view symbol) { + const SymbolTableNode *current_context = &context; do { // Look directly in current scope. const auto found = current_context->Find(symbol); @@ -1879,11 +1887,11 @@ static const SymbolTableNode* LookupSymbolThroughInheritedScopes( // TODO: lookup imported namespaces and symbols // Point to next inherited scope. - const auto* base_type = + const auto *base_type = current_context->Value().parent_type.user_defined_type; if (base_type == nullptr) break; - const SymbolTableNode* resolved_base = base_type->Value().resolved_symbol; + const SymbolTableNode *resolved_base = base_type->Value().resolved_symbol; // TODO: attempt to resolve on-demand because resolve ordering is not // guaranteed. if (resolved_base == nullptr) return nullptr; @@ -1895,11 +1903,11 @@ static const SymbolTableNode* LookupSymbolThroughInheritedScopes( } // Search up-scope, stopping at the first symbol found in the nearest scope. -static const SymbolTableNode* LookupSymbolUpwards( - const SymbolTableNode& context, absl::string_view symbol) { - const SymbolTableNode* current_context = &context; +static const SymbolTableNode *LookupSymbolUpwards( + const SymbolTableNode &context, absl::string_view symbol) { + const SymbolTableNode *current_context = &context; do { - const SymbolTableNode* found = + const SymbolTableNode *found = LookupSymbolThroughInheritedScopes(*current_context, symbol); if (found != nullptr) return found; @@ -1910,15 +1918,15 @@ static const SymbolTableNode* LookupSymbolUpwards( } static absl::Status DiagnoseUnqualifiedSymbolResolutionFailure( - absl::string_view name, const SymbolTableNode& context) { + absl::string_view name, const SymbolTableNode &context) { return absl::NotFoundError(absl::StrCat("Unable to resolve symbol \"", name, "\" from context ", ContextFullPath(context), ".")); } -static void ResolveReferenceComponentNodeLocal(ReferenceComponentNode* node, - const SymbolTableNode& context) { - ReferenceComponent& component(node->Value()); +static void ResolveReferenceComponentNodeLocal(ReferenceComponentNode *node, + const SymbolTableNode &context) { + ReferenceComponent &component(node->Value()); VLOG(2) << __FUNCTION__ << ": " << component; // If already resolved, skip. if (component.resolved_symbol != nullptr) return; // already bound @@ -1935,13 +1943,13 @@ static void ResolveReferenceComponentNodeLocal(ReferenceComponentNode* node, } } -static void ResolveUnqualifiedName(ReferenceComponent* component, - const SymbolTableNode& context, - std::vector* diagnostics) { +static void ResolveUnqualifiedName(ReferenceComponent *component, + const SymbolTableNode &context, + std::vector *diagnostics) { VLOG(2) << __FUNCTION__ << ": " << component; const absl::string_view key(component->identifier); // Find the first symbol whose name matches, without regard to its metatype. - const SymbolTableNode* resolved = LookupSymbolUpwards(context, key); + const SymbolTableNode *resolved = LookupSymbolUpwards(context, key); if (resolved == nullptr) { diagnostics->emplace_back( DiagnoseUnqualifiedSymbolResolutionFailure(key, context)); @@ -1957,9 +1965,9 @@ static void ResolveUnqualifiedName(ReferenceComponent* component, // Search this scope directly for a symbol, without any upward/inheritance // lookups. -static void ResolveImmediateMember(ReferenceComponent* component, - const SymbolTableNode& context, - std::vector* diagnostics) { +static void ResolveImmediateMember(ReferenceComponent *component, + const SymbolTableNode &context, + std::vector *diagnostics) { VLOG(2) << __FUNCTION__ << ": " << component; const absl::string_view key(component->identifier); const auto found = context.Find(key); @@ -1969,7 +1977,7 @@ static void ResolveImmediateMember(ReferenceComponent* component, return; } - const SymbolTableNode& found_symbol = found->second; + const SymbolTableNode &found_symbol = found->second; const auto resolve_status = component->ResolveSymbol(found_symbol); if (!resolve_status.ok()) { diagnostics->push_back(resolve_status); @@ -1977,13 +1985,13 @@ static void ResolveImmediateMember(ReferenceComponent* component, VLOG(2) << "end of " << __FUNCTION__; } -static void ResolveDirectMember(ReferenceComponent* component, - const SymbolTableNode& context, - std::vector* diagnostics) { +static void ResolveDirectMember(ReferenceComponent *component, + const SymbolTableNode &context, + std::vector *diagnostics) { VLOG(2) << __FUNCTION__ << ": " << component; // Canonicalize context if it an alias. - const SymbolTableNode* canonical_context = + const SymbolTableNode *canonical_context = CanonicalizeTypeForMemberLookup(context); if (canonical_context == nullptr) { // TODO: diagnostic could be improved by following each typedef indirection. @@ -1994,7 +2002,7 @@ static void ResolveDirectMember(ReferenceComponent* component, } const absl::string_view key(component->identifier); - const auto* found = + const auto *found = LookupSymbolThroughInheritedScopes(*canonical_context, key); if (found == nullptr) { diagnostics->emplace_back( @@ -2002,7 +2010,7 @@ static void ResolveDirectMember(ReferenceComponent* component, return; } - const SymbolTableNode& found_symbol = *found; + const SymbolTableNode &found_symbol = *found; const auto resolve_status = component->ResolveSymbol(found_symbol); if (!resolve_status.ok()) { diagnostics->push_back(resolve_status); @@ -2015,9 +2023,9 @@ static void ResolveDirectMember(ReferenceComponent* component, // resolve children references (guaranteed by calling this in a pre-order // traversal). static void ResolveReferenceComponentNode( - ReferenceComponentNode* node, const SymbolTableNode& context, - std::vector* diagnostics) { - ReferenceComponent& component(node->Value()); + ReferenceComponentNode *node, const SymbolTableNode &context, + std::vector *diagnostics) { + ReferenceComponent &component(node->Value()); VLOG(2) << __FUNCTION__ << ": " << component; if (component.resolved_symbol != nullptr) return; // already bound @@ -2039,9 +2047,9 @@ static void ResolveReferenceComponentNode( } case ReferenceType::kDirectMember: { // Use parent's scope (if resolved successfully) to resolve this node. - const ReferenceComponent& parent_component(node->Parent()->Value()); + const ReferenceComponent &parent_component(node->Parent()->Value()); - const SymbolTableNode* parent_scope = parent_component.resolved_symbol; + const SymbolTableNode *parent_scope = parent_component.resolved_symbol; if (parent_scope == nullptr) return; // leave this subtree unresolved ResolveDirectMember(&component, *parent_scope, diagnostics); @@ -2050,11 +2058,11 @@ static void ResolveReferenceComponentNode( case ReferenceType::kMemberOfTypeOfParent: { // Use parent's type's scope (if resolved successfully) to resolve this // node. Get the type of the object from the parent component. - const ReferenceComponent& parent_component(node->Parent()->Value()); - const SymbolTableNode* parent_scope = parent_component.resolved_symbol; + const ReferenceComponent &parent_component(node->Parent()->Value()); + const SymbolTableNode *parent_scope = parent_component.resolved_symbol; if (parent_scope == nullptr) return; // leave this subtree unresolved - const DeclarationTypeInfo& type_info = + const DeclarationTypeInfo &type_info = parent_scope->Value().declared_type; // Primitive types do not have members. if (type_info.user_defined_type == nullptr) { @@ -2077,7 +2085,7 @@ static void ResolveReferenceComponentNode( // This referenced object's scope is not a parent of this node, and // thus, not guaranteed to have been resolved first. // TODO(fangism): resolve on-demand - const SymbolTableNode* type_scope = + const SymbolTableNode *type_scope = type_info.user_defined_type->Value().resolved_symbol; if (type_scope == nullptr) return; @@ -2089,24 +2097,24 @@ static void ResolveReferenceComponentNode( } ReferenceComponentMap ReferenceComponentNodeMapView( - const ReferenceComponentNode& node) { + const ReferenceComponentNode &node) { ReferenceComponentMap map_view; - for (const auto& child : node.Children()) { + for (const auto &child : node.Children()) { map_view.emplace(std::make_pair(child.Value().identifier, &child)); } return map_view; } void DependentReferences::Resolve( - const SymbolTableNode& context, - std::vector* diagnostics) const { + const SymbolTableNode &context, + std::vector *diagnostics) const { VLOG(2) << __FUNCTION__; if (components == nullptr) return; // References are arranged in dependency trees. // Parent node references must be resolved before children nodes, // hence a pre-order traversal. ApplyPreOrder(*components, - [&context, diagnostics](ReferenceComponentNode& node) { + [&context, diagnostics](ReferenceComponentNode &node) { ResolveReferenceComponentNode(&node, context, diagnostics); // TODO: minor optimization, when resolution for a node fails, // skip checking that node's subtree; early terminate. @@ -2114,18 +2122,18 @@ void DependentReferences::Resolve( VLOG(2) << "end of " << __FUNCTION__; } -void DependentReferences::ResolveLocally(const SymbolTableNode& context) const { +void DependentReferences::ResolveLocally(const SymbolTableNode &context) const { if (components == nullptr) return; // Only attempt to resolve the reference root, and none of its subtrees. ResolveReferenceComponentNodeLocal(components.get(), context); } -absl::StatusOr DependentReferences::ResolveOnlyBaseLocally( - SymbolTableNode* context) { +absl::StatusOr DependentReferences::ResolveOnlyBaseLocally( + SymbolTableNode *context) { // Similar lookup to ResolveReferenceComponentNodeLocal() but allows // mutability of 'context' for injecting out-of-line definitions. - ReferenceComponent& base(ABSL_DIE_IF_NULL(components)->Value()); + ReferenceComponent &base(ABSL_DIE_IF_NULL(components)->Value()); CHECK(base.ref_type == ReferenceType::kUnqualified || base.ref_type == ReferenceType::kImmediate) << "Inconsistent reference type: " << base.ref_type; @@ -2134,7 +2142,7 @@ absl::StatusOr DependentReferences::ResolveOnlyBaseLocally( if (found == context->end()) { return DiagnoseMemberSymbolResolutionFailure(key, *context); } - SymbolTableNode& resolved = found->second; + SymbolTableNode &resolved = found->second; // If metatype doesn't match what is expected, then fail. if (absl::Status status = base.ResolveSymbol(resolved); !status.ok()) { @@ -2143,7 +2151,7 @@ absl::StatusOr DependentReferences::ResolveOnlyBaseLocally( return &resolved; } -std::ostream& operator<<(std::ostream& stream, ReferenceType ref_type) { +std::ostream &operator<<(std::ostream &stream, ReferenceType ref_type) { static const verible::EnumNameMap kReferenceTypeNames({ // short-hand annotation for identifier reference type {"@", ReferenceType::kUnqualified}, @@ -2154,8 +2162,8 @@ std::ostream& operator<<(std::ostream& stream, ReferenceType ref_type) { return kReferenceTypeNames.Unparse(ref_type, stream); } -std::ostream& ReferenceComponent::PrintPathComponent( - std::ostream& stream) const { +std::ostream &ReferenceComponent::PrintPathComponent( + std::ostream &stream) const { stream << ref_type << identifier; if (required_metatype != SymbolMetaType::kUnspecified) { stream << '[' << required_metatype << ']'; @@ -2163,7 +2171,7 @@ std::ostream& ReferenceComponent::PrintPathComponent( return stream; } -std::ostream& ReferenceComponent::PrintVerbose(std::ostream& stream) const { +std::ostream &ReferenceComponent::PrintVerbose(std::ostream &stream) const { PrintPathComponent(stream) << " -> "; if (resolved_symbol == nullptr) { return stream << ""; @@ -2171,15 +2179,15 @@ std::ostream& ReferenceComponent::PrintVerbose(std::ostream& stream) const { return stream << ContextFullPath(*resolved_symbol); } -std::ostream& operator<<(std::ostream& stream, - const ReferenceComponent& component) { +std::ostream &operator<<(std::ostream &stream, + const ReferenceComponent &component) { return component.PrintVerbose(stream); } void DeclarationTypeInfo::VerifySymbolTableRoot( - const SymbolTableNode* root) const { + const SymbolTableNode *root) const { if (user_defined_type != nullptr) { - ApplyPreOrder(*user_defined_type, [=](const ReferenceComponent& component) { + ApplyPreOrder(*user_defined_type, [=](const ReferenceComponent &component) { component.VerifySymbolTableRoot(root); }); } @@ -2194,8 +2202,8 @@ absl::string_view SymbolInfo::CreateAnonymousScope(absl::string_view base) { return *anonymous_scope_names.back(); } -std::ostream& operator<<(std::ostream& stream, - const DeclarationTypeInfo& decl_type_info) { +std::ostream &operator<<(std::ostream &stream, + const DeclarationTypeInfo &decl_type_info) { stream << "type-info { "; stream << "source: "; @@ -2223,27 +2231,27 @@ std::ostream& operator<<(std::ostream& stream, return stream << " }"; } -void SymbolInfo::VerifySymbolTableRoot(const SymbolTableNode* root) const { +void SymbolInfo::VerifySymbolTableRoot(const SymbolTableNode *root) const { declared_type.VerifySymbolTableRoot(root); - for (const auto& local_ref : local_references_to_bind) { + for (const auto &local_ref : local_references_to_bind) { local_ref.VerifySymbolTableRoot(root); } } -void SymbolInfo::Resolve(const SymbolTableNode& context, - std::vector* diagnostics) { - for (auto& local_ref : local_references_to_bind) { +void SymbolInfo::Resolve(const SymbolTableNode &context, + std::vector *diagnostics) { + for (auto &local_ref : local_references_to_bind) { local_ref.Resolve(context, diagnostics); } } -void SymbolInfo::ResolveLocally(const SymbolTableNode& context) { - for (auto& local_ref : local_references_to_bind) { +void SymbolInfo::ResolveLocally(const SymbolTableNode &context) { + for (auto &local_ref : local_references_to_bind) { local_ref.ResolveLocally(context); } } -std::ostream& SymbolInfo::PrintDefinition(std::ostream& stream, +std::ostream &SymbolInfo::PrintDefinition(std::ostream &stream, size_t indent) const { // print everything except local_references_to_bind const verible::Spacer wrap(indent); @@ -2259,7 +2267,7 @@ std::ostream& SymbolInfo::PrintDefinition(std::ostream& stream, return stream; } -std::ostream& SymbolInfo::PrintReferences(std::ostream& stream, +std::ostream &SymbolInfo::PrintReferences(std::ostream &stream, size_t indent) const { // only print local_references_to_bind // TODO: support indentation @@ -2281,7 +2289,7 @@ std::ostream& SymbolInfo::PrintReferences(std::ostream& stream, SymbolInfo::references_map_view_type SymbolInfo::LocalReferencesMapViewForTesting() const { references_map_view_type map_view; - for (const auto& local_ref : local_references_to_bind) { + for (const auto &local_ref : local_references_to_bind) { CHECK(!local_ref.Empty()) << "Never add empty DependentReferences."; map_view[local_ref.components->Value().identifier].emplace(&local_ref); } @@ -2289,45 +2297,45 @@ SymbolInfo::LocalReferencesMapViewForTesting() const { } void SymbolTable::CheckIntegrity() const { - const SymbolTableNode* root = &symbol_table_root_; + const SymbolTableNode *root = &symbol_table_root_; symbol_table_root_.ApplyPreOrder( - [=](const SymbolInfo& s) { s.VerifySymbolTableRoot(root); }); + [=](const SymbolInfo &s) { s.VerifySymbolTableRoot(root); }); } -void SymbolTable::Resolve(std::vector* diagnostics) { +void SymbolTable::Resolve(std::vector *diagnostics) { const absl::Time start = absl::Now(); symbol_table_root_.ApplyPreOrder( - [=](SymbolTableNode& node) { node.Value().Resolve(node, diagnostics); }); + [=](SymbolTableNode &node) { node.Value().Resolve(node, diagnostics); }); VLOG(1) << "SymbolTable::Resolve took " << (absl::Now() - start); } void SymbolTable::ResolveLocallyOnly() { symbol_table_root_.ApplyPreOrder( - [=](SymbolTableNode& node) { node.Value().ResolveLocally(node); }); + [=](SymbolTableNode &node) { node.Value().ResolveLocally(node); }); } -std::ostream& SymbolTable::PrintSymbolDefinitions(std::ostream& stream) const { +std::ostream &SymbolTable::PrintSymbolDefinitions(std::ostream &stream) const { return symbol_table_root_.PrintTree( stream, - [](std::ostream& s, const SymbolInfo& sym, - size_t indent) -> std::ostream& { + [](std::ostream &s, const SymbolInfo &sym, + size_t indent) -> std::ostream & { return sym.PrintDefinition(s << std::endl, indent + 4 /* wrap */) << verible::Spacer(indent); }); } -std::ostream& SymbolTable::PrintSymbolReferences(std::ostream& stream) const { +std::ostream &SymbolTable::PrintSymbolReferences(std::ostream &stream) const { return symbol_table_root_.PrintTree(stream, - [](std::ostream& s, const SymbolInfo& sym, - size_t indent) -> std::ostream& { + [](std::ostream &s, const SymbolInfo &sym, + size_t indent) -> std::ostream & { return sym.PrintReferences( s, indent + 4 /* wrap */); }); } static void ParseFileAndBuildSymbolTable( - VerilogSourceFile* source, SymbolTable* symbol_table, - VerilogProject* project, std::vector* diagnostics) { + VerilogSourceFile *source, SymbolTable *symbol_table, + VerilogProject *project, std::vector *diagnostics) { const auto parse_status = source->Parse(); if (!parse_status.ok()) diagnostics->push_back(parse_status); // Continue, in case syntax-error recovery left a partial syntax tree. @@ -2339,9 +2347,9 @@ static void ParseFileAndBuildSymbolTable( diagnostics->insert(diagnostics->end(), statuses.begin(), statuses.end()); } -void SymbolTable::Build(std::vector* diagnostics) { +void SymbolTable::Build(std::vector *diagnostics) { const absl::Time start = absl::Now(); - for (auto& translation_unit : *project_) { + for (auto &translation_unit : *project_) { ParseFileAndBuildSymbolTable(translation_unit.second.get(), this, project_, diagnostics); } @@ -2350,25 +2358,25 @@ void SymbolTable::Build(std::vector* diagnostics) { void SymbolTable::BuildSingleTranslationUnit( absl::string_view referenced_file_name, - std::vector* diagnostics) { + std::vector *diagnostics) { const auto translation_unit_or_status = project_->OpenTranslationUnit(referenced_file_name); if (!translation_unit_or_status.ok()) { diagnostics->push_back(translation_unit_or_status.status()); return; } - VerilogSourceFile* translation_unit = *translation_unit_or_status; + VerilogSourceFile *translation_unit = *translation_unit_or_status; ParseFileAndBuildSymbolTable(translation_unit, this, project_, diagnostics); } -std::vector BuildSymbolTable(const VerilogSourceFile& source, - SymbolTable* symbol_table, - VerilogProject* project) { +std::vector BuildSymbolTable(const VerilogSourceFile &source, + SymbolTable *symbol_table, + VerilogProject *project) { VLOG(2) << __FUNCTION__ << " " << source.ResolvedPath(); - const auto* text_structure = source.GetTextStructure(); + const auto *text_structure = source.GetTextStructure(); if (text_structure == nullptr) return std::vector(); - const auto& syntax_tree = text_structure->SyntaxTree(); + const auto &syntax_tree = text_structure->SyntaxTree(); if (syntax_tree == nullptr) return std::vector(); SymbolTable::Builder builder(source, symbol_table, project); diff --git a/verilog/analysis/symbol_table_test.cc b/verilog/analysis/symbol_table_test.cc index 2f2716b44..a1baaedb1 100644 --- a/verilog/analysis/symbol_table_test.cc +++ b/verilog/analysis/symbol_table_test.cc @@ -41,7 +41,7 @@ namespace verilog { // Directly test some SymbolTable internals. class SymbolTable::Tester : public SymbolTable { public: - explicit Tester(VerilogProject* project) : SymbolTable(project) {} + explicit Tester(VerilogProject *project) : SymbolTable(project) {} using SymbolTable::MutableRoot; }; @@ -60,11 +60,11 @@ using verible::file::testing::ScopedTestFile; using TestVerilogSourceFile = InMemoryVerilogSourceFile; struct ScopePathPrinter { - const SymbolTableNode& node; + const SymbolTableNode &node; }; -static std::ostream& operator<<(std::ostream& stream, - const ScopePathPrinter& p) { +static std::ostream &operator<<(std::ostream &stream, + const ScopePathPrinter &p) { return SymbolTableNodeFullPath(stream, p.node); } @@ -75,7 +75,7 @@ static std::ostream& operator<<(std::ostream& stream, const auto found_##dest(map.find(key)); /* iterator */ \ ASSERT_NE(found_##dest, map.end()) \ << "No element at \"" << key << "\" in " #map; \ - const auto& dest ABSL_ATTRIBUTE_UNUSED( \ + const auto &dest ABSL_ATTRIBUTE_UNUSED( \ found_##dest->second); /* mapped_type */ // Assert that container is not empty, and reference its first element. @@ -83,14 +83,14 @@ static std::ostream& operator<<(std::ostream& stream, // Defined as a macro for meaningful line numbers on failure. #define ASSIGN_MUST_HAVE_FIRST_ELEMENT(dest, container) \ ASSERT_FALSE(container.empty()); \ - const auto& dest(*container.begin()); + const auto &dest(*container.begin()); // Assert that container has exactly one-element, and reference it. // Works on any container with .size() and .begin(). // Defined as a macro for meaningful line numbers on failure. #define ASSIGN_MUST_HAVE_UNIQUE(dest, container) \ ASSERT_EQ(container.size(), 1); \ - const auto& dest(*container.begin()); + const auto &dest(*container.begin()); // Shorthand for asserting that a symbol table lookup from // (const SymbolTableNode& scope) using (absl::string_view key) must succeed, @@ -104,8 +104,8 @@ static std::ostream& operator<<(std::ostream& stream, ASSERT_NE(found_##dest, (scope).end()) \ << "No symbol at \"" << key << "\" in " << ScopePathPrinter{scope}; \ EXPECT_EQ(found_##dest->first, key); \ - const SymbolTableNode& dest(found_##dest->second); \ - const SymbolInfo& dest##_info ABSL_ATTRIBUTE_UNUSED(dest.Value()) + const SymbolTableNode &dest(found_##dest->second); \ + const SymbolInfo &dest##_info ABSL_ATTRIBUTE_UNUSED(dest.Value()) // For SymbolInfo::references_map_view_type only: Assert that there is exactly // one element at 'key' in 'map' and assign it to 'dest' (DependentReferences). @@ -153,7 +153,7 @@ TEST(ReferenceComponentTest, MatchesMetatypeTest) { .identifier = "", .ref_type = ReferenceType::kUnqualified, .required_metatype = SymbolMetaType::kUnspecified}; - for (const auto& other : + for (const auto &other : {SymbolMetaType::kUnspecified, SymbolMetaType::kParameter, SymbolMetaType::kFunction, SymbolMetaType::kTask}) { const auto status = component.MatchesMetatype(other); @@ -165,12 +165,12 @@ TEST(ReferenceComponentTest, MatchesMetatypeTest) { .identifier = "", .ref_type = ReferenceType::kUnqualified, .required_metatype = SymbolMetaType::kCallable}; - for (const auto& other : + for (const auto &other : {SymbolMetaType::kFunction, SymbolMetaType::kTask}) { const auto status = component.MatchesMetatype(other); EXPECT_TRUE(status.ok()) << status.message(); } - for (const auto& other : {SymbolMetaType::kModule, SymbolMetaType::kPackage, + for (const auto &other : {SymbolMetaType::kModule, SymbolMetaType::kPackage, SymbolMetaType::kClass}) { const auto status = component.MatchesMetatype(other); EXPECT_FALSE(status.ok()) @@ -182,12 +182,12 @@ TEST(ReferenceComponentTest, MatchesMetatypeTest) { .identifier = "", .ref_type = ReferenceType::kUnqualified, .required_metatype = SymbolMetaType::kClass}; - for (const auto& other : + for (const auto &other : {SymbolMetaType::kClass, SymbolMetaType::kTypeAlias}) { const auto status = component.MatchesMetatype(other); EXPECT_TRUE(status.ok()) << status.message(); } - for (const auto& other : + for (const auto &other : {SymbolMetaType::kModule, SymbolMetaType::kPackage, SymbolMetaType::kFunction, SymbolMetaType::kTask}) { const auto status = component.MatchesMetatype(other); @@ -201,7 +201,7 @@ TEST(ReferenceComponentTest, MatchesMetatypeTest) { .ref_type = ReferenceType::kUnqualified, .required_metatype = SymbolMetaType::kFunction}; - for (const auto& other : + for (const auto &other : {SymbolMetaType::kUnspecified, SymbolMetaType::kParameter, SymbolMetaType::kModule, SymbolMetaType::kTask, SymbolMetaType::kClass}) { @@ -389,8 +389,8 @@ TEST(SymbolTablePrintTest, PrintClass) { TEST(BuildSymbolTableTest, IntegrityCheckResolvedSymbol) { const auto test_func = []() { SymbolTable::Tester symbol_table_1(nullptr), symbol_table_2(nullptr); - SymbolTableNode& root1(symbol_table_1.MutableRoot()); - SymbolTableNode& root2(symbol_table_2.MutableRoot()); + SymbolTableNode &root1(symbol_table_1.MutableRoot()); + SymbolTableNode &root2(symbol_table_2.MutableRoot()); // Deliberately point from one symbol table to the other. // To avoid an use-after-free AddressSanitizer error, // mind the destruction ordering here: @@ -411,8 +411,8 @@ TEST(BuildSymbolTableTest, IntegrityCheckResolvedSymbol) { TEST(BuildSymbolTableTest, IntegrityCheckDeclaredType) { const auto test_func = []() { SymbolTable::Tester symbol_table_1(nullptr), symbol_table_2(nullptr); - SymbolTableNode& root1(symbol_table_1.MutableRoot()); - SymbolTableNode& root2(symbol_table_2.MutableRoot()); + SymbolTableNode &root1(symbol_table_1.MutableRoot()); + SymbolTableNode &root2(symbol_table_2.MutableRoot()); // Deliberately point from one symbol table to the other. // To avoid an use-after-free AddressSanitizer error, // mind the destruction ordering here: @@ -436,7 +436,7 @@ TEST(BuildSymbolTableTest, InvalidSyntax) { constexpr absl::string_view invalid_codes[] = { "module;\nendmodule\n", }; - for (const auto& code : invalid_codes) { + for (const auto &code : invalid_codes) { TestVerilogSourceFile src("foobar.sv", code); const auto status = src.Parse(); EXPECT_FALSE(status.ok()); @@ -467,7 +467,7 @@ TEST(BuildSymbolTableTest, AvoidCrashFromFuzzer) { "n#7;\n", "c#1;;=P;\n", }; - for (const auto& code : codes) { + for (const auto &code : codes) { TestVerilogSourceFile src("foobar.sv", code); const auto status = src.Parse(); // don't care if code is valid or not SymbolTable symbol_table(nullptr); @@ -490,7 +490,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationSingleEmpty) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -517,7 +517,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationLocalNetsVariables) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -529,7 +529,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationLocalNetsVariables) { EXPECT_EMPTY_STATUSES(build_diagnostics); static constexpr absl::string_view members[] = {"w1", "w2", "l1", "l2"}; - for (const auto& member : members) { + for (const auto &member : members) { MUST_ASSIGN_LOOKUP_SYMBOL(member_node, module_node, member); EXPECT_EQ(member_node_info.metatype, SymbolMetaType::kDataNetVariableInstance); @@ -553,7 +553,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationLocalDuplicateNets) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -597,12 +597,12 @@ TEST(BuildSymbolTableTest, ModuleDeclarationConditionalGenerateAnonymous) { " wire z;\n" "endmodule\n", }; - for (const auto& code : source_variants) { + for (const auto &code : source_variants) { TestVerilogSourceFile src("foobar.sv", code); const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -616,24 +616,24 @@ TEST(BuildSymbolTableTest, ModuleDeclarationConditionalGenerateAnonymous) { ASSERT_EQ(module_node.Children().size(), 3); auto iter = module_node.Children().begin(); { - const SymbolTableNode& gen_block(iter->second); // anonymous "...-0" - const SymbolInfo& gen_block_info(gen_block.Value()); + const SymbolTableNode &gen_block(iter->second); // anonymous "...-0" + const SymbolInfo &gen_block_info(gen_block.Value()); EXPECT_EQ(gen_block_info.metatype, SymbolMetaType::kGenerate); MUST_ASSIGN_LOOKUP_SYMBOL(wire_x, gen_block, "x"); EXPECT_EQ(wire_x_info.metatype, SymbolMetaType::kDataNetVariableInstance); ++iter; } { - const SymbolTableNode& gen_block(iter->second); // anonymous "...-1" - const SymbolInfo& gen_block_info(gen_block.Value()); + const SymbolTableNode &gen_block(iter->second); // anonymous "...-1" + const SymbolInfo &gen_block_info(gen_block.Value()); EXPECT_EQ(gen_block_info.metatype, SymbolMetaType::kGenerate); MUST_ASSIGN_LOOKUP_SYMBOL(wire_y, gen_block, "y"); EXPECT_EQ(wire_y_info.metatype, SymbolMetaType::kDataNetVariableInstance); ++iter; } { - const SymbolTableNode& gen_block(iter->second); // anonymous "...-2" - const SymbolInfo& gen_block_info(gen_block.Value()); + const SymbolTableNode &gen_block(iter->second); // anonymous "...-2" + const SymbolInfo &gen_block_info(gen_block.Value()); EXPECT_EQ(gen_block_info.metatype, SymbolMetaType::kGenerate); MUST_ASSIGN_LOOKUP_SYMBOL(wire_z, gen_block, "z"); EXPECT_EQ(wire_z_info.metatype, SymbolMetaType::kDataNetVariableInstance); @@ -662,7 +662,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationConditionalGenerateLabeled) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -710,7 +710,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationWithPorts) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -722,7 +722,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationWithPorts) { nullptr); // there is no module meta-type static constexpr absl::string_view members[] = {"clk", "q"}; - for (const auto& member : members) { + for (const auto &member : members) { MUST_ASSIGN_LOOKUP_SYMBOL(member_node, module_node, member); EXPECT_EQ(member_node_info.metatype, SymbolMetaType::kDataNetVariableInstance); @@ -744,13 +744,13 @@ TEST(BuildSymbolTableTest, ModuleDeclarationMultiple) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); const absl::string_view expected_modules[] = {"m1", "m2"}; - for (const auto& expected_module : expected_modules) { + for (const auto &expected_module : expected_modules) { MUST_ASSIGN_LOOKUP_SYMBOL(module_node, root_symbol, expected_module); EXPECT_EQ(module_node_info.metatype, SymbolMetaType::kModule); EXPECT_EQ(module_node_info.file_origin, &src); @@ -772,7 +772,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationDuplicate) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -802,7 +802,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationDuplicateSeparateFiles) { const auto status2 = src2.Parse(); ASSERT_TRUE(status2.ok()) << status2.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics1 = BuildSymbolTable(src, &symbol_table); const auto build_diagnostics = BuildSymbolTable(src2, &symbol_table); @@ -834,7 +834,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationNested) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -869,7 +869,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationNestedDuplicate) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -903,13 +903,13 @@ TEST(BuildSymbolTableTest, ModuleInstance) { "module pp;\n" "endmodule\n", }; - for (const auto& code : source_variants) { + for (const auto &code : source_variants) { VLOG(1) << "code:\n" << code; TestVerilogSourceFile src("foobar.sv", code); const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -929,9 +929,9 @@ TEST(BuildSymbolTableTest, ModuleInstance) { const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, src.GetTextStructure()->Contents())); @@ -950,7 +950,7 @@ TEST(BuildSymbolTableTest, ModuleInstance) { EXPECT_TRUE(rr_info.local_references_to_bind.empty()); EXPECT_NE(rr_info.declared_type.user_defined_type, nullptr); { - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( rr_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -978,7 +978,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceUndefined) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -992,9 +992,9 @@ TEST(BuildSymbolTableTest, ModuleInstanceUndefined) { const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); { // verify that a reference to "pp" was established - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, src.GetTextStructure()->Contents())); @@ -1009,7 +1009,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceUndefined) { EXPECT_TRUE(rr_info.local_references_to_bind.empty()); EXPECT_NE(rr_info.declared_type.user_defined_type, nullptr); { - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( rr_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -1058,12 +1058,12 @@ TEST(BuildSymbolTableTest, ModuleInstanceTwoInSameDecl) { "module pp;\n" "endmodule\n", }; - for (const auto& code : source_variants) { + for (const auto &code : source_variants) { TestVerilogSourceFile src("foobar.sv", code); const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1079,9 +1079,9 @@ TEST(BuildSymbolTableTest, ModuleInstanceTwoInSameDecl) { ASSERT_EQ(qq_info.local_references_to_bind.size(), 3); const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, src.GetTextStructure()->Contents())); @@ -1092,12 +1092,12 @@ TEST(BuildSymbolTableTest, ModuleInstanceTwoInSameDecl) { // "r1" and "r2" are both instances of type "pp" static constexpr absl::string_view pp_instances[] = {"r1", "r2"}; - for (const auto& pp_inst : pp_instances) { + for (const auto &pp_inst : pp_instances) { MUST_ASSIGN_LOOKUP_SYMBOL(rr, qq, pp_inst); EXPECT_TRUE(rr_info.local_references_to_bind.empty()); EXPECT_NE(rr_info.declared_type.user_defined_type, nullptr); { - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( rr_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -1112,7 +1112,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceTwoInSameDecl) { symbol_table.Resolve(&resolve_diagnostics); // nothing to resolve EXPECT_EMPTY_STATUSES(resolve_diagnostics); - for (const auto& pp_inst : pp_instances) { + for (const auto &pp_inst : pp_instances) { MUST_ASSIGN_LOOKUP_SYMBOL(rr, qq, pp_inst); EXPECT_TRUE(rr_info.local_references_to_bind.empty()); // Verify that typeof(r1,r2) successfully resolved to module pp. @@ -1139,7 +1139,7 @@ TEST(BuildSymbolTableTest, ModuleInstancePositionalPortConnection) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1203,7 +1203,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortConnection) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1237,13 +1237,13 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortConnection) { EXPECT_EQ(d_ref->LastLeaf()->Value().identifier, "d"); EXPECT_EQ(d_ref->LastLeaf()->Value().resolved_symbol, nullptr); - const ReferenceComponentNode& m_inst_ref_root(*m_inst_ref->components); + const ReferenceComponentNode &m_inst_ref_root(*m_inst_ref->components); ASSERT_EQ(m_inst_ref_root.Children().size(), 2); const ReferenceComponentMap port_refs( ReferenceComponentNodeMapView(m_inst_ref_root)); ASSIGN_MUST_FIND(clk_ref, port_refs, "clk"); - const ReferenceComponent& clk_ref_comp(clk_ref->Value()); + const ReferenceComponent &clk_ref_comp(clk_ref->Value()); EXPECT_EQ(clk_ref_comp.identifier, "clk"); EXPECT_EQ(clk_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(clk_ref_comp.required_metatype, @@ -1251,7 +1251,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortConnection) { EXPECT_EQ(clk_ref_comp.resolved_symbol, nullptr); // not yet resolved ASSIGN_MUST_FIND(q_ref, port_refs, "q"); - const ReferenceComponent& q_ref_comp(q_ref->Value()); + const ReferenceComponent &q_ref_comp(q_ref->Value()); EXPECT_EQ(q_ref_comp.identifier, "q"); EXPECT_EQ(q_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(q_ref_comp.required_metatype, @@ -1296,7 +1296,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1331,13 +1331,13 @@ TEST(BuildSymbolTableTest, EXPECT_EQ(d_ref->LastLeaf()->Value().identifier, "d"); EXPECT_EQ(d_ref->LastLeaf()->Value().resolved_symbol, nullptr); - const ReferenceComponentNode& m_inst_ref_root(*m_inst_ref->components); + const ReferenceComponentNode &m_inst_ref_root(*m_inst_ref->components); ASSERT_EQ(m_inst_ref_root.Children().size(), 2); const ReferenceComponentMap port_refs( ReferenceComponentNodeMapView(m_inst_ref_root)); ASSIGN_MUST_FIND(clk_ref, port_refs, "clk"); - const ReferenceComponent& clk_ref_comp(clk_ref->Value()); + const ReferenceComponent &clk_ref_comp(clk_ref->Value()); EXPECT_EQ(clk_ref_comp.identifier, "clk"); EXPECT_EQ(clk_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(clk_ref_comp.required_metatype, @@ -1346,7 +1346,7 @@ TEST(BuildSymbolTableTest, EXPECT_EQ(clk_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_FIND(q_ref, port_refs, "q"); - const ReferenceComponent& q_ref_comp(q_ref->Value()); + const ReferenceComponent &q_ref_comp(q_ref->Value()); EXPECT_EQ(q_ref_comp.identifier, "q"); EXPECT_EQ(q_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(q_ref_comp.required_metatype, @@ -1386,7 +1386,7 @@ TEST(BuildSymbolTableTest, ModuleInstancePositionalParameterAssignment) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1441,7 +1441,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedParameterAssignment) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1468,20 +1468,20 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedParameterAssignment) { const auto ref_map(rr_node_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(m_type_ref, ref_map, "m"); - const ReferenceComponentNode& m_type_ref_root(*m_type_ref->components); + const ReferenceComponentNode &m_type_ref_root(*m_type_ref->components); ASSERT_EQ(m_type_ref_root.Children().size(), 2); const ReferenceComponentMap param_refs( ReferenceComponentNodeMapView(m_type_ref_root)); ASSIGN_MUST_FIND(n_ref, param_refs, "N"); - const ReferenceComponent& n_ref_comp(n_ref->Value()); + const ReferenceComponent &n_ref_comp(n_ref->Value()); EXPECT_EQ(n_ref_comp.identifier, "N"); EXPECT_EQ(n_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(n_ref_comp.required_metatype, SymbolMetaType::kParameter); EXPECT_EQ(n_ref_comp.resolved_symbol, nullptr); // not yet resolved ASSIGN_MUST_FIND(p_ref, param_refs, "P"); - const ReferenceComponent& p_ref_comp(p_ref->Value()); + const ReferenceComponent &p_ref_comp(p_ref->Value()); EXPECT_EQ(p_ref_comp.identifier, "P"); EXPECT_EQ(p_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(p_ref_comp.required_metatype, SymbolMetaType::kParameter); @@ -1506,7 +1506,7 @@ TEST(BuildSymbolTableTest, TimerAsModuleNameRegressionIssue917) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1530,7 +1530,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortIsParameter) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1557,13 +1557,13 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortIsParameter) { const auto ref_map(rr_node_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(m_type_ref, ref_map, "m"); - const ReferenceComponentNode& m_type_ref_root(*m_type_ref->components); + const ReferenceComponentNode &m_type_ref_root(*m_type_ref->components); ASSERT_EQ(m_type_ref_root.Children().size(), 1); const ReferenceComponentMap param_refs( ReferenceComponentNodeMapView(m_type_ref_root)); ASSIGN_MUST_FIND(clk_ref, param_refs, "clk"); - const ReferenceComponent& clk_ref_comp(clk_ref->Value()); + const ReferenceComponent &clk_ref_comp(clk_ref->Value()); EXPECT_EQ(clk_ref_comp.identifier, "clk"); EXPECT_EQ(clk_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(clk_ref_comp.required_metatype, SymbolMetaType::kParameter); @@ -1598,7 +1598,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedParameterIsPort) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1625,13 +1625,13 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedParameterIsPort) { const auto ref_map(rr_node_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(m_inst_ref, ref_map, "m_inst"); - const ReferenceComponentNode& m_inst_ref_root(*m_inst_ref->components); + const ReferenceComponentNode &m_inst_ref_root(*m_inst_ref->components); ASSERT_EQ(m_inst_ref_root.Children().size(), 1); const ReferenceComponentMap port_refs( ReferenceComponentNodeMapView(m_inst_ref_root)); ASSIGN_MUST_FIND(n_ref, port_refs, "N"); - const ReferenceComponent& n_ref_comp(n_ref->Value()); + const ReferenceComponent &n_ref_comp(n_ref->Value()); EXPECT_EQ(n_ref_comp.identifier, "N"); EXPECT_EQ(n_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(n_ref_comp.required_metatype, @@ -1668,7 +1668,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortConnectionNonexistentPort) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1685,13 +1685,13 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortConnectionNonexistentPort) { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(m_inst_ref, ref_map, "m_inst"); ASSERT_NE(m_inst_ref, nullptr); - const ReferenceComponentNode& m_inst_ref_root(*m_inst_ref->components); + const ReferenceComponentNode &m_inst_ref_root(*m_inst_ref->components); ASSERT_EQ(m_inst_ref_root.Children().size(), 2); const ReferenceComponentMap port_refs( ReferenceComponentNodeMapView(m_inst_ref_root)); ASSIGN_MUST_FIND(clk_ref, port_refs, "clk"); - const ReferenceComponent& clk_ref_comp(clk_ref->Value()); + const ReferenceComponent &clk_ref_comp(clk_ref->Value()); EXPECT_EQ(clk_ref_comp.identifier, "clk"); EXPECT_EQ(clk_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(clk_ref_comp.required_metatype, @@ -1699,7 +1699,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedPortConnectionNonexistentPort) { EXPECT_EQ(clk_ref_comp.resolved_symbol, nullptr); // not yet resolved ASSIGN_MUST_FIND(p_ref, port_refs, "p"); - const ReferenceComponent& p_ref_comp(p_ref->Value()); + const ReferenceComponent &p_ref_comp(p_ref->Value()); EXPECT_EQ(p_ref_comp.identifier, "p"); EXPECT_EQ(p_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(p_ref_comp.required_metatype, @@ -1740,7 +1740,7 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedParameterNonexistentError) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1767,20 +1767,20 @@ TEST(BuildSymbolTableTest, ModuleInstanceNamedParameterNonexistentError) { const auto ref_map(rr_node_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(m_type_ref, ref_map, "m"); - const ReferenceComponentNode& m_type_ref_root(*m_type_ref->components); + const ReferenceComponentNode &m_type_ref_root(*m_type_ref->components); ASSERT_EQ(m_type_ref_root.Children().size(), 2); const ReferenceComponentMap param_refs( ReferenceComponentNodeMapView(m_type_ref_root)); ASSIGN_MUST_FIND(n_ref, param_refs, "N"); - const ReferenceComponent& n_ref_comp(n_ref->Value()); + const ReferenceComponent &n_ref_comp(n_ref->Value()); EXPECT_EQ(n_ref_comp.identifier, "N"); EXPECT_EQ(n_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(n_ref_comp.required_metatype, SymbolMetaType::kParameter); EXPECT_EQ(n_ref_comp.resolved_symbol, nullptr); // not yet resolved ASSIGN_MUST_FIND(q_ref, param_refs, "Q"); - const ReferenceComponent& q_ref_comp(q_ref->Value()); + const ReferenceComponent &q_ref_comp(q_ref->Value()); EXPECT_EQ(q_ref_comp.identifier, "Q"); EXPECT_EQ(q_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(q_ref_comp.required_metatype, SymbolMetaType::kParameter); @@ -1804,7 +1804,7 @@ TEST(BuildSymbolTableTest, OneGlobalIntParameter) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1829,7 +1829,7 @@ TEST(BuildSymbolTableTest, OneGlobalUndefinedTypeParameter) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1863,7 +1863,7 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterExpression) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1882,7 +1882,7 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterExpression) { EXPECT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(ref, ref_map, "mint"); - const ReferenceComponent& ref_comp(ref->components->Value()); + const ReferenceComponent &ref_comp(ref->components->Value()); EXPECT_TRUE(is_leaf(*ref->components)); EXPECT_EQ(ref_comp.identifier, "mint"); EXPECT_EQ(ref_comp.ref_type, ReferenceType::kUnqualified); @@ -1904,7 +1904,7 @@ TEST(BuildSymbolTableTest, OneUnresolvedReferenceInExpression) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1920,7 +1920,7 @@ TEST(BuildSymbolTableTest, OneUnresolvedReferenceInExpression) { EXPECT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(ref, ref_map, "spice"); - const ReferenceComponent& ref_comp(ref->components->Value()); + const ReferenceComponent &ref_comp(ref->components->Value()); EXPECT_TRUE(is_leaf(*ref->components)); EXPECT_EQ(ref_comp.identifier, "spice"); EXPECT_EQ(ref_comp.ref_type, ReferenceType::kUnqualified); @@ -1945,7 +1945,7 @@ TEST(BuildSymbolTableTest, PackageDeclarationSingle) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1972,7 +1972,7 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterFromPackageToRoot) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -1983,7 +1983,7 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterFromPackageToRoot) { ASSERT_EQ(p_pkg_info.local_references_to_bind.size(), 1); const auto ref_map(p_pkg_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(ref, ref_map, "mint"); - const ReferenceComponent& mint_ref(ref->components->Value()); + const ReferenceComponent &mint_ref(ref->components->Value()); EXPECT_EQ(mint_ref.identifier, "mint"); EXPECT_EQ(mint_ref.resolved_symbol, nullptr); // not yet resolved @@ -2017,7 +2017,7 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterFromRootToPackage) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2029,10 +2029,10 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterFromRootToPackage) { // p_mint_ref is the reference chain for "p::mint". const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(p_mint_ref, ref_map, "p"); - const ReferenceComponent& p_ref(p_mint_ref->components->Value()); + const ReferenceComponent &p_ref(p_mint_ref->components->Value()); EXPECT_EQ(p_ref.identifier, "p"); EXPECT_EQ(p_ref.resolved_symbol, nullptr); // not yet resolved - const ReferenceComponent& mint_ref(p_mint_ref->LastLeaf()->Value()); + const ReferenceComponent &mint_ref(p_mint_ref->LastLeaf()->Value()); EXPECT_EQ(mint_ref.identifier, "mint"); EXPECT_EQ(mint_ref.resolved_symbol, nullptr); // not yet resolved @@ -2066,7 +2066,7 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterFromRootToPackageNoSuchMember) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2078,10 +2078,10 @@ TEST(BuildSymbolTableTest, ReferenceOneParameterFromRootToPackageNoSuchMember) { // p_mint_ref is the reference chain for "p::mint". const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(p_mint_ref, ref_map, "p"); - const ReferenceComponent& p_ref(p_mint_ref->components->Value()); + const ReferenceComponent &p_ref(p_mint_ref->components->Value()); EXPECT_EQ(p_ref.identifier, "p"); EXPECT_EQ(p_ref.resolved_symbol, nullptr); // not yet resolved - const ReferenceComponent& zzz_ref(p_mint_ref->LastLeaf()->Value()); + const ReferenceComponent &zzz_ref(p_mint_ref->LastLeaf()->Value()); EXPECT_EQ(zzz_ref.identifier, "zzz"); EXPECT_EQ(zzz_ref.resolved_symbol, nullptr); // not yet resolved @@ -2117,7 +2117,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationWithParameters) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2130,16 +2130,16 @@ TEST(BuildSymbolTableTest, ModuleDeclarationWithParameters) { MUST_ASSIGN_LOOKUP_SYMBOL(w_param, module_node, "W"); EXPECT_EQ(w_param_info.metatype, SymbolMetaType::kParameter); - const ReferenceComponentNode* w_type_ref = + const ReferenceComponentNode *w_type_ref = w_param_info.declared_type.user_defined_type; EXPECT_EQ(w_type_ref, nullptr); // int is primitive type MUST_ASSIGN_LOOKUP_SYMBOL(b_param, module_node, "B"); EXPECT_EQ(b_param_info.metatype, SymbolMetaType::kParameter); - const ReferenceComponentNode* b_type_ref = + const ReferenceComponentNode *b_type_ref = b_param_info.declared_type.user_defined_type; ASSERT_NE(b_type_ref, nullptr); - const ReferenceComponent& b_type_ref_comp(b_type_ref->Value()); + const ReferenceComponent &b_type_ref_comp(b_type_ref->Value()); EXPECT_EQ(b_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(b_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(b_type_ref_comp.identifier, "bar"); @@ -2148,13 +2148,13 @@ TEST(BuildSymbolTableTest, ModuleDeclarationWithParameters) { const auto ref_map(module_node_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(w_ref, ref_map, "W"); - const ReferenceComponent& w_ref_comp(w_ref->components->Value()); + const ReferenceComponent &w_ref_comp(w_ref->components->Value()); EXPECT_EQ(w_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(w_ref_comp.identifier, "W"); EXPECT_EQ(w_ref_comp.resolved_symbol, nullptr); // not yet resolved ASSIGN_MUST_FIND_EXACTLY_ONE_REF(bar_ref, ref_map, "bar"); - const ReferenceComponent& bar_ref_comp(bar_ref->components->Value()); + const ReferenceComponent &bar_ref_comp(bar_ref->components->Value()); EXPECT_EQ(bar_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(bar_ref_comp.identifier, "bar"); EXPECT_EQ(bar_ref_comp.resolved_symbol, nullptr); // not yet resolved @@ -2186,7 +2186,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationLocalsDependOnParameter) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2199,7 +2199,7 @@ TEST(BuildSymbolTableTest, ModuleDeclarationLocalsDependOnParameter) { MUST_ASSIGN_LOOKUP_SYMBOL(n_param, module_m, "N"); EXPECT_EQ(n_param_info.metatype, SymbolMetaType::kParameter); - const ReferenceComponentNode* n_type_ref = + const ReferenceComponentNode *n_type_ref = n_param_info.declared_type.user_defined_type; EXPECT_EQ(n_type_ref, nullptr); // int is primitive type @@ -2208,8 +2208,8 @@ TEST(BuildSymbolTableTest, ModuleDeclarationLocalsDependOnParameter) { ASSIGN_MUST_FIND(n_refs, ref_map, "N"); ASSERT_EQ(n_refs.size(), 6); // all references to "N" parameter - for (const auto& n_ref : n_refs) { - const ReferenceComponent& n_ref_comp(n_ref->components->Value()); + for (const auto &n_ref : n_refs) { + const ReferenceComponent &n_ref_comp(n_ref->components->Value()); EXPECT_EQ(n_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(n_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(n_ref_comp.identifier, "N"); @@ -2222,8 +2222,8 @@ TEST(BuildSymbolTableTest, ModuleDeclarationLocalsDependOnParameter) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // All references to "N" resolved. - for (const auto& n_ref : n_refs) { - const ReferenceComponent& n_ref_comp(n_ref->components->Value()); + for (const auto &n_ref : n_refs) { + const ReferenceComponent &n_ref_comp(n_ref->components->Value()); EXPECT_EQ(n_ref_comp.resolved_symbol, &n_param); // resolved successfully } } @@ -2237,7 +2237,7 @@ TEST(BuildSymbolTableTest, ModuleSingleImplicitDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2250,7 +2250,7 @@ TEST(BuildSymbolTableTest, ModuleSingleImplicitDeclaration) { MUST_ASSIGN_LOOKUP_SYMBOL(a_variable, module_m, "a"); EXPECT_EQ(a_variable_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* a_type_ref = + const ReferenceComponentNode *a_type_ref = a_variable_info.declared_type.user_defined_type; EXPECT_EQ(a_type_ref, nullptr); // implicit type is primitive type EXPECT_TRUE(a_variable_info.declared_type.implicit); @@ -2260,8 +2260,8 @@ TEST(BuildSymbolTableTest, ModuleSingleImplicitDeclaration) { ASSIGN_MUST_FIND(a_refs, ref_map, "a"); ASSERT_EQ(a_refs.size(), 1); // all references to "a" parameter - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(a_ref_comp.identifier, "a"); @@ -2275,8 +2275,8 @@ TEST(BuildSymbolTableTest, ModuleSingleImplicitDeclaration) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // All references to "a" resolved. - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.resolved_symbol, &a_variable); // resolved successfully } @@ -2292,7 +2292,7 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2305,7 +2305,7 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclaration) { MUST_ASSIGN_LOOKUP_SYMBOL(a_variable, module_m, "a"); EXPECT_EQ(a_variable_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* a_type_ref = + const ReferenceComponentNode *a_type_ref = a_variable_info.declared_type.user_defined_type; EXPECT_EQ(a_type_ref, nullptr); // implicit type is primitive type EXPECT_TRUE(a_variable_info.declared_type.implicit); @@ -2316,16 +2316,16 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclaration) { ASSIGN_MUST_FIND(a_refs, ref_map, "a"); ASSERT_EQ(a_refs.size(), 2); // all references to "a" parameter { - const auto& a_ref = *a_refs.begin(); - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + const auto &a_ref = *a_refs.begin(); + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(a_ref_comp.identifier, "a"); EXPECT_EQ(a_ref_comp.resolved_symbol, &a_variable); // pre-resolved } { - const auto& a_ref = *std::next(a_refs.begin()); - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + const auto &a_ref = *std::next(a_refs.begin()); + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(a_ref_comp.identifier, "a"); @@ -2338,8 +2338,8 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclaration) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // All references to "a" resolved. - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.resolved_symbol, &a_variable); // resolved successfully } @@ -2357,7 +2357,7 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclarationInSubScope) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2370,7 +2370,7 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclarationInSubScope) { MUST_ASSIGN_LOOKUP_SYMBOL(a_variable, module_m, "a"); EXPECT_EQ(a_variable_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* a_type_ref = + const ReferenceComponentNode *a_type_ref = a_variable_info.declared_type.user_defined_type; EXPECT_EQ(a_type_ref, nullptr); // implicit type is primitive type EXPECT_TRUE(a_variable_info.declared_type.implicit); @@ -2380,8 +2380,8 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclarationInSubScope) { ASSIGN_MUST_FIND(a_refs, ref_map, "a"); ASSERT_EQ(a_refs.size(), 1); // all references to "a" parameter - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(a_ref_comp.identifier, "a"); @@ -2399,8 +2399,8 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclarationInSubScope) { ASSIGN_MUST_FIND(n_a_refs, n_ref_map, "a"); ASSERT_EQ(n_a_refs.size(), 1); // references to "a" net in "n" module - for (const auto& n_a_ref : n_a_refs) { - const ReferenceComponent& n_a_ref_comp(n_a_ref->components->Value()); + for (const auto &n_a_ref : n_a_refs) { + const ReferenceComponent &n_a_ref_comp(n_a_ref->components->Value()); EXPECT_EQ(n_a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(n_a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(n_a_ref_comp.identifier, "a"); @@ -2415,14 +2415,14 @@ TEST(BuildSymbolTableTest, ModuleReferenceToImplicitDeclarationInSubScope) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // All references to "a" resolved. - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.resolved_symbol, &a_variable); // resolved successfully } - for (const auto& n_a_ref : n_a_refs) { - const ReferenceComponent& n_a_ref_comp(n_a_ref->components->Value()); + for (const auto &n_a_ref : n_a_refs) { + const ReferenceComponent &n_a_ref_comp(n_a_ref->components->Value()); EXPECT_EQ(n_a_ref_comp.resolved_symbol, &a_variable); // resolved successfully } @@ -2441,7 +2441,7 @@ TEST(BuildSymbolTableTest, ModuleExplicitDeclarationInSubScope) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2454,7 +2454,7 @@ TEST(BuildSymbolTableTest, ModuleExplicitDeclarationInSubScope) { MUST_ASSIGN_LOOKUP_SYMBOL(a_variable, module_m, "a"); EXPECT_EQ(a_variable_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* a_type_ref = + const ReferenceComponentNode *a_type_ref = a_variable_info.declared_type.user_defined_type; EXPECT_EQ(a_type_ref, nullptr); // implicit type is primitive type EXPECT_TRUE(a_variable_info.declared_type.implicit); @@ -2464,8 +2464,8 @@ TEST(BuildSymbolTableTest, ModuleExplicitDeclarationInSubScope) { ASSIGN_MUST_FIND(a_refs, ref_map, "a"); ASSERT_EQ(a_refs.size(), 1); // all references to "a" parameter - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(a_ref_comp.identifier, "a"); @@ -2481,7 +2481,7 @@ TEST(BuildSymbolTableTest, ModuleExplicitDeclarationInSubScope) { MUST_ASSIGN_LOOKUP_SYMBOL(n_a_variable, module_n, "a"); EXPECT_EQ(n_a_variable_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* n_a_type_ref = + const ReferenceComponentNode *n_a_type_ref = n_a_variable_info.declared_type.user_defined_type; EXPECT_EQ(n_a_type_ref, nullptr); EXPECT_FALSE(n_a_variable_info.declared_type.implicit); @@ -2491,8 +2491,8 @@ TEST(BuildSymbolTableTest, ModuleExplicitDeclarationInSubScope) { ASSIGN_MUST_FIND(n_a_refs, n_ref_map, "a"); ASSERT_EQ(n_a_refs.size(), 1); // references to "a" net in "n" module - for (const auto& n_a_ref : n_a_refs) { - const ReferenceComponent& n_a_ref_comp(n_a_ref->components->Value()); + for (const auto &n_a_ref : n_a_refs) { + const ReferenceComponent &n_a_ref_comp(n_a_ref->components->Value()); EXPECT_EQ(n_a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(n_a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(n_a_ref_comp.identifier, "a"); @@ -2507,14 +2507,14 @@ TEST(BuildSymbolTableTest, ModuleExplicitDeclarationInSubScope) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // All references to "a" resolved. - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.resolved_symbol, &a_variable); // resolved successfully } - for (const auto& n_a_ref : n_a_refs) { - const ReferenceComponent& n_a_ref_comp(n_a_ref->components->Value()); + for (const auto &n_a_ref : n_a_refs) { + const ReferenceComponent &n_a_ref_comp(n_a_ref->components->Value()); EXPECT_EQ(n_a_ref_comp.resolved_symbol, &n_a_variable); // resolved successfully } @@ -2531,7 +2531,7 @@ TEST(BuildSymbolTableTest, ModuleExplicitAndImplicitDeclarations) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2544,14 +2544,14 @@ TEST(BuildSymbolTableTest, ModuleExplicitAndImplicitDeclarations) { MUST_ASSIGN_LOOKUP_SYMBOL(a_variable, module_m, "a"); EXPECT_EQ(a_variable_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* a_type_ref = + const ReferenceComponentNode *a_type_ref = a_variable_info.declared_type.user_defined_type; EXPECT_EQ(a_type_ref, nullptr); // implicit type is primitive type EXPECT_TRUE(a_variable_info.declared_type.implicit); MUST_ASSIGN_LOOKUP_SYMBOL(b_variable, module_m, "b"); EXPECT_EQ(b_variable_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* b_type_ref = + const ReferenceComponentNode *b_type_ref = b_variable_info.declared_type.user_defined_type; EXPECT_EQ(b_type_ref, nullptr); EXPECT_FALSE(b_variable_info.declared_type.implicit); @@ -2561,8 +2561,8 @@ TEST(BuildSymbolTableTest, ModuleExplicitAndImplicitDeclarations) { ASSIGN_MUST_FIND(a_refs, ref_map, "a"); ASSERT_EQ(a_refs.size(), 1); // all references to "a" parameter - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(a_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(a_ref_comp.identifier, "a"); @@ -2571,8 +2571,8 @@ TEST(BuildSymbolTableTest, ModuleExplicitAndImplicitDeclarations) { ASSIGN_MUST_FIND(b_refs, ref_map, "b"); ASSERT_EQ(b_refs.size(), 1); - for (const auto& b_ref : b_refs) { - const ReferenceComponent& b_ref_comp(b_ref->components->Value()); + for (const auto &b_ref : b_refs) { + const ReferenceComponent &b_ref_comp(b_ref->components->Value()); EXPECT_EQ(b_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(b_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(b_ref_comp.identifier, "b"); @@ -2586,15 +2586,15 @@ TEST(BuildSymbolTableTest, ModuleExplicitAndImplicitDeclarations) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // All references to "a" resolved. - for (const auto& a_ref : a_refs) { - const ReferenceComponent& a_ref_comp(a_ref->components->Value()); + for (const auto &a_ref : a_refs) { + const ReferenceComponent &a_ref_comp(a_ref->components->Value()); EXPECT_EQ(a_ref_comp.resolved_symbol, &a_variable); // resolved successfully } // All references to "b" resolved. - for (const auto& b_ref : b_refs) { - const ReferenceComponent& b_ref_comp(b_ref->components->Value()); + for (const auto &b_ref : b_refs) { + const ReferenceComponent &b_ref_comp(b_ref->components->Value()); EXPECT_EQ(b_ref_comp.resolved_symbol, &b_variable); // resolved successfully } @@ -2624,7 +2624,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationSingle) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2653,7 +2653,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationNested) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2693,7 +2693,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationWithParameter) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2706,7 +2706,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationWithParameter) { MUST_ASSIGN_LOOKUP_SYMBOL(n_param, class_cc, "N"); EXPECT_EQ(n_param_info.metatype, SymbolMetaType::kParameter); - const ReferenceComponentNode* n_type_ref = + const ReferenceComponentNode *n_type_ref = n_param_info.declared_type.user_defined_type; EXPECT_EQ(n_type_ref, nullptr); // int is primitive type @@ -2728,7 +2728,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMember) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2740,7 +2740,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMember) { MUST_ASSIGN_LOOKUP_SYMBOL(size_field, class_cc, "size"); EXPECT_EQ(size_field_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* size_type_ref = + const ReferenceComponentNode *size_type_ref = size_field_info.declared_type.user_defined_type; EXPECT_EQ(size_type_ref, nullptr); // int is primitive type EXPECT_EQ( @@ -2750,7 +2750,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMember) { MUST_ASSIGN_LOOKUP_SYMBOL(count_field, class_cc, "count"); EXPECT_EQ(count_field_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* count_type_ref = + const ReferenceComponentNode *count_type_ref = count_field_info.declared_type.user_defined_type; EXPECT_EQ(count_type_ref, nullptr); // int is primitive type EXPECT_EQ(verible::StringSpanOfSymbol( @@ -2774,7 +2774,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMemberMultiDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2787,7 +2787,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMemberMultiDeclaration) { MUST_ASSIGN_LOOKUP_SYMBOL(height_field, class_cc, "height"); EXPECT_EQ(height_field_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* height_type_ref = + const ReferenceComponentNode *height_type_ref = height_field_info.declared_type.user_defined_type; EXPECT_EQ(height_type_ref, nullptr); // int is primitive type EXPECT_EQ(verible::StringSpanOfSymbol( @@ -2797,7 +2797,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMemberMultiDeclaration) { MUST_ASSIGN_LOOKUP_SYMBOL(width_field, class_cc, "width"); EXPECT_EQ(width_field_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* width_type_ref = + const ReferenceComponentNode *width_type_ref = width_field_info.declared_type.user_defined_type; EXPECT_EQ(width_type_ref, nullptr); // int is primitive type EXPECT_EQ(verible::StringSpanOfSymbol( @@ -2824,7 +2824,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMemberAccessedFromMethod) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2836,7 +2836,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMemberAccessedFromMethod) { MUST_ASSIGN_LOOKUP_SYMBOL(size_field, class_cc, "size"); EXPECT_EQ(size_field_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* size_type_ref = + const ReferenceComponentNode *size_type_ref = size_field_info.declared_type.user_defined_type; EXPECT_EQ(size_type_ref, nullptr); // int is primitive type EXPECT_EQ( @@ -2849,7 +2849,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationDataMemberAccessedFromMethod) { const auto ref_map(get_size_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(size_ref, ref_map, "size"); - const ReferenceComponent& size_ref_comp(size_ref->components->Value()); + const ReferenceComponent &size_ref_comp(size_ref->components->Value()); EXPECT_EQ(size_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(size_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(size_ref_comp.resolved_symbol, nullptr); @@ -2876,7 +2876,7 @@ TEST(BuildSymbolTableTest, ClassDataMemberAccessedDirectly) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2888,7 +2888,7 @@ TEST(BuildSymbolTableTest, ClassDataMemberAccessedDirectly) { MUST_ASSIGN_LOOKUP_SYMBOL(size_field, class_cc, "size"); EXPECT_EQ(size_field_info.metatype, SymbolMetaType::kDataNetVariableInstance); - const ReferenceComponentNode* size_type_ref = + const ReferenceComponentNode *size_type_ref = size_field_info.declared_type.user_defined_type; EXPECT_EQ(size_type_ref, nullptr); // int is primitive type EXPECT_EQ( @@ -2904,15 +2904,15 @@ TEST(BuildSymbolTableTest, ClassDataMemberAccessedDirectly) { const auto ref_map(get_size_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(cc_data_ref, ref_map, "cc_data"); - const ReferenceComponent& cc_data_ref_comp(cc_data_ref->components->Value()); + const ReferenceComponent &cc_data_ref_comp(cc_data_ref->components->Value()); EXPECT_EQ(cc_data_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_data_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_data_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(cc_data_ref->components->Children().size(), 1); - const ReferenceComponentNode& size_ref( + const ReferenceComponentNode &size_ref( cc_data_ref->components->Children().front()); - const ReferenceComponent& size_ref_comp(size_ref.Value()); + const ReferenceComponent &size_ref_comp(size_ref.Value()); EXPECT_EQ(size_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(size_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(size_ref_comp.resolved_symbol, nullptr); @@ -2936,7 +2936,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationSingleInheritance) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -2957,7 +2957,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationSingleInheritance) { EXPECT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(base_ref, ref_map, "base"); - const ReferenceComponent& base_ref_comp(base_ref->components->Value()); + const ReferenceComponent &base_ref_comp(base_ref->components->Value()); EXPECT_EQ(base_ref_comp.identifier, "base"); EXPECT_EQ(base_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(base_ref_comp.required_metatype, SymbolMetaType::kClass); @@ -2991,7 +2991,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationSingleInheritanceAcrossPackage) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3015,16 +3015,16 @@ TEST(BuildSymbolTableTest, ClassDeclarationSingleInheritanceAcrossPackage) { EXPECT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_ref, ref_map, "pp"); - const ReferenceComponent& pp_ref_comp(pp_ref->components->Value()); + const ReferenceComponent &pp_ref_comp(pp_ref->components->Value()); EXPECT_EQ(pp_ref_comp.identifier, "pp"); EXPECT_EQ(pp_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(pp_ref->components->Children().size(), 1); - const ReferenceComponentNode& base_ref( + const ReferenceComponentNode &base_ref( pp_ref->components->Children().front()); - const ReferenceComponent& base_ref_comp(base_ref.Value()); + const ReferenceComponent &base_ref_comp(base_ref.Value()); EXPECT_EQ(base_ref_comp.identifier, "base"); EXPECT_EQ(base_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(base_ref_comp.required_metatype, SymbolMetaType::kClass); @@ -3062,7 +3062,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationSingleInheritancePackageToPackage) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3090,16 +3090,16 @@ TEST(BuildSymbolTableTest, ClassDeclarationSingleInheritancePackageToPackage) { EXPECT_EQ(package_qq_info.local_references_to_bind.size(), 1); const auto ref_map(package_qq_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_ref, ref_map, "pp"); - const ReferenceComponent& pp_ref_comp(pp_ref->components->Value()); + const ReferenceComponent &pp_ref_comp(pp_ref->components->Value()); EXPECT_EQ(pp_ref_comp.identifier, "pp"); EXPECT_EQ(pp_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(pp_ref->components->Children().size(), 1); - const ReferenceComponentNode& base_ref( + const ReferenceComponentNode &base_ref( pp_ref->components->Children().front()); - const ReferenceComponent& base_ref_comp(base_ref.Value()); + const ReferenceComponent &base_ref_comp(base_ref.Value()); EXPECT_EQ(base_ref_comp.identifier, "base"); EXPECT_EQ(base_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(base_ref_comp.required_metatype, SymbolMetaType::kClass); @@ -3137,7 +3137,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationInheritanceFromNestedClass) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3165,16 +3165,16 @@ TEST(BuildSymbolTableTest, ClassDeclarationInheritanceFromNestedClass) { EXPECT_EQ(class_qq_info.local_references_to_bind.size(), 1); const auto ref_map(class_qq_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_ref, ref_map, "pp"); - const ReferenceComponent& pp_ref_comp(pp_ref->components->Value()); + const ReferenceComponent &pp_ref_comp(pp_ref->components->Value()); EXPECT_EQ(pp_ref_comp.identifier, "pp"); EXPECT_EQ(pp_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(pp_ref->components->Children().size(), 1); - const ReferenceComponentNode& base_ref( + const ReferenceComponentNode &base_ref( pp_ref->components->Children().front()); - const ReferenceComponent& base_ref_comp(base_ref.Value()); + const ReferenceComponent &base_ref_comp(base_ref.Value()); EXPECT_EQ(base_ref_comp.identifier, "base"); EXPECT_EQ(base_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(base_ref_comp.required_metatype, SymbolMetaType::kClass); @@ -3207,7 +3207,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationInLineConstructorDefinition) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3243,7 +3243,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationOutOfLineConstructorDefinition) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3265,13 +3265,13 @@ TEST(BuildSymbolTableTest, ClassDeclarationOutOfLineConstructorDefinition) { // Expect a "C::new" reference from the out-of-line definition. const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(class_c_ref, ref_map, "C"); - const ReferenceComponent& c_ref_comp(class_c_ref->components->Value()); + const ReferenceComponent &c_ref_comp(class_c_ref->components->Value()); EXPECT_EQ(c_ref_comp.identifier, "C"); EXPECT_EQ(c_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(c_ref_comp.required_metatype, SymbolMetaType::kClass); // out-of-line class and method reference must be resolved at build-time EXPECT_NE(c_ref_comp.resolved_symbol, nullptr); - const ReferenceComponent& ctor_ref_comp(class_c_ref->LastLeaf()->Value()); + const ReferenceComponent &ctor_ref_comp(class_c_ref->LastLeaf()->Value()); EXPECT_EQ(ctor_ref_comp.identifier, "new"); EXPECT_EQ(ctor_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(ctor_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -3300,7 +3300,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationReferenceInheritedMemberFromMethod) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3329,7 +3329,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationReferenceInheritedMemberFromMethod) { EXPECT_EQ(get_count_info.local_references_to_bind.size(), 1); const auto ref_map(get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(count_ref, ref_map, "count"); - const ReferenceComponent& count_ref_comp(count_ref->components->Value()); + const ReferenceComponent &count_ref_comp(count_ref->components->Value()); EXPECT_EQ(count_ref_comp.identifier, "count"); EXPECT_EQ(count_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(count_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -3369,7 +3369,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationReferenceGrandparentMember) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3404,7 +3404,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationReferenceGrandparentMember) { EXPECT_EQ(get_count_info.local_references_to_bind.size(), 1); const auto ref_map(get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(count_ref, ref_map, "count"); - const ReferenceComponent& count_ref_comp(count_ref->components->Value()); + const ReferenceComponent &count_ref_comp(count_ref->components->Value()); EXPECT_EQ(count_ref_comp.identifier, "count"); EXPECT_EQ(count_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(count_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -3414,14 +3414,14 @@ TEST(BuildSymbolTableTest, ClassDeclarationReferenceGrandparentMember) { // Make sure the "derived" reference is linked from the "more_derived" class. const auto root_refs = root_symbol.Value().LocalReferencesMapViewForTesting(); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(base_ref, root_refs, "base"); - const ReferenceComponent& base_ref_comp(base_ref->components->Value()); + const ReferenceComponent &base_ref_comp(base_ref->components->Value()); EXPECT_EQ(base_ref_comp.identifier, "base"); EXPECT_EQ(base_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(base_ref_comp.required_metatype, SymbolMetaType::kClass); EXPECT_EQ(base_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(derived_ref, root_refs, "derived"); - const ReferenceComponent& derived_ref_comp(derived_ref->components->Value()); + const ReferenceComponent &derived_ref_comp(derived_ref->components->Value()); EXPECT_EQ(derived_ref_comp.identifier, "derived"); EXPECT_EQ(derived_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(derived_ref_comp.required_metatype, SymbolMetaType::kClass); @@ -3465,7 +3465,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3504,7 +3504,7 @@ TEST(BuildSymbolTableTest, const auto ref_map(get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(derived_type_ref, ref_map, "derived"); - const ReferenceComponent& derived_type_ref_comp( + const ReferenceComponent &derived_type_ref_comp( derived_type_ref->components->Value()); EXPECT_EQ(derived_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(derived_type_ref_comp.required_metatype, @@ -3516,16 +3516,16 @@ TEST(BuildSymbolTableTest, derived_type_ref->components.get()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(dd_ref, ref_map, "dd"); - const ReferenceComponent& dd_ref_comp(dd_ref->components->Value()); + const ReferenceComponent &dd_ref_comp(dd_ref->components->Value()); EXPECT_EQ(dd_ref_comp.identifier, "dd"); EXPECT_EQ(dd_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(dd_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(dd_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(dd_ref->components->Children().size(), 1); - const ReferenceComponentNode& dd_count_ref( + const ReferenceComponentNode &dd_count_ref( dd_ref->components->Children().front()); - const ReferenceComponent& dd_count_ref_comp(dd_count_ref.Value()); + const ReferenceComponent &dd_count_ref_comp(dd_count_ref.Value()); EXPECT_EQ(dd_count_ref_comp.identifier, "count"); EXPECT_EQ(dd_count_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(dd_count_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -3570,7 +3570,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationReferenceInheritedBaseClassMethod) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3599,7 +3599,7 @@ TEST(BuildSymbolTableTest, ClassDeclarationReferenceInheritedBaseClassMethod) { EXPECT_EQ(get_count_info.local_references_to_bind.size(), 1); const auto ref_map(get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(count_ref, ref_map, "count"); - const ReferenceComponent& count_ref_comp(count_ref->components->Value()); + const ReferenceComponent &count_ref_comp(count_ref->components->Value()); EXPECT_EQ(count_ref_comp.identifier, "count"); EXPECT_EQ(count_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(count_ref_comp.required_metatype, SymbolMetaType::kCallable); @@ -3639,7 +3639,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3678,7 +3678,7 @@ TEST(BuildSymbolTableTest, const auto ref_map(get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(derived_type_ref, ref_map, "derived"); - const ReferenceComponent& derived_type_ref_comp( + const ReferenceComponent &derived_type_ref_comp( derived_type_ref->components->Value()); EXPECT_EQ(derived_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(derived_type_ref_comp.required_metatype, @@ -3690,16 +3690,16 @@ TEST(BuildSymbolTableTest, derived_type_ref->components.get()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(dd_ref, ref_map, "dd"); - const ReferenceComponent& dd_ref_comp(dd_ref->components->Value()); + const ReferenceComponent &dd_ref_comp(dd_ref->components->Value()); EXPECT_EQ(dd_ref_comp.identifier, "dd"); EXPECT_EQ(dd_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(dd_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(dd_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(dd_ref->components->Children().size(), 1); - const ReferenceComponentNode& dd_count_ref( + const ReferenceComponentNode &dd_count_ref( dd_ref->components->Children().front()); - const ReferenceComponent& dd_count_ref_comp(dd_count_ref.Value()); + const ReferenceComponent &dd_count_ref_comp(dd_count_ref.Value()); EXPECT_EQ(dd_count_ref_comp.identifier, "count"); EXPECT_EQ(dd_count_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(dd_count_ref_comp.required_metatype, SymbolMetaType::kCallable); @@ -3737,7 +3737,7 @@ TEST(BuildSymbolTableTest, TypeParameterizedModuleDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3769,7 +3769,7 @@ TEST(BuildSymbolTableTest, TypeParameterizedClassDataDeclarations) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3794,8 +3794,8 @@ TEST(BuildSymbolTableTest, TypeParameterizedClassDataDeclarations) { ASSIGN_MUST_FIND(cc_refs, ref_map, "cc"); EXPECT_EQ(cc_refs.size(), 2); - for (const auto& cc_ref : cc_refs) { - const ReferenceComponent& cc_ref_comp(cc_ref->components->Value()); + for (const auto &cc_ref : cc_refs) { + const ReferenceComponent &cc_ref_comp(cc_ref->components->Value()); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.identifier, "cc"); @@ -3804,7 +3804,7 @@ TEST(BuildSymbolTableTest, TypeParameterizedClassDataDeclarations) { // Of the two "cc" type refs, the outer one is the first one, by ordering of // textual position among references that start with the same identifier. - const DependentReferences& data_cc_type(**cc_refs.begin()); + const DependentReferences &data_cc_type(**cc_refs.begin()); EXPECT_EQ(data_info.declared_type.user_defined_type, data_cc_type.LastTypeComponent()); @@ -3813,8 +3813,8 @@ TEST(BuildSymbolTableTest, TypeParameterizedClassDataDeclarations) { symbol_table.Resolve(&resolve_diagnostics); EXPECT_EMPTY_STATUSES(resolve_diagnostics); - for (const auto& cc_ref : cc_refs) { - const ReferenceComponent& cc_ref_comp(cc_ref->components->Value()); + for (const auto &cc_ref : cc_refs) { + const ReferenceComponent &cc_ref_comp(cc_ref->components->Value()); EXPECT_EQ(cc_ref_comp.resolved_symbol, &cc_class); } // type of "data" is resolved @@ -3839,7 +3839,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3872,17 +3872,17 @@ TEST(BuildSymbolTableTest, EXPECT_EQ(pp_refs.size(), 3); // all "pp::cc" references have the same structure - for (const auto& pp_ref : pp_refs) { - const ReferenceComponent& pp_ref_comp(pp_ref->components->Value()); + for (const auto &pp_ref : pp_refs) { + const ReferenceComponent &pp_ref_comp(pp_ref->components->Value()); EXPECT_EQ(pp_ref_comp.identifier, "pp"); EXPECT_EQ(pp_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(pp_ref->components->Children().size(), 1); - const ReferenceComponentNode& cc_ref( + const ReferenceComponentNode &cc_ref( pp_ref->components->Children().front()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.identifier, "cc"); @@ -3891,7 +3891,7 @@ TEST(BuildSymbolTableTest, // Of all the "pp::cc" type refs, the outer one is the first one, by ordering // of textual position among references that start with the same identifier. - const DependentReferences& data_cc_type(**pp_refs.begin()); + const DependentReferences &data_cc_type(**pp_refs.begin()); EXPECT_EQ(data_info.declared_type.user_defined_type, data_cc_type.LastTypeComponent()); @@ -3900,13 +3900,13 @@ TEST(BuildSymbolTableTest, symbol_table.Resolve(&resolve_diagnostics); EXPECT_EMPTY_STATUSES(resolve_diagnostics); - for (const auto& pp_ref : pp_refs) { - const ReferenceComponent& pp_ref_comp(pp_ref->components->Value()); + for (const auto &pp_ref : pp_refs) { + const ReferenceComponent &pp_ref_comp(pp_ref->components->Value()); EXPECT_EQ(pp_ref_comp.resolved_symbol, &pp_package); - const ReferenceComponentNode& cc_ref( + const ReferenceComponentNode &cc_ref( pp_ref->components->Children().front()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.resolved_symbol, &cc_class); } // type of "data" is resolved @@ -3927,7 +3927,7 @@ TEST(BuildSymbolTableTest, NestedTypeParameterizedClassDataDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -3963,17 +3963,17 @@ TEST(BuildSymbolTableTest, NestedTypeParameterizedClassDataDeclaration) { EXPECT_EQ(outer_refs.size(), 3); // all "pp::cc" references have the same structure - for (const auto& outer_ref : outer_refs) { - const ReferenceComponent& outer_ref_comp(outer_ref->components->Value()); + for (const auto &outer_ref : outer_refs) { + const ReferenceComponent &outer_ref_comp(outer_ref->components->Value()); EXPECT_EQ(outer_ref_comp.identifier, "outer"); EXPECT_EQ(outer_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(outer_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(outer_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(outer_ref->components->Children().size(), 1); - const ReferenceComponentNode& cc_ref( + const ReferenceComponentNode &cc_ref( outer_ref->components->Children().front()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.identifier, "cc"); @@ -3983,7 +3983,7 @@ TEST(BuildSymbolTableTest, NestedTypeParameterizedClassDataDeclaration) { // Of all the "outer::cc" type refs, the outer one is the first one, by // ordering of textual position among references that start with the same // identifier. - const DependentReferences& data_cc_type(**outer_refs.begin()); + const DependentReferences &data_cc_type(**outer_refs.begin()); EXPECT_EQ(data_info.declared_type.user_defined_type, data_cc_type.LastTypeComponent()); @@ -3992,13 +3992,13 @@ TEST(BuildSymbolTableTest, NestedTypeParameterizedClassDataDeclaration) { symbol_table.Resolve(&resolve_diagnostics); EXPECT_EMPTY_STATUSES(resolve_diagnostics); - for (const auto& outer_ref : outer_refs) { - const ReferenceComponent& outer_ref_comp(outer_ref->components->Value()); + for (const auto &outer_ref : outer_refs) { + const ReferenceComponent &outer_ref_comp(outer_ref->components->Value()); EXPECT_EQ(outer_ref_comp.resolved_symbol, &outer_class); - const ReferenceComponentNode& cc_ref( + const ReferenceComponentNode &cc_ref( outer_ref->components->Children().front()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.resolved_symbol, &cc_class); } // type of "data" is resolved @@ -4020,7 +4020,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4047,7 +4047,7 @@ TEST(BuildSymbolTableTest, const auto ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(cc_refs, ref_map, "cc"); ASSIGN_MUST_HAVE_UNIQUE(cc_ref, cc_refs); - const ReferenceComponent& cc_ref_comp(cc_ref->components->Value()); + const ReferenceComponent &cc_ref_comp(cc_ref->components->Value()); EXPECT_EQ(cc_ref_comp.identifier, "cc"); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -4056,20 +4056,20 @@ TEST(BuildSymbolTableTest, const ReferenceComponentMap param_ref_map( ReferenceComponentNodeMapView(*cc_ref->components)); ASSIGN_MUST_FIND(s_ref, param_ref_map, "S"); - const ReferenceComponent& s_ref_comp(s_ref->Value()); + const ReferenceComponent &s_ref_comp(s_ref->Value()); EXPECT_EQ(s_ref_comp.identifier, "S"); EXPECT_EQ(s_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(s_ref_comp.required_metatype, SymbolMetaType::kParameter); EXPECT_EQ(s_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_FIND(t_ref, param_ref_map, "T"); - const ReferenceComponent& t_ref_comp(t_ref->Value()); + const ReferenceComponent &t_ref_comp(t_ref->Value()); EXPECT_EQ(t_ref_comp.identifier, "T"); EXPECT_EQ(t_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(t_ref_comp.required_metatype, SymbolMetaType::kParameter); EXPECT_EQ(t_ref_comp.resolved_symbol, nullptr); - const DependentReferences& data_cc_type(*cc_ref); + const DependentReferences &data_cc_type(*cc_ref); EXPECT_EQ(data_info.declared_type.user_defined_type, data_cc_type.components.get()); @@ -4101,7 +4101,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4137,8 +4137,8 @@ TEST(BuildSymbolTableTest, EXPECT_EQ(outer_refs.size(), 3); // all "outer::cc" references have the same structure - for (const auto& outer_ref : outer_refs) { - const ReferenceComponent& outer_ref_comp(outer_ref->components->Value()); + for (const auto &outer_ref : outer_refs) { + const ReferenceComponent &outer_ref_comp(outer_ref->components->Value()); EXPECT_EQ(outer_ref_comp.identifier, "outer"); EXPECT_EQ(outer_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(outer_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -4146,25 +4146,25 @@ TEST(BuildSymbolTableTest, ASSERT_EQ(outer_ref->components->Children().size(), 2); - const ReferenceComponentNode& s_param_ref( + const ReferenceComponentNode &s_param_ref( outer_ref->components->Children().front()); - const ReferenceComponent& s_param_ref_comp(s_param_ref.Value()); + const ReferenceComponent &s_param_ref_comp(s_param_ref.Value()); EXPECT_EQ(s_param_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(s_param_ref_comp.required_metatype, SymbolMetaType::kParameter); EXPECT_EQ(s_param_ref_comp.identifier, "S"); EXPECT_EQ(s_param_ref_comp.resolved_symbol, nullptr); - const ReferenceComponentNode& cc_ref( + const ReferenceComponentNode &cc_ref( outer_ref->components->Children().back()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.identifier, "cc"); EXPECT_EQ(cc_ref_comp.resolved_symbol, nullptr); ASSERT_EQ(cc_ref.Children().size(), 1); - const ReferenceComponentNode& t_param_ref(cc_ref.Children().front()); - const ReferenceComponent& t_param_ref_comp(t_param_ref.Value()); + const ReferenceComponentNode &t_param_ref(cc_ref.Children().front()); + const ReferenceComponent &t_param_ref_comp(t_param_ref.Value()); EXPECT_EQ(t_param_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(t_param_ref_comp.required_metatype, SymbolMetaType::kParameter); EXPECT_EQ(t_param_ref_comp.identifier, "T"); @@ -4174,7 +4174,7 @@ TEST(BuildSymbolTableTest, // Of all the "outer::cc" type refs, the outer one is the first one, by // ordering of textual position among references that start with the same // identifier. - const DependentReferences& data_cc_type(**outer_refs.begin()); + const DependentReferences &data_cc_type(**outer_refs.begin()); EXPECT_EQ(data_info.declared_type.user_defined_type, data_cc_type.LastTypeComponent()); @@ -4183,22 +4183,22 @@ TEST(BuildSymbolTableTest, symbol_table.Resolve(&resolve_diagnostics); EXPECT_EMPTY_STATUSES(resolve_diagnostics); - for (const auto& outer_ref : outer_refs) { - const ReferenceComponent& outer_ref_comp(outer_ref->components->Value()); + for (const auto &outer_ref : outer_refs) { + const ReferenceComponent &outer_ref_comp(outer_ref->components->Value()); EXPECT_EQ(outer_ref_comp.resolved_symbol, &outer_class); - const ReferenceComponentNode& s_param_ref( + const ReferenceComponentNode &s_param_ref( outer_ref->components->Children().front()); - const ReferenceComponent& s_param_ref_comp(s_param_ref.Value()); + const ReferenceComponent &s_param_ref_comp(s_param_ref.Value()); EXPECT_EQ(s_param_ref_comp.resolved_symbol, &s_type_param); - const ReferenceComponentNode& cc_ref( + const ReferenceComponentNode &cc_ref( outer_ref->components->Children().back()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.resolved_symbol, &cc_class); - const ReferenceComponentNode& t_param_ref(cc_ref.Children().front()); - const ReferenceComponent& t_param_ref_comp(t_param_ref.Value()); + const ReferenceComponentNode &t_param_ref(cc_ref.Children().front()); + const ReferenceComponent &t_param_ref_comp(t_param_ref.Value()); EXPECT_EQ(t_param_ref_comp.resolved_symbol, &t_type_param); } // type of "data" is resolved @@ -4215,7 +4215,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationNoReturnType) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4243,7 +4243,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationWithPort) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4281,7 +4281,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationWithLocalVariable) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4317,7 +4317,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationVoidReturnType) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4348,7 +4348,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationClassReturnType) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4361,10 +4361,10 @@ TEST(BuildSymbolTableTest, FunctionDeclarationClassReturnType) { EXPECT_EQ(verible::StringSpanOfSymbol( *function_ff_info.declared_type.syntax_origin), "cc"); - const ReferenceComponentNode* cc_ref = + const ReferenceComponentNode *cc_ref = function_ff_info.declared_type.user_defined_type; ASSERT_NE(cc_ref, nullptr); - const ReferenceComponent& cc_ref_comp(cc_ref->Value()); + const ReferenceComponent &cc_ref_comp(cc_ref->Value()); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.identifier, "cc"); @@ -4392,7 +4392,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationInModule) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4405,7 +4405,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationInModule) { EXPECT_EQ(verible::StringSpanOfSymbol( *function_ff_info.declared_type.syntax_origin), "void"); - const ReferenceComponentNode* ff_type = + const ReferenceComponentNode *ff_type = function_ff_info.declared_type.user_defined_type; EXPECT_EQ(ff_type, nullptr); @@ -4430,7 +4430,7 @@ TEST(BuildSymbolTableTest, ClassMethodFunctionDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4443,7 +4443,7 @@ TEST(BuildSymbolTableTest, ClassMethodFunctionDeclaration) { EXPECT_EQ(verible::StringSpanOfSymbol( *function_ff_info.declared_type.syntax_origin), "int"); - const ReferenceComponentNode* ff_type = + const ReferenceComponentNode *ff_type = function_ff_info.declared_type.user_defined_type; EXPECT_EQ(ff_type, nullptr); @@ -4475,7 +4475,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4494,19 +4494,19 @@ TEST(BuildSymbolTableTest, "aa::vv"); // return type points to the last component of the chain, "vv" - const ReferenceComponentNode* vv_ref = + const ReferenceComponentNode *vv_ref = function_ff_info.declared_type.user_defined_type; ASSERT_NE(vv_ref, nullptr); - const ReferenceComponent& vv_ref_comp(vv_ref->Value()); + const ReferenceComponent &vv_ref_comp(vv_ref->Value()); EXPECT_EQ(vv_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(vv_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(vv_ref_comp.identifier, "vv"); EXPECT_EQ(vv_ref_comp.resolved_symbol, nullptr); // dependent reference parent is "aa" in "aa::vv" - const ReferenceComponentNode* aa_ref = vv_ref->Parent(); + const ReferenceComponentNode *aa_ref = vv_ref->Parent(); ASSERT_NE(aa_ref, nullptr); - const ReferenceComponent& aa_ref_comp(aa_ref->Value()); + const ReferenceComponent &aa_ref_comp(aa_ref->Value()); EXPECT_EQ(aa_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(aa_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(aa_ref_comp.identifier, "aa"); @@ -4537,7 +4537,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationOutOfLineMissingOuterClass) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); { @@ -4573,7 +4573,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationOutOfLineInvalidModuleInjection) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); { @@ -4596,8 +4596,8 @@ TEST(BuildSymbolTableTest, FunctionDeclarationOutOfLineInvalidModuleInjection) { EXPECT_EQ(mm_ref->components->Value().resolved_symbol, nullptr); // Method injection will not happen for modules. - const ReferenceComponentNode* ff_ref = mm_ref->LastLeaf(); - const ReferenceComponent& ref(ff_ref->Value()); + const ReferenceComponentNode *ff_ref = mm_ref->LastLeaf(); + const ReferenceComponent &ref(ff_ref->Value()); EXPECT_EQ(ref.identifier, "ff"); EXPECT_EQ(ref.resolved_symbol, nullptr); @@ -4622,7 +4622,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationOutOfLineMissingPrototype) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); { @@ -4647,8 +4647,8 @@ TEST(BuildSymbolTableTest, FunctionDeclarationOutOfLineMissingPrototype) { EXPECT_EQ(cc_ref->components->Value().resolved_symbol, &class_cc); // Method reference is resolved to the injected symbol. - const ReferenceComponentNode* ff_ref = cc_ref->LastLeaf(); - const ReferenceComponent& ref(ff_ref->Value()); + const ReferenceComponentNode *ff_ref = cc_ref->LastLeaf(); + const ReferenceComponent &ref(ff_ref->Value()); EXPECT_EQ(ref.identifier, "ff"); EXPECT_EQ(ref.resolved_symbol, &method_ff); @@ -4671,7 +4671,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationMethodPrototypeOnly) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4715,7 +4715,7 @@ TEST(BuildSymbolTableTest, FunctionDeclarationOutOfLineWithMethodPrototype) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4750,8 +4750,8 @@ TEST(BuildSymbolTableTest, FunctionDeclarationOutOfLineWithMethodPrototype) { EXPECT_EQ(cc_ref->components->Value().resolved_symbol, &class_cc); // Method reference is resolved to the injected symbol. - const ReferenceComponentNode* ff_ref = cc_ref->LastLeaf(); - const ReferenceComponent& ref(ff_ref->Value()); + const ReferenceComponentNode *ff_ref = cc_ref->LastLeaf(); + const ReferenceComponent &ref(ff_ref->Value()); EXPECT_EQ(ref.identifier, "ff"); EXPECT_EQ(ref.resolved_symbol, &method_ff); @@ -4776,7 +4776,7 @@ TEST(BuildSymbolTableTest, TaskDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4805,7 +4805,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationInPackage) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4835,7 +4835,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationInModule) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4865,7 +4865,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationInClass) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4893,7 +4893,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationWithPorts) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -4929,7 +4929,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationOutOfLineMissingOuterClass) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); { @@ -4966,7 +4966,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationOutOfLineMissingPrototype) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); { @@ -4991,8 +4991,8 @@ TEST(BuildSymbolTableTest, TaskDeclarationOutOfLineMissingPrototype) { EXPECT_EQ(cc_ref->components->Value().resolved_symbol, &class_cc); // Method reference is resolved to the injected symbol. - const ReferenceComponentNode* tt_ref = cc_ref->LastLeaf(); - const ReferenceComponent& ref(tt_ref->Value()); + const ReferenceComponentNode *tt_ref = cc_ref->LastLeaf(); + const ReferenceComponent &ref(tt_ref->Value()); EXPECT_EQ(ref.identifier, "tt"); EXPECT_EQ(ref.resolved_symbol, &method_tt); @@ -5016,7 +5016,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationOutOfLineInvalidPackageInjection) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); { @@ -5039,8 +5039,8 @@ TEST(BuildSymbolTableTest, TaskDeclarationOutOfLineInvalidPackageInjection) { EXPECT_EQ(pp_ref->components->Value().resolved_symbol, nullptr); // Method injection will not happen for packages. - const ReferenceComponentNode* tt_ref = pp_ref->LastLeaf(); - const ReferenceComponent& ref(tt_ref->Value()); + const ReferenceComponentNode *tt_ref = pp_ref->LastLeaf(); + const ReferenceComponent &ref(tt_ref->Value()); EXPECT_EQ(ref.identifier, "tt"); EXPECT_EQ(ref.resolved_symbol, nullptr); @@ -5063,7 +5063,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationMethodPrototypeOnly) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5103,7 +5103,7 @@ TEST(BuildSymbolTableTest, TaskDeclarationOutOfLineWithMethodPrototype) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5135,8 +5135,8 @@ TEST(BuildSymbolTableTest, TaskDeclarationOutOfLineWithMethodPrototype) { EXPECT_EQ(cc_ref->components->Value().resolved_symbol, &class_cc); // Method reference is resolved to the injected symbol. - const ReferenceComponentNode* tt_ref = cc_ref->LastLeaf(); - const ReferenceComponent& ref(tt_ref->Value()); + const ReferenceComponentNode *tt_ref = cc_ref->LastLeaf(); + const ReferenceComponent &ref(tt_ref->Value()); EXPECT_EQ(ref.identifier, "tt"); EXPECT_EQ(ref.resolved_symbol, &method_tt); @@ -5165,7 +5165,7 @@ TEST(BuildSymbolTableTest, OutOfLineDefinitionMismatchesPrototype) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); ASSIGN_MUST_HAVE_UNIQUE(err, build_diagnostics); @@ -5194,8 +5194,8 @@ TEST(BuildSymbolTableTest, OutOfLineDefinitionMismatchesPrototype) { EXPECT_EQ(cc_ref->components->Value().resolved_symbol, &class_cc); // Method reference "tt" fails to resolve due to metatype mismatch. - const ReferenceComponentNode* tt_ref = cc_ref->LastLeaf(); - const ReferenceComponent& ref(tt_ref->Value()); + const ReferenceComponentNode *tt_ref = cc_ref->LastLeaf(); + const ReferenceComponent &ref(tt_ref->Value()); EXPECT_EQ(ref.identifier, "tt"); EXPECT_EQ(ref.resolved_symbol, nullptr); @@ -5227,7 +5227,7 @@ TEST(BuildSymbolTableTest, FunctionCallResolvedSameScope) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5242,7 +5242,7 @@ TEST(BuildSymbolTableTest, FunctionCallResolvedSameScope) { EXPECT_EQ(function_vv_info.local_references_to_bind.size(), 1); const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(tt_ref, ref_map, "tt"); - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); @@ -5264,7 +5264,7 @@ TEST(BuildSymbolTableTest, FunctionCallUnresolved) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5276,7 +5276,7 @@ TEST(BuildSymbolTableTest, FunctionCallUnresolved) { EXPECT_EQ(function_vv_info.local_references_to_bind.size(), 1); const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(tt_ref, ref_map, "tt"); - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); @@ -5302,7 +5302,7 @@ TEST(BuildSymbolTableTest, FunctionCallUnresolvedNamedParameters) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5314,7 +5314,7 @@ TEST(BuildSymbolTableTest, FunctionCallUnresolvedNamedParameters) { EXPECT_EQ(function_vv_info.local_references_to_bind.size(), 1); const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(tt_ref, ref_map, "tt"); - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); @@ -5322,7 +5322,7 @@ TEST(BuildSymbolTableTest, FunctionCallUnresolvedNamedParameters) { ReferenceComponentNodeMapView(*tt_ref->components)); ASSIGN_MUST_FIND(a_ref, param_refs, "a"); - const ReferenceComponent& a_ref_comp(a_ref->Value()); + const ReferenceComponent &a_ref_comp(a_ref->Value()); EXPECT_EQ(a_ref_comp.identifier, "a"); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(a_ref_comp.required_metatype, @@ -5330,7 +5330,7 @@ TEST(BuildSymbolTableTest, FunctionCallUnresolvedNamedParameters) { EXPECT_EQ(a_ref_comp.resolved_symbol, nullptr); // not yet resolved ASSIGN_MUST_FIND(b_ref, param_refs, "b"); - const ReferenceComponent& b_ref_comp(b_ref->Value()); + const ReferenceComponent &b_ref_comp(b_ref->Value()); EXPECT_EQ(b_ref_comp.identifier, "b"); EXPECT_EQ(b_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(b_ref_comp.required_metatype, @@ -5364,7 +5364,7 @@ TEST(BuildSymbolTableTest, FunctionCallResolvedNamedParameters) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5389,7 +5389,7 @@ TEST(BuildSymbolTableTest, FunctionCallResolvedNamedParameters) { EXPECT_EQ(function_vv_info.local_references_to_bind.size(), 1); const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(tt_ref, ref_map, "tt"); - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); @@ -5397,7 +5397,7 @@ TEST(BuildSymbolTableTest, FunctionCallResolvedNamedParameters) { ReferenceComponentNodeMapView(*tt_ref->components)); ASSIGN_MUST_FIND(a_ref, param_refs, "a"); - const ReferenceComponent& a_ref_comp(a_ref->Value()); + const ReferenceComponent &a_ref_comp(a_ref->Value()); EXPECT_EQ(a_ref_comp.identifier, "a"); EXPECT_EQ(a_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(a_ref_comp.required_metatype, @@ -5405,7 +5405,7 @@ TEST(BuildSymbolTableTest, FunctionCallResolvedNamedParameters) { EXPECT_EQ(a_ref_comp.resolved_symbol, nullptr); // not yet resolved ASSIGN_MUST_FIND(b_ref, param_refs, "b"); - const ReferenceComponent& b_ref_comp(b_ref->Value()); + const ReferenceComponent &b_ref_comp(b_ref->Value()); EXPECT_EQ(b_ref_comp.identifier, "b"); EXPECT_EQ(b_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(b_ref_comp.required_metatype, @@ -5434,7 +5434,7 @@ TEST(BuildSymbolTableTest, CallNonFunction) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5449,7 +5449,7 @@ TEST(BuildSymbolTableTest, CallNonFunction) { EXPECT_EQ(function_vv_info.local_references_to_bind.size(), 1); const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(tt_ref, ref_map, "tt"); - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); @@ -5477,7 +5477,7 @@ TEST(BuildSymbolTableTest, NestedCallsArguments) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5495,7 +5495,7 @@ TEST(BuildSymbolTableTest, NestedCallsArguments) { EXPECT_EQ(function_tt_info.local_references_to_bind.size(), 1); const auto tt_ref_map(function_tt_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(aa_ref, tt_ref_map, "aa"); - const ReferenceComponent& aa_ref_comp(aa_ref->components->Value()); + const ReferenceComponent &aa_ref_comp(aa_ref->components->Value()); EXPECT_EQ(aa_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(aa_ref_comp.resolved_symbol, nullptr); @@ -5503,8 +5503,8 @@ TEST(BuildSymbolTableTest, NestedCallsArguments) { EXPECT_EQ(function_vv_info.local_references_to_bind.size(), 3); const auto vv_ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(tt_refs, vv_ref_map, "tt"); - for (const auto& tt_ref : tt_refs) { - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + for (const auto &tt_ref : tt_refs) { + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); } @@ -5517,8 +5517,8 @@ TEST(BuildSymbolTableTest, NestedCallsArguments) { EXPECT_EQ(aa_ref_comp.resolved_symbol, &arg_aa); // Calls to "tt" are all resolved. - for (const auto& tt_ref : tt_refs) { - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + for (const auto &tt_ref : tt_refs) { + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.resolved_symbol, &function_tt); } } @@ -5532,7 +5532,7 @@ TEST(BuildSymbolTableTest, SelfRecursion) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5544,7 +5544,7 @@ TEST(BuildSymbolTableTest, SelfRecursion) { EXPECT_EQ(function_tt_info.local_references_to_bind.size(), 1); const auto tt_ref_map(function_tt_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(tt_ref, tt_ref_map, "tt"); - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); @@ -5569,7 +5569,7 @@ TEST(BuildSymbolTableTest, MutualRecursion) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5584,14 +5584,14 @@ TEST(BuildSymbolTableTest, MutualRecursion) { EXPECT_EQ(function_tt_info.local_references_to_bind.size(), 1); const auto tt_ref_map(function_tt_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(vv_ref, tt_ref_map, "vv"); - const ReferenceComponent& vv_ref_comp(vv_ref->components->Value()); + const ReferenceComponent &vv_ref_comp(vv_ref->components->Value()); EXPECT_EQ(vv_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(vv_ref_comp.resolved_symbol, nullptr); EXPECT_EQ(function_vv_info.local_references_to_bind.size(), 1); const auto vv_ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(tt_ref, vv_ref_map, "tt"); - const ReferenceComponent& tt_ref_comp(tt_ref->components->Value()); + const ReferenceComponent &tt_ref_comp(tt_ref->components->Value()); EXPECT_EQ(tt_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(tt_ref_comp.resolved_symbol, nullptr); @@ -5619,7 +5619,7 @@ TEST(BuildSymbolTableTest, PackageQualifiedFunctionCall) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5637,12 +5637,12 @@ TEST(BuildSymbolTableTest, PackageQualifiedFunctionCall) { const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_ref, ref_map, "pp"); ASSERT_EQ(pp_ref->components->Children().size(), 1); - const ReferenceComponent& pp_ref_comp(pp_ref->components->Value()); + const ReferenceComponent &pp_ref_comp(pp_ref->components->Value()); EXPECT_EQ(pp_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_ref_comp.resolved_symbol, nullptr); - const ReferenceComponent& tt_ref_comp( + const ReferenceComponent &tt_ref_comp( pp_ref->components->Children().front().Value()); EXPECT_EQ(tt_ref_comp.identifier, "tt"); EXPECT_EQ(tt_ref_comp.ref_type, ReferenceType::kDirectMember); @@ -5673,7 +5673,7 @@ TEST(BuildSymbolTableTest, ClassQualifiedFunctionCall) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5691,12 +5691,12 @@ TEST(BuildSymbolTableTest, ClassQualifiedFunctionCall) { const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(cc_ref, ref_map, "cc"); ASSERT_EQ(cc_ref->components->Children().size(), 1); - const ReferenceComponent& cc_ref_comp(cc_ref->components->Value()); + const ReferenceComponent &cc_ref_comp(cc_ref->components->Value()); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.resolved_symbol, nullptr); - const ReferenceComponent& tt_ref_comp( + const ReferenceComponent &tt_ref_comp( cc_ref->components->Children().front().Value()); EXPECT_EQ(tt_ref_comp.identifier, "tt"); EXPECT_EQ(tt_ref_comp.ref_type, ReferenceType::kDirectMember); @@ -5724,7 +5724,7 @@ TEST(BuildSymbolTableTest, ClassQualifiedFunctionCallUnresolved) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5739,12 +5739,12 @@ TEST(BuildSymbolTableTest, ClassQualifiedFunctionCallUnresolved) { const auto ref_map(function_vv_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(cc_ref, ref_map, "cc"); ASSERT_EQ(cc_ref->components->Children().size(), 1); - const ReferenceComponent& cc_ref_comp(cc_ref->components->Value()); + const ReferenceComponent &cc_ref_comp(cc_ref->components->Value()); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.resolved_symbol, nullptr); - const ReferenceComponent& tt_ref_comp( + const ReferenceComponent &tt_ref_comp( cc_ref->components->Children().front().Value()); EXPECT_EQ(tt_ref_comp.identifier, "tt"); EXPECT_EQ(tt_ref_comp.ref_type, ReferenceType::kDirectMember); @@ -5776,7 +5776,7 @@ TEST(BuildSymbolTableTest, ClassMethodCall) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5797,17 +5797,17 @@ TEST(BuildSymbolTableTest, ClassMethodCall) { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(cc_type_ref, ref_map, "cc"); // "cc" is a type - const ReferenceComponent& cc_type_ref_comp(cc_type_ref->components->Value()); + const ReferenceComponent &cc_type_ref_comp(cc_type_ref->components->Value()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(cc_obj_ref, ref_map, "cc_obj"); // "cc_obj" is data ASSERT_EQ(cc_obj_ref->components->Children().size(), 1); - const ReferenceComponent& cc_obj_ref_comp(cc_obj_ref->components->Value()); + const ReferenceComponent &cc_obj_ref_comp(cc_obj_ref->components->Value()); EXPECT_EQ(cc_obj_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_obj_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_obj_ref_comp.resolved_symbol, nullptr); - const ReferenceComponent& tt_ref_comp( + const ReferenceComponent &tt_ref_comp( cc_obj_ref->components->Children().front().Value()); EXPECT_EQ(tt_ref_comp.identifier, "tt"); EXPECT_EQ(tt_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); @@ -5837,7 +5837,7 @@ TEST(BuildSymbolTableTest, ClassMethodCallUnresolved) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5855,17 +5855,17 @@ TEST(BuildSymbolTableTest, ClassMethodCallUnresolved) { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(cc_type_ref, ref_map, "cc"); // "cc" is a type - const ReferenceComponent& cc_type_ref_comp(cc_type_ref->components->Value()); + const ReferenceComponent &cc_type_ref_comp(cc_type_ref->components->Value()); ASSIGN_MUST_FIND_EXACTLY_ONE_REF(cc_obj_ref, ref_map, "cc_obj"); // "cc_obj" is data ASSERT_EQ(cc_obj_ref->components->Children().size(), 1); - const ReferenceComponent& cc_obj_ref_comp(cc_obj_ref->components->Value()); + const ReferenceComponent &cc_obj_ref_comp(cc_obj_ref->components->Value()); EXPECT_EQ(cc_obj_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_obj_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_obj_ref_comp.resolved_symbol, nullptr); - const ReferenceComponent& tt_ref_comp( + const ReferenceComponent &tt_ref_comp( cc_obj_ref->components->Children().front().Value()); EXPECT_EQ(tt_ref_comp.identifier, "tt"); EXPECT_EQ(tt_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); @@ -5903,7 +5903,7 @@ TEST(BuildSymbolTableTest, ChainedMethodCall) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -5936,27 +5936,27 @@ TEST(BuildSymbolTableTest, ChainedMethodCall) { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(dd_type_ref, ref_map, "dd"); // "dd" is a type - const ReferenceComponent& dd_type_ref_comp(dd_type_ref->components->Value()); + const ReferenceComponent &dd_type_ref_comp(dd_type_ref->components->Value()); // Examine the dd_obj.gg().tt() reference chain. ASSIGN_MUST_FIND_EXACTLY_ONE_REF(dd_obj_ref, ref_map, "dd_obj"); // "dd_obj" is data ASSERT_EQ(dd_obj_ref->components->Children().size(), 1); - const ReferenceComponent& dd_obj_ref_comp(dd_obj_ref->components->Value()); + const ReferenceComponent &dd_obj_ref_comp(dd_obj_ref->components->Value()); EXPECT_EQ(dd_obj_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(dd_obj_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(dd_obj_ref_comp.resolved_symbol, nullptr); - const ReferenceComponentNode& dd_gg_ref( + const ReferenceComponentNode &dd_gg_ref( dd_obj_ref->components->Children().front()); - const ReferenceComponent& dd_gg_ref_comp(dd_gg_ref.Value()); + const ReferenceComponent &dd_gg_ref_comp(dd_gg_ref.Value()); EXPECT_EQ(dd_gg_ref_comp.identifier, "gg"); EXPECT_EQ(dd_gg_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(dd_gg_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(dd_gg_ref_comp.resolved_symbol, nullptr); - const ReferenceComponentNode& dd_gg_tt_ref(dd_gg_ref.Children().front()); - const ReferenceComponent& dd_gg_tt_ref_comp(dd_gg_tt_ref.Value()); + const ReferenceComponentNode &dd_gg_tt_ref(dd_gg_ref.Children().front()); + const ReferenceComponent &dd_gg_tt_ref_comp(dd_gg_tt_ref.Value()); EXPECT_EQ(dd_gg_tt_ref_comp.identifier, "tt"); EXPECT_EQ(dd_gg_tt_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(dd_gg_tt_ref_comp.required_metatype, SymbolMetaType::kCallable); @@ -6003,7 +6003,7 @@ TEST(BuildSymbolTableTest, ChainedMethodCallReturnTypeNotAClass) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6036,27 +6036,27 @@ TEST(BuildSymbolTableTest, ChainedMethodCallReturnTypeNotAClass) { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(dd_type_ref, ref_map, "dd"); // "dd" is a type - const ReferenceComponent& dd_type_ref_comp(dd_type_ref->components->Value()); + const ReferenceComponent &dd_type_ref_comp(dd_type_ref->components->Value()); // Examine the dd_obj.gg().tt() reference chain. ASSIGN_MUST_FIND_EXACTLY_ONE_REF(dd_obj_ref, ref_map, "dd_obj"); // "dd_obj" is data ASSERT_EQ(dd_obj_ref->components->Children().size(), 1); - const ReferenceComponent& dd_obj_ref_comp(dd_obj_ref->components->Value()); + const ReferenceComponent &dd_obj_ref_comp(dd_obj_ref->components->Value()); EXPECT_EQ(dd_obj_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(dd_obj_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(dd_obj_ref_comp.resolved_symbol, nullptr); - const ReferenceComponentNode& dd_gg_ref( + const ReferenceComponentNode &dd_gg_ref( dd_obj_ref->components->Children().front()); - const ReferenceComponent& dd_gg_ref_comp(dd_gg_ref.Value()); + const ReferenceComponent &dd_gg_ref_comp(dd_gg_ref.Value()); EXPECT_EQ(dd_gg_ref_comp.identifier, "gg"); EXPECT_EQ(dd_gg_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(dd_gg_ref_comp.required_metatype, SymbolMetaType::kCallable); EXPECT_EQ(dd_gg_ref_comp.resolved_symbol, nullptr); - const ReferenceComponentNode& dd_gg_tt_ref(dd_gg_ref.Children().front()); - const ReferenceComponent& dd_gg_tt_ref_comp(dd_gg_tt_ref.Value()); + const ReferenceComponentNode &dd_gg_tt_ref(dd_gg_ref.Children().front()); + const ReferenceComponent &dd_gg_tt_ref_comp(dd_gg_tt_ref.Value()); EXPECT_EQ(dd_gg_tt_ref_comp.identifier, "tt"); EXPECT_EQ(dd_gg_tt_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(dd_gg_tt_ref_comp.required_metatype, SymbolMetaType::kCallable); @@ -6092,7 +6092,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeData) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6103,12 +6103,12 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeData) { // Find the symbol that is a struct (anon), which is not "data". const auto found = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.first != "data"; }); ASSERT_NE(found, root_symbol.Children().end()); - const SymbolTableNode& anon_struct(found->second); - const SymbolInfo& anon_struct_info(anon_struct.Value()); + const SymbolTableNode &anon_struct(found->second); + const SymbolInfo &anon_struct_info(anon_struct.Value()); EXPECT_EQ(anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_info.local_references_to_bind.empty()); @@ -6123,9 +6123,9 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeData) { // Expect to bind anonymous struct immediately. ASSERT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( root_symbol.Value().local_references_to_bind.front()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6156,7 +6156,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiFields) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6167,12 +6167,12 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiFields) { // Find the symbol that is a struct (anon), which is not "data". const auto found = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.first != "data"; }); ASSERT_NE(found, root_symbol.Children().end()); - const SymbolTableNode& anon_struct(found->second); - const SymbolInfo& anon_struct_info(anon_struct.Value()); + const SymbolTableNode &anon_struct(found->second); + const SymbolInfo &anon_struct_info(anon_struct.Value()); EXPECT_EQ(anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_info.local_references_to_bind.empty()); @@ -6195,9 +6195,9 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiFields) { // Expect to bind anonymous struct immediately. ASSERT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( root_symbol.Value().local_references_to_bind.front()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6231,7 +6231,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiDeclaration) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6242,12 +6242,12 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiDeclaration) { // Find the symbol that is a struct (anon), which is not "data". const auto found = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.first != "data"; }); ASSERT_NE(found, root_symbol.Children().end()); - const SymbolTableNode& anon_struct(found->second); - const SymbolInfo& anon_struct_info(anon_struct.Value()); + const SymbolTableNode &anon_struct(found->second); + const SymbolInfo &anon_struct_info(anon_struct.Value()); EXPECT_EQ(anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_info.local_references_to_bind.empty()); @@ -6270,9 +6270,9 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiDeclaration) { // Expect to bind anonymous struct immediately. ASSERT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( root_symbol.Value().local_references_to_bind.front()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6302,7 +6302,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiVariables) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6313,12 +6313,12 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiVariables) { // Find the first symbol that is a struct (anon). const auto found = std::find_if( root_symbol.Children().begin(), root_symbol.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.second.Value().metatype == SymbolMetaType::kStruct; }); ASSERT_NE(found, root_symbol.Children().end()); - const SymbolTableNode& anon_struct(found->second); - const SymbolInfo& anon_struct_info(anon_struct.Value()); + const SymbolTableNode &anon_struct(found->second); + const SymbolInfo &anon_struct_info(anon_struct.Value()); EXPECT_EQ(anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_info.local_references_to_bind.empty()); @@ -6333,9 +6333,9 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiVariables) { // Expect to bind anonymous struct immediately. ASSERT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( root_symbol.Value().local_references_to_bind.front()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6371,7 +6371,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiVariables) { } } -static bool IsStruct(const SymbolTableNode::key_value_type& p) { +static bool IsStruct(const SymbolTableNode::key_value_type &p) { return p.second.Value().metatype == SymbolMetaType::kStruct; } @@ -6386,7 +6386,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiVariablesDistinctTypes) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6398,22 +6398,22 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiVariablesDistinctTypes) { const auto found = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), IsStruct); ASSERT_NE(found, root_symbol.Children().end()); - const SymbolTableNode& anon_struct(found->second); - const SymbolInfo& anon_struct_info(anon_struct.Value()); + const SymbolTableNode &anon_struct(found->second); + const SymbolInfo &anon_struct_info(anon_struct.Value()); EXPECT_EQ(anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_info.local_references_to_bind.empty()); const auto found_2 = std::find_if(std::next(found), root_symbol.Children().end(), IsStruct); ASSERT_NE(found_2, root_symbol.Children().end()); - const SymbolTableNode& anon_struct_2(found_2->second); - const SymbolInfo& anon_struct_2_info(anon_struct.Value()); + const SymbolTableNode &anon_struct_2(found_2->second); + const SymbolInfo &anon_struct_2_info(anon_struct.Value()); EXPECT_EQ(anon_struct_2_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_2_info.local_references_to_bind.empty()); // Struct has one member. Both structs have the same elements and structure, // but have distinct scopes in the symbol table. - for (const auto* anon_struct_iter : {&anon_struct, &anon_struct_2}) { + for (const auto *anon_struct_iter : {&anon_struct, &anon_struct_2}) { MUST_ASSIGN_LOOKUP_SYMBOL(int_size, *anon_struct_iter, "size"); EXPECT_EQ(int_size_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(int_size_info.file_origin, &src); @@ -6425,17 +6425,17 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeDataMultiVariablesDistinctTypes) { // Expect to bind both anonymous structs immediately. ASSERT_EQ(root_symbol.Value().local_references_to_bind.size(), 2); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( root_symbol.Value().local_references_to_bind.front()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); EXPECT_EQ(anon_struct_ref_comp.resolved_symbol, &anon_struct); - const DependentReferences& anon_struct_2_ref( + const DependentReferences &anon_struct_2_ref( root_symbol.Value().local_references_to_bind.back()); - const ReferenceComponent& anon_struct_2_ref_comp( + const ReferenceComponent &anon_struct_2_ref_comp( anon_struct_2_ref.components->Value()); EXPECT_EQ(anon_struct_2_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_2_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6483,7 +6483,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeFunctionParameter) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6497,12 +6497,12 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeFunctionParameter) { // Find the symbol that is a struct (anon). const auto found = std::find_if( ff_function.Children().begin(), ff_function.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.second.Value().metatype == SymbolMetaType::kStruct; }); ASSERT_NE(found, ff_function.Children().end()); - const SymbolTableNode& anon_struct(found->second); - const SymbolInfo& anon_struct_info(anon_struct.Value()); + const SymbolTableNode &anon_struct(found->second); + const SymbolInfo &anon_struct_info(anon_struct.Value()); EXPECT_EQ(anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_info.local_references_to_bind.empty()); @@ -6518,7 +6518,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeFunctionParameter) { const auto ref_map(ff_function_info.LocalReferencesMapViewForTesting()); // Expect one type reference and one reference rooted at "data". ASSIGN_MUST_FIND_EXACTLY_ONE_REF(data_ref, ref_map, "data"); - const ReferenceComponent& data_ref_comp(data_ref->components->Value()); + const ReferenceComponent &data_ref_comp(data_ref->components->Value()); EXPECT_EQ(data_ref_comp.identifier, "data"); EXPECT_EQ(data_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(data_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -6526,21 +6526,21 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeFunctionParameter) { // "data.weight" ASSIGN_MUST_HAVE_UNIQUE(weight_ref, data_ref->components->Children()); - const ReferenceComponent& weight_ref_comp(weight_ref.Value()); + const ReferenceComponent &weight_ref_comp(weight_ref.Value()); EXPECT_EQ(weight_ref_comp.identifier, "weight"); EXPECT_EQ(weight_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(weight_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(weight_ref_comp.resolved_symbol, nullptr); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( **std::find_if(ref_map.begin(), ref_map.end(), - [](const decltype(ref_map)::value_type& r) { + [](const decltype(ref_map)::value_type &r) { return (*r.second.begin()) ->components->Value() .required_metatype == SymbolMetaType::kStruct; }) ->second.begin()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6576,7 +6576,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNested) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6588,8 +6588,8 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNested) { const auto outer_found = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), IsStruct); ASSERT_NE(outer_found, root_symbol.Children().end()); - const SymbolTableNode& outer_anon_struct(outer_found->second); - const SymbolInfo& outer_anon_struct_info(outer_anon_struct.Value()); + const SymbolTableNode &outer_anon_struct(outer_found->second); + const SymbolInfo &outer_anon_struct_info(outer_anon_struct.Value()); EXPECT_EQ(outer_anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_EQ(outer_anon_struct_info.local_references_to_bind.size(), 1); // Expect one anonymous struct definition inside the outer struct. @@ -6607,16 +6607,16 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNested) { std::find_if(outer_anon_struct.Children().begin(), outer_anon_struct.Children().end(), IsStruct); ASSERT_NE(inner_found, outer_anon_struct.Children().end()); - const SymbolTableNode& inner_anon_struct(inner_found->second); - const SymbolInfo& inner_anon_struct_info(inner_anon_struct.Value()); + const SymbolTableNode &inner_anon_struct(inner_found->second); + const SymbolInfo &inner_anon_struct_info(inner_anon_struct.Value()); EXPECT_EQ(inner_anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(inner_anon_struct_info.local_references_to_bind.empty()); // "foo"'s type is pre-bound to the inner anonymous struct. - const ReferenceComponentNode* foo_type = + const ReferenceComponentNode *foo_type = struct_foo_info.declared_type.user_defined_type; ASSERT_NE(foo_type, nullptr); - const ReferenceComponent& foo_type_comp(foo_type->Value()); + const ReferenceComponent &foo_type_comp(foo_type->Value()); EXPECT_EQ(foo_type_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(foo_type_comp.required_metatype, SymbolMetaType::kStruct); EXPECT_EQ(foo_type_comp.resolved_symbol, &inner_anon_struct); @@ -6632,9 +6632,9 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNested) { // Expect to bind (outer) anonymous struct immediately. ASSERT_EQ(root_symbol.Value().local_references_to_bind.size(), 1); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( root_symbol.Value().local_references_to_bind.front()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6671,7 +6671,7 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNestedMemberReference) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6687,8 +6687,8 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNestedMemberReference) { const auto outer_found = std::find_if(function_ff.Children().begin(), function_ff.Children().end(), IsStruct); ASSERT_NE(outer_found, function_ff.Children().end()); - const SymbolTableNode& outer_anon_struct(outer_found->second); - const SymbolInfo& outer_anon_struct_info(outer_anon_struct.Value()); + const SymbolTableNode &outer_anon_struct(outer_found->second); + const SymbolInfo &outer_anon_struct_info(outer_anon_struct.Value()); EXPECT_EQ(outer_anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_EQ(outer_anon_struct_info.local_references_to_bind.size(), 1); // Expect one anonymous struct definition inside the outer struct. @@ -6706,16 +6706,16 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNestedMemberReference) { std::find_if(outer_anon_struct.Children().begin(), outer_anon_struct.Children().end(), IsStruct); ASSERT_NE(inner_found, outer_anon_struct.Children().end()); - const SymbolTableNode& inner_anon_struct(inner_found->second); - const SymbolInfo& inner_anon_struct_info(inner_anon_struct.Value()); + const SymbolTableNode &inner_anon_struct(inner_found->second); + const SymbolInfo &inner_anon_struct_info(inner_anon_struct.Value()); EXPECT_EQ(inner_anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(inner_anon_struct_info.local_references_to_bind.empty()); // "foo"'s type is pre-bound to the inner anonymous struct. - const ReferenceComponentNode* foo_type = + const ReferenceComponentNode *foo_type = struct_foo_info.declared_type.user_defined_type; ASSERT_NE(foo_type, nullptr); - const ReferenceComponent& foo_type_comp(foo_type->Value()); + const ReferenceComponent &foo_type_comp(foo_type->Value()); EXPECT_EQ(foo_type_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(foo_type_comp.required_metatype, SymbolMetaType::kStruct); EXPECT_EQ(foo_type_comp.resolved_symbol, &inner_anon_struct); @@ -6733,9 +6733,9 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNestedMemberReference) { // First reference to anonymous struct, second reference to "data". ASSERT_EQ(function_ff_info.local_references_to_bind.size(), 2); - const DependentReferences& anon_struct_ref( + const DependentReferences &anon_struct_ref( function_ff_info.local_references_to_bind.front()); - const ReferenceComponent& anon_struct_ref_comp( + const ReferenceComponent &anon_struct_ref_comp( anon_struct_ref.components->Value()); EXPECT_EQ(anon_struct_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_struct_ref_comp.required_metatype, SymbolMetaType::kStruct); @@ -6749,23 +6749,23 @@ TEST(BuildSymbolTableTest, AnonymousStructTypeNestedMemberReference) { anon_struct_ref.LastLeaf()); // Find the "data.foo.size" reference - const DependentReferences& data_ref( + const DependentReferences &data_ref( function_ff_info.local_references_to_bind.back()); - const ReferenceComponent& data_ref_comp(data_ref.components->Value()); + const ReferenceComponent &data_ref_comp(data_ref.components->Value()); EXPECT_EQ(data_ref_comp.identifier, "data"); EXPECT_EQ(data_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(data_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(data_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(data_foo_ref, data_ref.components->Children()); - const ReferenceComponent& data_foo_ref_comp(data_foo_ref.Value()); + const ReferenceComponent &data_foo_ref_comp(data_foo_ref.Value()); EXPECT_EQ(data_foo_ref_comp.identifier, "foo"); EXPECT_EQ(data_foo_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(data_foo_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(data_foo_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(data_foo_size_ref, data_foo_ref.Children()); - const ReferenceComponent& data_foo_size_ref_comp(data_foo_size_ref.Value()); + const ReferenceComponent &data_foo_size_ref_comp(data_foo_size_ref.Value()); EXPECT_EQ(data_foo_size_ref_comp.identifier, "size"); EXPECT_EQ(data_foo_size_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); @@ -6795,7 +6795,7 @@ TEST(BuildSymbolTableTest, AnonymousEnumTypeData) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6809,12 +6809,12 @@ TEST(BuildSymbolTableTest, AnonymousEnumTypeData) { // Find the symbol that is a enum (anon) const auto found = std::find_if( root_symbol.Children().begin(), root_symbol.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.first != "data" && p.first != "idle" && p.first != "busy"; }); ASSERT_NE(found, root_symbol.Children().end()); - const SymbolTableNode& anon_enum(found->second); - const SymbolInfo& anon_enum_info(anon_enum.Value()); + const SymbolTableNode &anon_enum(found->second); + const SymbolInfo &anon_enum_info(anon_enum.Value()); EXPECT_EQ(anon_enum_info.metatype, SymbolMetaType::kEnumType); EXPECT_TRUE(anon_enum_info.local_references_to_bind.empty()); @@ -6834,24 +6834,24 @@ TEST(BuildSymbolTableTest, AnonymousEnumTypeData) { // Find idle symbol const auto found_enum_idle = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.first == "idle"; }); ASSERT_NE(found_enum_idle, root_symbol.Children().end()); - const SymbolTableNode& enum_idle(found_enum_idle->second); - const SymbolInfo& enum_idle_info(enum_idle.Value()); + const SymbolTableNode &enum_idle(found_enum_idle->second); + const SymbolInfo &enum_idle_info(enum_idle.Value()); EXPECT_EQ(enum_idle_info.metatype, SymbolMetaType::kTypeAlias); EXPECT_TRUE(enum_idle_info.local_references_to_bind.empty()); // Find busy symbol const auto found_enum_busy = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), - [](const SymbolTableNode::key_value_type& p) { + [](const SymbolTableNode::key_value_type &p) { return p.first == "busy"; }); ASSERT_NE(found_enum_busy, root_symbol.Children().end()); - const SymbolTableNode& enum_busy(found_enum_busy->second); - const SymbolInfo& enum_busy_info(enum_busy.Value()); + const SymbolTableNode &enum_busy(found_enum_busy->second); + const SymbolInfo &enum_busy_info(enum_busy.Value()); EXPECT_EQ(enum_busy_info.metatype, SymbolMetaType::kTypeAlias); EXPECT_TRUE(enum_busy_info.local_references_to_bind.empty()); @@ -6860,20 +6860,20 @@ TEST(BuildSymbolTableTest, AnonymousEnumTypeData) { // Expect them to bind immediately. - const ReferenceComponent& anon_enum_ref_comp( + const ReferenceComponent &anon_enum_ref_comp( root_symbol.Value().local_references_to_bind[2].LastLeaf()->Value()); EXPECT_EQ(anon_enum_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(anon_enum_ref_comp.required_metatype, SymbolMetaType::kEnumType); EXPECT_EQ(anon_enum_ref_comp.resolved_symbol, &anon_enum); - const ReferenceComponent& enum_idle_ref_comp( + const ReferenceComponent &enum_idle_ref_comp( root_symbol.Value().local_references_to_bind[0].LastLeaf()->Value()); EXPECT_EQ(enum_idle_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(enum_idle_ref_comp.required_metatype, SymbolMetaType::kEnumConstant); EXPECT_EQ(enum_idle_ref_comp.resolved_symbol, &busy); - const ReferenceComponent& enum_busy_ref_comp( + const ReferenceComponent &enum_busy_ref_comp( root_symbol.Value().local_references_to_bind[1].LastLeaf()->Value()); EXPECT_EQ(enum_busy_ref_comp.ref_type, ReferenceType::kImmediate); EXPECT_EQ(enum_busy_ref_comp.required_metatype, @@ -6885,7 +6885,7 @@ TEST(BuildSymbolTableTest, AnonymousEnumTypeData) { EXPECT_EQ(data_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(data_info.file_origin, &src); - const DependentReferences& anon_enum_ref( + const DependentReferences &anon_enum_ref( root_symbol.Value().local_references_to_bind[2]); EXPECT_EQ(data_info.declared_type.user_defined_type, anon_enum_ref.LastLeaf()); @@ -6909,7 +6909,7 @@ TEST(BuildSymbolTableTest, TypedefPrimitive) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6925,7 +6925,7 @@ TEST(BuildSymbolTableTest, TypedefPrimitive) { // Expect one type reference to "number". ASSIGN_MUST_HAVE_UNIQUE(number_ref, root_symbol.Value().local_references_to_bind); - const ReferenceComponent& number_ref_comp(number_ref.components->Value()); + const ReferenceComponent &number_ref_comp(number_ref.components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -6952,7 +6952,7 @@ TEST(BuildSymbolTableTest, TypedefTransitive) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -6973,7 +6973,7 @@ TEST(BuildSymbolTableTest, TypedefTransitive) { // Expect one type reference to "num". ASSIGN_MUST_FIND_EXACTLY_ONE_REF(num_ref, ref_map, "num"); - const ReferenceComponent& num_ref_comp(num_ref->components->Value()); + const ReferenceComponent &num_ref_comp(num_ref->components->Value()); EXPECT_EQ(num_ref_comp.identifier, "num"); EXPECT_EQ(num_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(num_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -6981,7 +6981,7 @@ TEST(BuildSymbolTableTest, TypedefTransitive) { // Expect one type reference to "number". ASSIGN_MUST_FIND_EXACTLY_ONE_REF(number_ref, ref_map, "number"); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7013,7 +7013,7 @@ TEST(BuildSymbolTableTest, TypedefClass) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7031,11 +7031,11 @@ TEST(BuildSymbolTableTest, TypedefClass) { EXPECT_EQ(foo_var_info.file_origin, &src); // Expect one type reference to "number", and one to "cc". - const auto& ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); + const auto &ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(cc_type_refs, ref_map, "cc"); ASSIGN_MUST_HAVE_UNIQUE(cc_type_ref, cc_type_refs); - const ReferenceComponent& cc_type_ref_comp(cc_type_ref->components->Value()); + const ReferenceComponent &cc_type_ref_comp(cc_type_ref->components->Value()); EXPECT_EQ(cc_type_ref_comp.identifier, "cc"); EXPECT_EQ(cc_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7043,7 +7043,7 @@ TEST(BuildSymbolTableTest, TypedefClass) { ASSIGN_MUST_FIND(number_refs, ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7073,7 +7073,7 @@ TEST(BuildSymbolTableTest, TypedefClassPackageQualified) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7094,19 +7094,19 @@ TEST(BuildSymbolTableTest, TypedefClassPackageQualified) { EXPECT_EQ(foo_var_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(foo_var_info.file_origin, &src); - const auto& ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); + const auto &ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); // Expect one type reference to "pp::cc". ASSIGN_MUST_FIND(pp_type_refs, ref_map, "pp"); ASSIGN_MUST_HAVE_UNIQUE(pp_type_ref, pp_type_refs); - const ReferenceComponent& pp_type_ref_comp(pp_type_ref->components->Value()); + const ReferenceComponent &pp_type_ref_comp(pp_type_ref->components->Value()); EXPECT_EQ(pp_type_ref_comp.identifier, "pp"); EXPECT_EQ(pp_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_type_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(cc_type_ref, pp_type_ref->components->Children()); - const ReferenceComponent& cc_type_ref_comp(cc_type_ref.Value()); + const ReferenceComponent &cc_type_ref_comp(cc_type_ref.Value()); EXPECT_EQ(cc_type_ref_comp.identifier, "cc"); EXPECT_EQ(cc_type_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7115,7 +7115,7 @@ TEST(BuildSymbolTableTest, TypedefClassPackageQualified) { // Expect one type reference to "number". ASSIGN_MUST_FIND(number_refs, ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7142,7 +7142,7 @@ TEST(BuildSymbolTableTest, TypedefClassUnresolvedQualifiedReferenceBase) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7155,19 +7155,19 @@ TEST(BuildSymbolTableTest, TypedefClassUnresolvedQualifiedReferenceBase) { EXPECT_EQ(foo_var_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(foo_var_info.file_origin, &src); - const auto& ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); + const auto &ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); // Expect one type reference to "pp::cc". ASSIGN_MUST_FIND(pp_type_refs, ref_map, "pp"); ASSIGN_MUST_HAVE_UNIQUE(pp_type_ref, pp_type_refs); - const ReferenceComponent& pp_type_ref_comp(pp_type_ref->components->Value()); + const ReferenceComponent &pp_type_ref_comp(pp_type_ref->components->Value()); EXPECT_EQ(pp_type_ref_comp.identifier, "pp"); EXPECT_EQ(pp_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_type_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(cc_type_ref, pp_type_ref->components->Children()); - const ReferenceComponent& cc_type_ref_comp(cc_type_ref.Value()); + const ReferenceComponent &cc_type_ref_comp(cc_type_ref.Value()); EXPECT_EQ(cc_type_ref_comp.identifier, "cc"); EXPECT_EQ(cc_type_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7176,7 +7176,7 @@ TEST(BuildSymbolTableTest, TypedefClassUnresolvedQualifiedReferenceBase) { // Expect one type reference to "number". ASSIGN_MUST_FIND(number_refs, ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7207,7 +7207,7 @@ TEST(BuildSymbolTableTest, TypedefClassPartiallyResolvedQualifiedReference) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7223,26 +7223,26 @@ TEST(BuildSymbolTableTest, TypedefClassPartiallyResolvedQualifiedReference) { EXPECT_EQ(foo_var_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(foo_var_info.file_origin, &src); - const auto& ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); + const auto &ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); // Expect one type reference to "pp::cc::dd". ASSIGN_MUST_FIND(pp_type_refs, ref_map, "pp"); ASSIGN_MUST_HAVE_UNIQUE(pp_type_ref, pp_type_refs); - const ReferenceComponent& pp_type_ref_comp(pp_type_ref->components->Value()); + const ReferenceComponent &pp_type_ref_comp(pp_type_ref->components->Value()); EXPECT_EQ(pp_type_ref_comp.identifier, "pp"); EXPECT_EQ(pp_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_type_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(cc_type_ref, pp_type_ref->components->Children()); - const ReferenceComponent& cc_type_ref_comp(cc_type_ref.Value()); + const ReferenceComponent &cc_type_ref_comp(cc_type_ref.Value()); EXPECT_EQ(cc_type_ref_comp.identifier, "cc"); EXPECT_EQ(cc_type_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_type_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(dd_type_ref, cc_type_ref.Children()); - const ReferenceComponent& dd_type_ref_comp(dd_type_ref.Value()); + const ReferenceComponent &dd_type_ref_comp(dd_type_ref.Value()); EXPECT_EQ(dd_type_ref_comp.identifier, "dd"); EXPECT_EQ(dd_type_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(dd_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7251,7 +7251,7 @@ TEST(BuildSymbolTableTest, TypedefClassPartiallyResolvedQualifiedReference) { // Expect one type reference to "number". ASSIGN_MUST_FIND(number_refs, ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7282,7 +7282,7 @@ TEST(BuildSymbolTableTest, TypedefOfClassTypeParameter) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7304,11 +7304,11 @@ TEST(BuildSymbolTableTest, TypedefOfClassTypeParameter) { EXPECT_EQ(foo_var_info.file_origin, &src); // Expect one type reference to "number", and one to "T". - const auto& ref_map(cc_class_info.LocalReferencesMapViewForTesting()); + const auto &ref_map(cc_class_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(t_type_refs, ref_map, "T"); ASSIGN_MUST_HAVE_UNIQUE(t_type_ref, t_type_refs); - const ReferenceComponent& t_type_ref_comp(t_type_ref->components->Value()); + const ReferenceComponent &t_type_ref_comp(t_type_ref->components->Value()); EXPECT_EQ(t_type_ref_comp.identifier, "T"); EXPECT_EQ(t_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(t_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7316,7 +7316,7 @@ TEST(BuildSymbolTableTest, TypedefOfClassTypeParameter) { ASSIGN_MUST_FIND(number_refs, ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7347,7 +7347,7 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassPositionalParams) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7372,11 +7372,11 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassPositionalParams) { EXPECT_EQ(foo_var_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(foo_var_info.file_origin, &src); - const auto& ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); + const auto &ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); // Expect one type reference to "number". ASSIGN_MUST_FIND(number_refs, ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7385,15 +7385,15 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassPositionalParams) { // Expect two type references to "pp::cc". ASSIGN_MUST_FIND(pp_refs, ref_map, "pp"); EXPECT_EQ(pp_refs.size(), 2); - for (const auto& pp_ref_iter : pp_refs) { - const ReferenceComponent& pp_ref_comp(pp_ref_iter->components->Value()); + for (const auto &pp_ref_iter : pp_refs) { + const ReferenceComponent &pp_ref_comp(pp_ref_iter->components->Value()); EXPECT_EQ(pp_ref_comp.identifier, "pp"); EXPECT_EQ(pp_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(cc_ref, pp_ref_iter->components->Children()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.identifier, "cc"); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7409,12 +7409,12 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassPositionalParams) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // Resolve "pp::cc" type references - for (const auto& pp_ref_iter : pp_refs) { - const ReferenceComponent& pp_ref_comp(pp_ref_iter->components->Value()); + for (const auto &pp_ref_iter : pp_refs) { + const ReferenceComponent &pp_ref_comp(pp_ref_iter->components->Value()); EXPECT_EQ(pp_ref_comp.resolved_symbol, &pp_package); ASSIGN_MUST_HAVE_UNIQUE(cc_ref, pp_ref_iter->components->Children()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.resolved_symbol, &cc_class); } // Resolve "number" type reference. @@ -7433,7 +7433,7 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassNamedParams) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7458,11 +7458,11 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassNamedParams) { EXPECT_EQ(foo_var_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(foo_var_info.file_origin, &src); - const auto& ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); + const auto &ref_map(root_symbol.Value().LocalReferencesMapViewForTesting()); // Expect one type reference to "number". ASSIGN_MUST_FIND(number_refs, ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7471,22 +7471,22 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassNamedParams) { // Expect two type references to "pp::cc#(.T(...))". ASSIGN_MUST_FIND(pp_refs, ref_map, "pp"); EXPECT_EQ(pp_refs.size(), 2); - for (const auto& pp_ref_iter : pp_refs) { - const ReferenceComponent& pp_ref_comp(pp_ref_iter->components->Value()); + for (const auto &pp_ref_iter : pp_refs) { + const ReferenceComponent &pp_ref_comp(pp_ref_iter->components->Value()); EXPECT_EQ(pp_ref_comp.identifier, "pp"); EXPECT_EQ(pp_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(pp_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(pp_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(cc_ref, pp_ref_iter->components->Children()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.identifier, "cc"); EXPECT_EQ(cc_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(cc_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(cc_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(t_param_ref, cc_ref.Children()); - const ReferenceComponent& t_param_ref_comp(t_param_ref.Value()); + const ReferenceComponent &t_param_ref_comp(t_param_ref.Value()); EXPECT_EQ(t_param_ref_comp.identifier, "T"); EXPECT_EQ(t_param_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(t_param_ref_comp.required_metatype, SymbolMetaType::kParameter); @@ -7502,16 +7502,16 @@ TEST(BuildSymbolTableTest, TypedefOfParameterizedClassNamedParams) { EXPECT_EMPTY_STATUSES(resolve_diagnostics); // Resolve "pp::cc#(.T(...))" type references - for (const auto& pp_ref_iter : pp_refs) { - const ReferenceComponent& pp_ref_comp(pp_ref_iter->components->Value()); + for (const auto &pp_ref_iter : pp_refs) { + const ReferenceComponent &pp_ref_comp(pp_ref_iter->components->Value()); EXPECT_EQ(pp_ref_comp.resolved_symbol, &pp_package); ASSIGN_MUST_HAVE_UNIQUE(cc_ref, pp_ref_iter->components->Children()); - const ReferenceComponent& cc_ref_comp(cc_ref.Value()); + const ReferenceComponent &cc_ref_comp(cc_ref.Value()); EXPECT_EQ(cc_ref_comp.resolved_symbol, &cc_class); ASSIGN_MUST_HAVE_UNIQUE(t_param_ref, cc_ref.Children()); - const ReferenceComponent& t_param_ref_comp(t_param_ref.Value()); + const ReferenceComponent &t_param_ref_comp(t_param_ref.Value()); EXPECT_EQ(t_param_ref_comp.resolved_symbol, &t_type_param); } // Resolve "number" type reference. @@ -7526,7 +7526,7 @@ TEST(BuildSymbolTableTest, InvalidMemberLookupOfAliasedType) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7540,18 +7540,18 @@ TEST(BuildSymbolTableTest, InvalidMemberLookupOfAliasedType) { "int"); // Expect one type reference to "number". - const auto& get_count_ref_map( + const auto &get_count_ref_map( root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(number_refs, get_count_ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(number_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(number_count_ref, number_ref->components->Children()); - const ReferenceComponent& number_count_ref_comp(number_count_ref.Value()); + const ReferenceComponent &number_count_ref_comp(number_count_ref.Value()); EXPECT_EQ(number_count_ref_comp.identifier, "count"); EXPECT_EQ(number_count_ref_comp.ref_type, ReferenceType::kDirectMember); EXPECT_EQ(number_count_ref_comp.required_metatype, @@ -7588,7 +7588,7 @@ TEST(BuildSymbolTableTest, InvalidMemberLookupOfTypedefPrimitive) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7611,11 +7611,11 @@ TEST(BuildSymbolTableTest, InvalidMemberLookupOfTypedefPrimitive) { EXPECT_EQ(foo_var_info.file_origin, &src); // Expect one type reference to "number". - const auto& get_count_ref_map( + const auto &get_count_ref_map( get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(number_refs, get_count_ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7623,14 +7623,14 @@ TEST(BuildSymbolTableTest, InvalidMemberLookupOfTypedefPrimitive) { ASSIGN_MUST_FIND(foo_refs, get_count_ref_map, "foo"); ASSIGN_MUST_HAVE_UNIQUE(foo_ref, foo_refs); - const ReferenceComponent& foo_ref_comp(foo_ref->components->Value()); + const ReferenceComponent &foo_ref_comp(foo_ref->components->Value()); EXPECT_EQ(foo_ref_comp.identifier, "foo"); EXPECT_EQ(foo_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(foo_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(foo_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(foo_count_ref, foo_ref->components->Children()); - const ReferenceComponent& foo_count_ref_comp(foo_count_ref.Value()); + const ReferenceComponent &foo_count_ref_comp(foo_count_ref.Value()); EXPECT_EQ(foo_count_ref_comp.identifier, "count"); EXPECT_EQ(foo_count_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(foo_count_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7667,7 +7667,7 @@ TEST(BuildSymbolTableTest, AccessClassMemberThroughTypedef) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7695,11 +7695,11 @@ TEST(BuildSymbolTableTest, AccessClassMemberThroughTypedef) { EXPECT_EQ(foo_var_info.file_origin, &src); // Expect one type reference to "cc". - const auto& root_ref_map( + const auto &root_ref_map( root_symbol.Value().LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(cc_type_refs, root_ref_map, "cc"); ASSIGN_MUST_HAVE_UNIQUE(cc_type_ref, cc_type_refs); - const ReferenceComponent& cc_type_ref_comp(cc_type_ref->components->Value()); + const ReferenceComponent &cc_type_ref_comp(cc_type_ref->components->Value()); EXPECT_EQ(cc_type_ref_comp.identifier, "cc"); EXPECT_EQ(cc_type_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(cc_type_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7709,11 +7709,11 @@ TEST(BuildSymbolTableTest, AccessClassMemberThroughTypedef) { cc_type_ref->LastTypeComponent()); // Expect one type reference to "number". - const auto& get_count_ref_map( + const auto &get_count_ref_map( get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(number_refs, get_count_ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7721,14 +7721,14 @@ TEST(BuildSymbolTableTest, AccessClassMemberThroughTypedef) { ASSIGN_MUST_FIND(foo_refs, get_count_ref_map, "foo"); ASSIGN_MUST_HAVE_UNIQUE(foo_ref, foo_refs); - const ReferenceComponent& foo_ref_comp(foo_ref->components->Value()); + const ReferenceComponent &foo_ref_comp(foo_ref->components->Value()); EXPECT_EQ(foo_ref_comp.identifier, "foo"); EXPECT_EQ(foo_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(foo_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(foo_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(foo_count_ref, foo_ref->components->Children()); - const ReferenceComponent& foo_count_ref_comp(foo_count_ref.Value()); + const ReferenceComponent &foo_count_ref_comp(foo_count_ref.Value()); EXPECT_EQ(foo_count_ref_comp.identifier, "count"); EXPECT_EQ(foo_count_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(foo_count_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7762,7 +7762,7 @@ TEST(BuildSymbolTableTest, AccessStructMemberThroughTypedef) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7771,8 +7771,8 @@ TEST(BuildSymbolTableTest, AccessStructMemberThroughTypedef) { const auto found = std::find_if(root_symbol.Children().begin(), root_symbol.Children().end(), IsStruct); ASSERT_NE(found, root_symbol.Children().end()); - const SymbolTableNode& anon_struct(found->second); - const SymbolInfo& anon_struct_info(anon_struct.Value()); + const SymbolTableNode &anon_struct(found->second); + const SymbolInfo &anon_struct_info(anon_struct.Value()); EXPECT_EQ(anon_struct_info.metatype, SymbolMetaType::kStruct); EXPECT_TRUE(anon_struct_info.local_references_to_bind.empty()); @@ -7801,11 +7801,11 @@ TEST(BuildSymbolTableTest, AccessStructMemberThroughTypedef) { &anon_struct); // Expect one type reference to "number". - const auto& get_count_ref_map( + const auto &get_count_ref_map( get_count_info.LocalReferencesMapViewForTesting()); ASSIGN_MUST_FIND(number_refs, get_count_ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7813,14 +7813,14 @@ TEST(BuildSymbolTableTest, AccessStructMemberThroughTypedef) { ASSIGN_MUST_FIND(foo_refs, get_count_ref_map, "foo"); ASSIGN_MUST_HAVE_UNIQUE(foo_ref, foo_refs); - const ReferenceComponent& foo_ref_comp(foo_ref->components->Value()); + const ReferenceComponent &foo_ref_comp(foo_ref->components->Value()); EXPECT_EQ(foo_ref_comp.identifier, "foo"); EXPECT_EQ(foo_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(foo_ref_comp.required_metatype, SymbolMetaType::kUnspecified); EXPECT_EQ(foo_ref_comp.resolved_symbol, nullptr); ASSIGN_MUST_HAVE_UNIQUE(foo_count_ref, foo_ref->components->Children()); - const ReferenceComponent& foo_count_ref_comp(foo_count_ref.Value()); + const ReferenceComponent &foo_count_ref_comp(foo_count_ref.Value()); EXPECT_EQ(foo_count_ref_comp.identifier, "count"); EXPECT_EQ(foo_count_ref_comp.ref_type, ReferenceType::kMemberOfTypeOfParent); EXPECT_EQ(foo_count_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7853,7 +7853,7 @@ TEST(BuildSymbolTableTest, InheritBaseClassThroughTypedef) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -7880,13 +7880,13 @@ TEST(BuildSymbolTableTest, InheritBaseClassThroughTypedef) { EXPECT_EQ(count_info.metatype, SymbolMetaType::kDataNetVariableInstance); EXPECT_EQ(count_info.file_origin, &src); - const auto& root_ref_map( + const auto &root_ref_map( root_symbol.Value().LocalReferencesMapViewForTesting()); // Expect one reference to "base" ASSIGN_MUST_FIND(base_type_refs, root_ref_map, "base"); ASSIGN_MUST_HAVE_UNIQUE(base_type_ref, base_type_refs); - const ReferenceComponent& base_type_ref_comp( + const ReferenceComponent &base_type_ref_comp( base_type_ref->components->Value()); EXPECT_EQ(base_type_ref_comp.identifier, "base"); EXPECT_EQ(base_type_ref_comp.ref_type, ReferenceType::kUnqualified); @@ -7899,7 +7899,7 @@ TEST(BuildSymbolTableTest, InheritBaseClassThroughTypedef) { // Expect one reference to "base_alias" ASSIGN_MUST_FIND(base_alias_refs, root_ref_map, "base_alias"); ASSIGN_MUST_HAVE_UNIQUE(base_alias_ref, base_alias_refs); - const ReferenceComponent& base_alias_ref_comp( + const ReferenceComponent &base_alias_ref_comp( base_alias_ref->components->Value()); EXPECT_EQ(base_alias_ref_comp.identifier, "base_alias"); EXPECT_EQ(base_alias_ref_comp.ref_type, ReferenceType::kUnqualified); @@ -7909,13 +7909,13 @@ TEST(BuildSymbolTableTest, InheritBaseClassThroughTypedef) { EXPECT_EQ(derived_class_info.parent_type.user_defined_type, base_alias_ref->components.get()); - const auto& derived_ref_map( + const auto &derived_ref_map( derived_class_info.LocalReferencesMapViewForTesting()); // Expect one type reference to "number". ASSIGN_MUST_FIND(number_refs, derived_ref_map, "number"); ASSIGN_MUST_HAVE_UNIQUE(number_ref, number_refs); - const ReferenceComponent& number_ref_comp(number_ref->components->Value()); + const ReferenceComponent &number_ref_comp(number_ref->components->Value()); EXPECT_EQ(number_ref_comp.identifier, "number"); EXPECT_EQ(number_ref_comp.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(number_ref_comp.required_metatype, SymbolMetaType::kUnspecified); @@ -7936,18 +7936,18 @@ TEST(BuildSymbolTableTest, InheritBaseClassThroughTypedef) { } } -static bool SourceFileLess(const TestVerilogSourceFile* left, - const TestVerilogSourceFile* right) { +static bool SourceFileLess(const TestVerilogSourceFile *left, + const TestVerilogSourceFile *right) { return left->ReferencedPath() < right->ReferencedPath(); } static void SortSourceFiles( - std::vector* sources) { + std::vector *sources) { std::sort(sources->begin(), sources->end(), SourceFileLess); } static bool PermuteSourceFiles( - std::vector* sources) { + std::vector *sources) { return std::next_permutation(sources->begin(), sources->end(), SourceFileLess); } @@ -7980,16 +7980,16 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstance) { // All permutations of the following file ordering should end up with the // same results. - std::vector ordering( + std::vector ordering( {&pp_src, &qq_src, &ss_src}); // start with the lexicographically "lowest" permutation SortSourceFiles(&ordering); int count = 0; do { SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); - for (const auto* src : ordering) { + for (const auto *src : ordering) { const auto build_diagnostics = BuildSymbolTable(*src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); } @@ -8016,9 +8016,9 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstance) { const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, qq_src.GetTextStructure()->Contents())); @@ -8039,9 +8039,9 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstance) { const auto ref_map(ss_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(qq_type, ref_map, "qq"); - const ReferenceComponentNode* ref_node = qq_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = qq_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "qq"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, ss_src.GetTextStructure()->Contents())); @@ -8061,7 +8061,7 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstance) { { // Verify pp_inst's type info EXPECT_TRUE(pp_inst_info.local_references_to_bind.empty()); EXPECT_NE(pp_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( pp_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8073,7 +8073,7 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstance) { { // Verify qq_inst's type info EXPECT_TRUE(qq_inst_info.local_references_to_bind.empty()); EXPECT_NE(qq_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& qq_type( + const ReferenceComponent &qq_type( qq_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(qq_type.identifier, "qq"); EXPECT_EQ(qq_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8126,7 +8126,7 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectOneFileAtATime) { const ScopedTestFile file3(sources_dir, text3); // Register files as part of project. - for (const auto* file : {&file1, &file2, &file3}) { + for (const auto *file : {&file1, &file2, &file3}) { const auto status_or_file = project.OpenTranslationUnit(Basename(file->filename())); ASSERT_TRUE(status_or_file.ok()); @@ -8138,13 +8138,13 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectOneFileAtATime) { // Caller decides order of processing files, which doesn't matter for this // example. std::vector build_diagnostics; - for (const auto* file : {&file3, &file2, &file1}) { + for (const auto *file : {&file3, &file2, &file1}) { symbol_table.BuildSingleTranslationUnit(Basename(file->filename()), &build_diagnostics); EXPECT_EMPTY_STATUSES(build_diagnostics); } - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); // Goal: resolve the reference of "pp" to this definition node. MUST_ASSIGN_LOOKUP_SYMBOL(pp, root_symbol, "pp"); @@ -8165,9 +8165,9 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectOneFileAtATime) { const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_EQ(ref.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(ref.required_metatype, SymbolMetaType::kUnspecified); @@ -8186,9 +8186,9 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectOneFileAtATime) { const auto ref_map(ss_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(qq_type, ref_map, "qq"); - const ReferenceComponentNode* ref_node = qq_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = qq_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "qq"); EXPECT_EQ(ref.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(ref.required_metatype, SymbolMetaType::kUnspecified); @@ -8206,7 +8206,7 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectOneFileAtATime) { { // Verify pp_inst's type info EXPECT_TRUE(pp_inst_info.local_references_to_bind.empty()); EXPECT_NE(pp_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( pp_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8217,7 +8217,7 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectOneFileAtATime) { { // Verify qq_inst's type info EXPECT_TRUE(qq_inst_info.local_references_to_bind.empty()); EXPECT_NE(qq_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& qq_type( + const ReferenceComponent &qq_type( qq_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(qq_type.identifier, "qq"); EXPECT_EQ(qq_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8282,7 +8282,7 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectFilesGood) { const ScopedTestFile file3(sources_dir, text3); // Register files as part of project. - for (const auto* file : {&file1, &file2, &file3}) { + for (const auto *file : {&file1, &file2, &file3}) { const auto status_or_file = project.OpenTranslationUnit(Basename(file->filename())); ASSERT_TRUE(status_or_file.ok()); @@ -8295,7 +8295,7 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectFilesGood) { symbol_table.Build(&build_diagnostics); EXPECT_EMPTY_STATUSES(build_diagnostics); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); // Goal: resolve the reference of "pp" to this definition node. MUST_ASSIGN_LOOKUP_SYMBOL(pp, root_symbol, "pp"); @@ -8316,9 +8316,9 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectFilesGood) { const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_EQ(ref.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(ref.required_metatype, SymbolMetaType::kUnspecified); @@ -8337,9 +8337,9 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectFilesGood) { const auto ref_map(ss_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(qq_type, ref_map, "qq"); - const ReferenceComponentNode* ref_node = qq_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = qq_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "qq"); EXPECT_EQ(ref.ref_type, ReferenceType::kUnqualified); EXPECT_EQ(ref.required_metatype, SymbolMetaType::kUnspecified); @@ -8357,7 +8357,7 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectFilesGood) { { // Verify pp_inst's type info EXPECT_TRUE(pp_inst_info.local_references_to_bind.empty()); EXPECT_NE(pp_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( pp_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8368,7 +8368,7 @@ TEST(BuildSymbolTableTest, ModuleInstancesFromProjectFilesGood) { { // Verify qq_inst's type info EXPECT_TRUE(qq_inst_info.local_references_to_bind.empty()); EXPECT_NE(qq_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& qq_type( + const ReferenceComponent &qq_type( qq_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(qq_type.identifier, "qq"); EXPECT_EQ(qq_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8411,7 +8411,7 @@ TEST(BuildSymbolTableTest, SingleFileModuleInstanceCyclicDependencies) { } SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); @@ -8441,9 +8441,9 @@ TEST(BuildSymbolTableTest, SingleFileModuleInstanceCyclicDependencies) { const auto ref_map(pp_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(ss_type, ref_map, "ss"); - const ReferenceComponentNode* ref_node = ss_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = ss_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "ss"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, src.GetTextStructure()->Contents())); @@ -8464,9 +8464,9 @@ TEST(BuildSymbolTableTest, SingleFileModuleInstanceCyclicDependencies) { const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, src.GetTextStructure()->Contents())); @@ -8487,9 +8487,9 @@ TEST(BuildSymbolTableTest, SingleFileModuleInstanceCyclicDependencies) { const auto ref_map(ss_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(qq_type, ref_map, "qq"); - const ReferenceComponentNode* ref_node = qq_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = qq_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "qq"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, src.GetTextStructure()->Contents())); @@ -8509,7 +8509,7 @@ TEST(BuildSymbolTableTest, SingleFileModuleInstanceCyclicDependencies) { { // Verify ss_inst's type info EXPECT_TRUE(ss_inst_info.local_references_to_bind.empty()); EXPECT_NE(ss_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& ss_type( + const ReferenceComponent &ss_type( ss_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(ss_type.identifier, "ss"); EXPECT_EQ(ss_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8521,7 +8521,7 @@ TEST(BuildSymbolTableTest, SingleFileModuleInstanceCyclicDependencies) { { // Verify pp_inst's type info EXPECT_TRUE(pp_inst_info.local_references_to_bind.empty()); EXPECT_NE(pp_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( pp_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8533,7 +8533,7 @@ TEST(BuildSymbolTableTest, SingleFileModuleInstanceCyclicDependencies) { { // Verify qq_inst's type info EXPECT_TRUE(qq_inst_info.local_references_to_bind.empty()); EXPECT_NE(qq_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& qq_type( + const ReferenceComponent &qq_type( qq_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(qq_type.identifier, "qq"); EXPECT_EQ(qq_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8592,16 +8592,16 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstanceCyclicDependencies) { // All permutations of the following file ordering should end up with the // same results. - std::vector ordering( + std::vector ordering( {&pp_src, &qq_src, &ss_src}); // start with the lexicographically "lowest" permutation SortSourceFiles(&ordering); int count = 0; do { SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); - for (const auto* src : ordering) { + for (const auto *src : ordering) { const auto build_diagnostics = BuildSymbolTable(*src, &symbol_table); EXPECT_EMPTY_STATUSES(build_diagnostics); } @@ -8631,9 +8631,9 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstanceCyclicDependencies) { const auto ref_map(pp_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(ss_type, ref_map, "ss"); - const ReferenceComponentNode* ref_node = ss_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = ss_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "ss"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, pp_src.GetTextStructure()->Contents())); @@ -8654,9 +8654,9 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstanceCyclicDependencies) { const auto ref_map(qq_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(pp_type, ref_map, "pp"); - const ReferenceComponentNode* ref_node = pp_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = pp_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "pp"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, qq_src.GetTextStructure()->Contents())); @@ -8677,9 +8677,9 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstanceCyclicDependencies) { const auto ref_map(ss_info.LocalReferencesMapViewForTesting()); { ASSIGN_MUST_FIND_EXACTLY_ONE_REF(qq_type, ref_map, "qq"); - const ReferenceComponentNode* ref_node = qq_type->LastTypeComponent(); + const ReferenceComponentNode *ref_node = qq_type->LastTypeComponent(); ASSERT_NE(ref_node, nullptr); - const ReferenceComponent& ref(ref_node->Value()); + const ReferenceComponent &ref(ref_node->Value()); EXPECT_EQ(ref.identifier, "qq"); EXPECT_TRUE(verible::IsSubRange(ref.identifier, ss_src.GetTextStructure()->Contents())); @@ -8699,7 +8699,7 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstanceCyclicDependencies) { { // Verify ss_inst's type info EXPECT_TRUE(ss_inst_info.local_references_to_bind.empty()); EXPECT_NE(ss_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& ss_type( + const ReferenceComponent &ss_type( ss_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(ss_type.identifier, "ss"); EXPECT_EQ(ss_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8711,7 +8711,7 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstanceCyclicDependencies) { { // Verify pp_inst's type info EXPECT_TRUE(pp_inst_info.local_references_to_bind.empty()); EXPECT_NE(pp_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& pp_type( + const ReferenceComponent &pp_type( pp_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(pp_type.identifier, "pp"); EXPECT_EQ(pp_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8723,7 +8723,7 @@ TEST(BuildSymbolTableTest, MultiFileModuleInstanceCyclicDependencies) { { // Verify qq_inst's type info EXPECT_TRUE(qq_inst_info.local_references_to_bind.empty()); EXPECT_NE(qq_inst_info.declared_type.user_defined_type, nullptr); - const ReferenceComponent& qq_type( + const ReferenceComponent &qq_type( qq_inst_info.declared_type.user_defined_type->Value()); EXPECT_EQ(qq_type.identifier, "qq"); EXPECT_EQ(qq_type.resolved_symbol, nullptr); // nothing resolved yet @@ -8772,7 +8772,7 @@ TEST(BuildSymbolTableTest, IncludeModuleDefinition) { ASSERT_TRUE(file_or_status.ok()) << file_or_status.status().message(); SymbolTable symbol_table(&project); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); std::vector build_diagnostics; symbol_table.Build(&build_diagnostics); @@ -8780,7 +8780,7 @@ TEST(BuildSymbolTableTest, IncludeModuleDefinition) { MUST_ASSIGN_LOOKUP_SYMBOL(pp, root_symbol, "pp"); - const VerilogSourceFile* included = project.LookupRegisteredFile("module.sv"); + const VerilogSourceFile *included = project.LookupRegisteredFile("module.sv"); ASSERT_NE(included, nullptr); EXPECT_EQ(pp_info.file_origin, included); @@ -8828,7 +8828,7 @@ TEST(BuildSymbolTableTest, IncludeFileNotFound) { ASSERT_TRUE(file_or_status.ok()) << file_or_status.status().message(); SymbolTable symbol_table(&project); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); std::vector build_diagnostics; symbol_table.Build(&build_diagnostics); @@ -8925,11 +8925,11 @@ TEST(BuildSymbolTableTest, IncludedTwiceFromOneFile) { const auto file_or_status = project.OpenTranslationUnit(Basename(pp_src.filename())); ASSERT_TRUE(file_or_status.ok()) << file_or_status.status().message(); - const VerilogSourceFile* pp_file = *file_or_status; + const VerilogSourceFile *pp_file = *file_or_status; ASSERT_NE(pp_file, nullptr); SymbolTable symbol_table(&project); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); std::vector build_diagnostics; symbol_table.Build(&build_diagnostics); @@ -8940,7 +8940,7 @@ TEST(BuildSymbolTableTest, IncludedTwiceFromOneFile) { MUST_ASSIGN_LOOKUP_SYMBOL(pp_ww, pp, "ww"); MUST_ASSIGN_LOOKUP_SYMBOL(qq_ww, qq, "ww"); - const VerilogSourceFile* included = project.LookupRegisteredFile("wires.sv"); + const VerilogSourceFile *included = project.LookupRegisteredFile("wires.sv"); ASSERT_NE(included, nullptr); EXPECT_EQ(pp_info.file_origin, pp_file); EXPECT_EQ(qq_info.file_origin, pp_file); @@ -8979,17 +8979,17 @@ TEST(BuildSymbolTableTest, IncludedTwiceFromDifferentFiles) { const auto pp_file_or_status = project.OpenTranslationUnit(Basename(pp_src.filename())); ASSERT_TRUE(pp_file_or_status.ok()) << pp_file_or_status.status().message(); - const VerilogSourceFile* pp_file = *pp_file_or_status; + const VerilogSourceFile *pp_file = *pp_file_or_status; ASSERT_NE(pp_file, nullptr); const auto qq_file_or_status = project.OpenTranslationUnit(Basename(qq_src.filename())); ASSERT_TRUE(qq_file_or_status.ok()) << qq_file_or_status.status().message(); - const VerilogSourceFile* qq_file = *qq_file_or_status; + const VerilogSourceFile *qq_file = *qq_file_or_status; ASSERT_NE(qq_file, nullptr); SymbolTable symbol_table(&project); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); std::vector build_diagnostics; symbol_table.Build(&build_diagnostics); @@ -9000,7 +9000,7 @@ TEST(BuildSymbolTableTest, IncludedTwiceFromDifferentFiles) { MUST_ASSIGN_LOOKUP_SYMBOL(pp_ww, pp, "ww"); MUST_ASSIGN_LOOKUP_SYMBOL(qq_ww, qq, "ww"); - const VerilogSourceFile* included = project.LookupRegisteredFile("wires.sv"); + const VerilogSourceFile *included = project.LookupRegisteredFile("wires.sv"); ASSERT_NE(included, nullptr); EXPECT_EQ(pp_info.file_origin, pp_file); EXPECT_EQ(qq_info.file_origin, qq_file); @@ -9039,7 +9039,7 @@ TEST(BuildSymbolTableTest, ModulePortDeclarationDirectionRedefinition) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -9072,7 +9072,7 @@ TEST(BuildSymbolTableTest, ModulePortDeclarationTypeRedefinition) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -9119,7 +9119,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -9173,7 +9173,7 @@ TEST(BuildSymbolTableTest, const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -9204,7 +9204,7 @@ TEST(BuildSymbolTableTest, ModulePortDeclarationTypeMultilineWithPortList) { const auto status = src.Parse(); ASSERT_TRUE(status.ok()) << status.message(); SymbolTable symbol_table(nullptr); - const SymbolTableNode& root_symbol(symbol_table.Root()); + const SymbolTableNode &root_symbol(symbol_table.Root()); const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); @@ -9226,6 +9226,202 @@ TEST(BuildSymbolTableTest, ModulePortDeclarationTypeMultilineWithPortList) { } } +TEST(BuildSymbolTableTest, InterfaceDeclarationSingleEmpty) { + TestVerilogSourceFile src("foobar_if.sv", + "interface foobar_if;\n" + "endinterface\n"); + const auto status = src.Parse(); + ASSERT_TRUE(status.ok()) << status.message(); + SymbolTable symbol_table(nullptr); + const SymbolTableNode &root_symbol(symbol_table.Root()); + + const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); + + MUST_ASSIGN_LOOKUP_SYMBOL(interface_node, root_symbol, "foobar_if"); + EXPECT_EQ(interface_node_info.metatype, SymbolMetaType::kInterface); + EXPECT_EQ(interface_node_info.file_origin, &src); + EXPECT_EQ(interface_node_info.declared_type.syntax_origin, + nullptr); // there is no interface meta-type + EXPECT_EMPTY_STATUSES(build_diagnostics); + + { + std::vector resolve_diagnostics; + symbol_table.Resolve(&resolve_diagnostics); // nothing to resolve + EXPECT_EMPTY_STATUSES(resolve_diagnostics); + } +} + +TEST(BuildSymbolTableTest, InterfaceDeclarationLocalNetsVariables) { + TestVerilogSourceFile src("foobar_if.sv", + "interface foobar_if;\n" + " logic l1;\n" + " logic l2;\n" + "endinterface\n"); + const auto status = src.Parse(); + ASSERT_TRUE(status.ok()) << status.message(); + SymbolTable symbol_table(nullptr); + const SymbolTableNode &root_symbol(symbol_table.Root()); + + const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); + + MUST_ASSIGN_LOOKUP_SYMBOL(interface_node, root_symbol, "foobar_if"); + EXPECT_EQ(interface_node_info.metatype, SymbolMetaType::kInterface); + EXPECT_EQ(interface_node_info.file_origin, &src); + EXPECT_EQ(interface_node_info.declared_type.syntax_origin, + nullptr); // there is no interface meta-type + EXPECT_EMPTY_STATUSES(build_diagnostics); + + static constexpr absl::string_view members[] = {"l1", "l2"}; + for (const auto &member : members) { + MUST_ASSIGN_LOOKUP_SYMBOL(member_node, interface_node, member); + EXPECT_EQ(member_node_info.metatype, + SymbolMetaType::kDataNetVariableInstance); + EXPECT_EQ(member_node_info.declared_type.user_defined_type, + nullptr); // types are primitive + } + + { + std::vector resolve_diagnostics; + symbol_table.Resolve(&resolve_diagnostics); // nothing to resolve + EXPECT_EMPTY_STATUSES(resolve_diagnostics); + } +} + +TEST(BuildSymbolTableTest, InterfaceDeclarationWithPorts) { + TestVerilogSourceFile src("foobar_if.sv", + "interface foobar_if (\n" + " input wire clk,\n" + " input logic reset\n" + ");\n" + " logic d;" + " logic q;" + " modport dff (" + " input d," + " output q);" + " modport dff_test (" + " output d," + " input q);" + "endinterface\n"); + const auto status = src.Parse(); + ASSERT_TRUE(status.ok()) << status.message(); + SymbolTable symbol_table(nullptr); + const SymbolTableNode &root_symbol(symbol_table.Root()); + + const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); + EXPECT_EMPTY_STATUSES(build_diagnostics); + + MUST_ASSIGN_LOOKUP_SYMBOL(interface_node, root_symbol, "foobar_if"); + EXPECT_EQ(interface_node_info.metatype, SymbolMetaType::kInterface); + EXPECT_EQ(interface_node_info.file_origin, &src); + EXPECT_EQ(interface_node_info.declared_type.syntax_origin, + nullptr); // there is no interface meta-type + + static constexpr absl::string_view members[] = {"clk", "reset", "d", "q"}; + for (const auto &member : members) { + MUST_ASSIGN_LOOKUP_SYMBOL(member_node, interface_node, member); + EXPECT_EQ(member_node_info.metatype, + SymbolMetaType::kDataNetVariableInstance); + EXPECT_EQ(member_node_info.declared_type.user_defined_type, + nullptr); // types are primitive + } + + { + std::vector resolve_diagnostics; + symbol_table.Resolve(&resolve_diagnostics); // nothing to resolve + EXPECT_EMPTY_STATUSES(resolve_diagnostics); + } +} + +TEST(BuildSymbolTableTest, InterfaceDeclarationMultiple) { + TestVerilogSourceFile src("foobar_if.sv", + "interface foobar1_if;\nendinterface\n" + "interface foobar2_if;\nendinterface\n"); + const auto status = src.Parse(); + ASSERT_TRUE(status.ok()) << status.message(); + SymbolTable symbol_table(nullptr); + const SymbolTableNode &root_symbol(symbol_table.Root()); + + const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); + EXPECT_EMPTY_STATUSES(build_diagnostics); + + const absl::string_view expected_interfaces[] = {"foobar1_if", "foobar2_if"}; + for (const auto &expected_interface : expected_interfaces) { + MUST_ASSIGN_LOOKUP_SYMBOL(interface_node, root_symbol, expected_interface); + EXPECT_EQ(interface_node_info.metatype, SymbolMetaType::kInterface); + EXPECT_EQ(interface_node_info.file_origin, &src); + EXPECT_EQ(interface_node_info.declared_type.syntax_origin, + nullptr); // there is no interface meta-type + } + + { + std::vector resolve_diagnostics; + symbol_table.Resolve(&resolve_diagnostics); // nothing to resolve + EXPECT_EMPTY_STATUSES(resolve_diagnostics); + } +} + +TEST(BuildSymbolTableTest, InterfaceDeclarationDuplicate) { + TestVerilogSourceFile src("foobar_if.sv", + "interface foobar_if;\nendinterface\n" + "interface foobar_if;\nendinterface\n"); + const auto status = src.Parse(); + ASSERT_TRUE(status.ok()) << status.message(); + SymbolTable symbol_table(nullptr); + const SymbolTableNode &root_symbol(symbol_table.Root()); + + const auto build_diagnostics = BuildSymbolTable(src, &symbol_table); + + MUST_ASSIGN_LOOKUP_SYMBOL(interface_node, root_symbol, "foobar_if"); + EXPECT_EQ(interface_node_info.metatype, SymbolMetaType::kInterface); + EXPECT_EQ(interface_node_info.file_origin, &src); + EXPECT_EQ(interface_node_info.declared_type.syntax_origin, + nullptr); // there is no interface meta-type + + ASSIGN_MUST_HAVE_UNIQUE(err, build_diagnostics); + EXPECT_EQ(err.code(), absl::StatusCode::kAlreadyExists); + EXPECT_THAT(err.message(), + HasSubstr("\"foobar_if\" is already defined in the $root scope")); + + { + std::vector resolve_diagnostics; + symbol_table.Resolve(&resolve_diagnostics); // nothing to resolve + EXPECT_EMPTY_STATUSES(resolve_diagnostics); + } +} + +TEST(BuildSymbolTableTest, InterfaceDeclarationDuplicateSeparateFiles) { + TestVerilogSourceFile src("foobar_if.sv", + "interface foobar_if;\nendinterface\n"); + TestVerilogSourceFile src2("foobar_if-2.sv", + "interface foobar_if;\nendinterface\n"); + const auto status = src.Parse(); + ASSERT_TRUE(status.ok()) << status.message(); + const auto status2 = src2.Parse(); + ASSERT_TRUE(status2.ok()) << status2.message(); + SymbolTable symbol_table(nullptr); + const SymbolTableNode &root_symbol(symbol_table.Root()); + + const auto build_diagnostics1 = BuildSymbolTable(src, &symbol_table); + const auto build_diagnostics = BuildSymbolTable(src2, &symbol_table); + + MUST_ASSIGN_LOOKUP_SYMBOL(interface_node, root_symbol, "foobar_if"); + EXPECT_EQ(interface_node_info.metatype, SymbolMetaType::kInterface); + EXPECT_EQ(interface_node_info.file_origin, &src); + EXPECT_EQ(interface_node_info.declared_type.syntax_origin, + nullptr); // there is no interface meta-type + + ASSIGN_MUST_HAVE_UNIQUE(err, build_diagnostics); + EXPECT_EQ(err.code(), absl::StatusCode::kAlreadyExists); + EXPECT_THAT(err.message(), + HasSubstr("\"foobar_if\" is already defined in the $root scope")); + + { + std::vector resolve_diagnostics; + symbol_table.Resolve(&resolve_diagnostics); // nothing to resolve + EXPECT_EMPTY_STATUSES(resolve_diagnostics); + } +} + struct FileListTestCase { absl::string_view contents; std::vector expected_files; @@ -9255,7 +9451,7 @@ TEST(ParseSourceFileListFromFileTest, VariousValidFiles) { "bar/baz.txt\n", {"/foo/bar.sv", "bar/baz.txt"}}, }; - for (const auto& test : kTestCases) { + for (const auto &test : kTestCases) { const ScopedTestFile test_file(testing::TempDir(), test.contents); FileList file_list; const auto status(AppendFileListFromFile(test_file.filename(), &file_list));