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"
22#include "frontends/common/parser_options.h"
24#include "ir/pass_manager.h"
25#include "lib/cstring.h"
26#include "lib/iterator_range.h"
27#include "referenceMap.h"
39 const std::vector<const IR::IDeclaration *> &memoizeDeclarations(
40 const IR::INamespace *ns)
const;
42 using DeclsVector = absl::InlinedVector<const IR::IDeclaration *, 2>;
43 using NamespaceDeclsByName = absl::flat_hash_map<cstring, DeclsVector, Util::Hash>;
47 NamespaceDeclsByName &memoizeDeclsByName(
const IR::INamespace *ns)
const;
49 mutable absl::flat_hash_map<const IR::INamespace *, std::vector<const IR::IDeclaration *>,
52 mutable absl::flat_hash_map<const IR::INamespace *, NamespaceDeclsByName, Util::Hash>
58 std::vector<const IR::IDeclaration *> lookup(
const IR::INamespace *ns,
const IR::ID &name,
64 std::vector<const IR::IDeclaration *> lookupMatchKind(
const IR::ID &name)
const;
70 bool anyOrder =
false;
73 explicit ResolutionContext(
bool ao) : anyOrder(ao) {}
84 const IR::INamespace * =
nullptr)
const;
91 const IR::Type *
resolveType(
const IR::Type *type)
const;
94 bool notNull =
false)
const override;
95 const IR::IDeclaration *getDeclaration(
const IR::This *,
bool notNull =
false)
const override;
99 auto nsIt = namespaceDecls.find(ns);
100 const auto &decls = nsIt != namespaceDecls.end() ? nsIt->second : memoizeDeclarations(ns);
106 auto nsIt = namespaceDeclNames.find(ns);
107 const auto &namesToDecls =
108 nsIt != namespaceDeclNames.end() ? nsIt->second : memoizeDeclsByName(ns);
110 auto decls = namesToDecls.find(name);
111 if (decls == namesToDecls.end())
112 return Util::Enumerator<const IR::IDeclaration *>::emptyEnumerator();
113 return Util::enumerate(decls->second);
124class ResolveReferences :
public Inspector,
private ResolutionContext {
134 const IR::IDeclaration *resolvePath(
const IR::Path *path,
bool isType)
const override;
137 explicit ResolveReferences(
P4::ReferenceMap *refMap,
bool checkShadow =
false);
140 void end_apply(
const IR::Node *node)
override;
142 bool preorder(
const IR::Type_Name *type)
override;
143 bool preorder(
const IR::PathExpression *path)
override;
144 bool preorder(
const IR::KeyElement *path)
override;
145 bool preorder(
const IR::This *pointer)
override;
146 bool preorder(
const IR::Declaration_Instance *decl)
override;
148 bool preorder(
const IR::P4Program *t)
override;
149 void postorder(
const IR::P4Program *t)
override;
150 bool preorder(
const IR::P4Control *t)
override;
151 bool preorder(
const IR::P4Parser *t)
override;
152 bool preorder(
const IR::P4Action *t)
override;
153 bool preorder(
const IR::Function *t)
override;
154 bool preorder(
const IR::TableProperties *t)
override;
155 bool preorder(
const IR::Type_Method *t)
override;
156 bool preorder(
const IR::ParserState *t)
override;
157 bool preorder(
const IR::Type_Extern *t)
override;
158 bool preorder(
const IR::Type_ArchBlock *t)
override;
159 void postorder(
const IR::Type_ArchBlock *t)
override;
160 bool preorder(
const IR::Type_StructLike *t)
override;
161 bool preorder(
const IR::BlockStatement *t)
override;
163 bool preorder(
const IR::P4Table *table)
override;
164 bool preorder(
const IR::Declaration *d)
override {
165 refMap->usedName(d->getName().name);
168 bool preorder(
const IR::Type_Declaration *d)
override {
169 refMap->usedName(d->getName().name);
173 void checkShadowing(
const IR::INamespace *ns)
const;
176class CheckShadowing :
public PassManager {
184 setName(
"CheckShadowing");
Definition referenceMap.h:57
The Declaration interface, representing objects with names.
Definition declaration.h:26
static P4CContext & get()
Definition parser_options.cpp:539
Class used to encode maps from paths to declarations.
Definition referenceMap.h:67
void setIsV1(bool isv1)
Set boolean indicating whether map is for a P4_14 program to isV1.
Definition referenceMap.h:106
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:105
auto getDeclarations(const IR::INamespace *ns) const
Returns the set of decls that exist in the given namespace.
Definition resolveReferences.h:98
virtual const IR::IDeclaration * resolvePath(const IR::Path *path, bool isType) const
Definition resolveReferences.cpp:312
const IR::Vector< IR::Argument > * methodArguments(cstring name) const
We are resolving a method call. Find the arguments from the context.
Definition resolveReferences.cpp:184
const IR::Type * resolveType(const IR::Type *type) const
Resolve a refrence to a type type.
Definition resolveReferences.cpp:299
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:224
Definition resolveReferences.h:124
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:32