17#ifndef COMMON_RESOLVEREFERENCES_RESOLVEREFERENCES_H_
18#define COMMON_RESOLVEREFERENCES_RESOLVEREFERENCES_H_
20#include "absl/container/flat_hash_map.h"
21#include "absl/container/inlined_vector.h"
23#include "lib/cstring.h"
24#include "lib/iterator_range.h"
25#include "referenceMap.h"
37 const std::vector<const IR::IDeclaration *> &memoizeDeclarations(
38 const IR::INamespace *ns)
const;
40 using DeclsVector = absl::InlinedVector<const IR::IDeclaration *, 2>;
41 using NamespaceDeclsByName = absl::flat_hash_map<cstring, DeclsVector, Util::Hash>;
45 NamespaceDeclsByName &memoizeDeclsByName(
const IR::INamespace *ns)
const;
47 mutable absl::flat_hash_map<const IR::INamespace *, std::vector<const IR::IDeclaration *>,
50 mutable absl::flat_hash_map<const IR::INamespace *, NamespaceDeclsByName, Util::Hash>
56 std::vector<const IR::IDeclaration *> lookup(
const IR::INamespace *ns,
const IR::ID &name,
62 std::vector<const IR::IDeclaration *> lookupMatchKind(
const IR::ID &name)
const;
68 bool anyOrder =
false;
71 explicit ResolutionContext(
bool ao) : anyOrder(ao) {}
82 const IR::INamespace * =
nullptr)
const;
89 const IR::Type *
resolveType(
const IR::Type *type)
const;
91 const IR::IDeclaration *getDeclaration(
const IR::Path *path,
bool notNull =
false)
const;
92 const IR::IDeclaration *getDeclaration(
const IR::This *,
bool notNull =
false)
const;
96 auto nsIt = namespaceDecls.find(ns);
97 const auto &decls = nsIt != namespaceDecls.end() ? nsIt->second : memoizeDeclarations(ns);
103 auto nsIt = namespaceDeclNames.find(ns);
104 const auto &namesToDecls =
105 nsIt != namespaceDeclNames.end() ? nsIt->second : memoizeDeclsByName(ns);
107 auto decls = namesToDecls.find(name);
108 if (decls == namesToDecls.end())
109 return Util::Enumerator<const IR::IDeclaration *>::emptyEnumerator();
110 return Util::enumerate(decls->second);
121class ResolveReferences :
public Inspector,
private ResolutionContext {
131 const IR::IDeclaration *resolvePath(
const IR::Path *path,
bool isType)
const override;
134 explicit ResolveReferences(
P4::ReferenceMap *refMap,
bool checkShadow =
false);
137 void end_apply(
const IR::Node *node)
override;
139 bool preorder(
const IR::Type_Name *type)
override;
140 bool preorder(
const IR::PathExpression *path)
override;
141 bool preorder(
const IR::KeyElement *path)
override;
142 bool preorder(
const IR::This *pointer)
override;
143 bool preorder(
const IR::Declaration_Instance *decl)
override;
145 bool preorder(
const IR::P4Program *t)
override;
146 void postorder(
const IR::P4Program *t)
override;
147 bool preorder(
const IR::P4Control *t)
override;
148 bool preorder(
const IR::P4Parser *t)
override;
149 bool preorder(
const IR::P4Action *t)
override;
150 bool preorder(
const IR::Function *t)
override;
151 bool preorder(
const IR::TableProperties *t)
override;
152 bool preorder(
const IR::Type_Method *t)
override;
153 bool preorder(
const IR::ParserState *t)
override;
154 bool preorder(
const IR::Type_Extern *t)
override;
155 bool preorder(
const IR::Type_ArchBlock *t)
override;
156 void postorder(
const IR::Type_ArchBlock *t)
override;
157 bool preorder(
const IR::Type_StructLike *t)
override;
158 bool preorder(
const IR::BlockStatement *t)
override;
160 bool preorder(
const IR::P4Table *table)
override;
161 bool preorder(
const IR::Declaration *d)
override {
162 refMap->usedName(d->getName().name);
165 bool preorder(
const IR::Type_Declaration *d)
override {
166 refMap->usedName(d->getName().name);
170 void checkShadowing(
const IR::INamespace *ns)
const;
Definition referenceMap.h:57
The Declaration interface, representing objects with names.
Definition declaration.h:26
Class used to encode maps from paths to declarations.
Definition referenceMap.h:66
std::vector< const IR::IDeclaration * > resolve(const IR::ID &name, ResolutionType type) const
Resolve references for name, restricted to type declarations.
Definition resolveReferences.cpp:48
auto getDeclsByName(const IR::INamespace *ns, cstring name) const
Returns the set of decls with the given name that exist in the given namespace.
Definition resolveReferences.h:102
auto getDeclarations(const IR::INamespace *ns) const
Returns the set of decls that exist in the given namespace.
Definition resolveReferences.h:95
virtual const IR::IDeclaration * resolvePath(const IR::Path *path, bool isType) const
Definition resolveReferences.cpp:311
const IR::Vector< IR::Argument > * methodArguments(cstring name) const
We are resolving a method call. Find the arguments from the context.
Definition resolveReferences.cpp:183
const IR::Type * resolveType(const IR::Type *type) const
Resolve a refrence to a type type.
Definition resolveReferences.cpp:298
const IR::IDeclaration * resolveUnique(const IR::ID &name, ResolutionType type, const IR::INamespace *=nullptr) const
Resolve reference for name, restricted to type declarations, and expect one result.
Definition resolveReferences.cpp:223
Definition iterator_range.h:44
TODO: this is not really specific to BMV2, it should reside somewhere else.
Definition applyOptionsPragmas.cpp:24
ResolutionType
Helper class to indicate types of nodes that may be returned during resolution.
Definition resolveReferences.h:30