aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorArthur Cohen <arthur.cohen@embecosm.com>2022-04-26 14:36:55 +0200
committerArthur Cohen <arthur.cohen@embecosm.com>2022-04-26 16:18:43 +0200
commit6f07a7689284a89d25a6e236193fca0b06f8e82e (patch)
treed96e6b8bddd8921afca5fa3bced3fa8e34486873 /gcc
parentab845217887468b500b624f0837023122002c534 (diff)
downloadgcc-6f07a7689284a89d25a6e236193fca0b06f8e82e.zip
gcc-6f07a7689284a89d25a6e236193fca0b06f8e82e.tar.gz
gcc-6f07a7689284a89d25a6e236193fca0b06f8e82e.tar.bz2
mappings: Add mappings for SimplePath{Segment}s
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/util/rust-hir-map.cc50
-rw-r--r--gcc/rust/util/rust-hir-map.h11
2 files changed, 61 insertions, 0 deletions
diff --git a/gcc/rust/util/rust-hir-map.cc b/gcc/rust/util/rust-hir-map.cc
index ac1cf70..4062ce7 100644
--- a/gcc/rust/util/rust-hir-map.cc
+++ b/gcc/rust/util/rust-hir-map.cc
@@ -427,6 +427,56 @@ Mappings::lookup_hir_path_expr_seg (CrateNum crateNum, HirId id)
}
void
+Mappings::insert_simple_path_segment (CrateNum crateNum, HirId id,
+ AST::SimplePathSegment *path)
+{
+ rust_assert (lookup_simple_path_segment (crateNum, id) == nullptr);
+
+ astSimplePathSegmentMappings[crateNum][id] = path;
+ nodeIdToHirMappings[crateNum][path->get_node_id ()] = id;
+ insert_location (crateNum, id, path->get_locus ());
+}
+
+AST::SimplePathSegment *
+Mappings::lookup_simple_path_segment (CrateNum crateNum, HirId id)
+{
+ auto it = astSimplePathSegmentMappings.find (crateNum);
+ if (it == astSimplePathSegmentMappings.end ())
+ return nullptr;
+
+ auto iy = it->second.find (id);
+ if (iy == it->second.end ())
+ return nullptr;
+
+ return iy->second;
+}
+
+void
+Mappings::insert_simple_path (CrateNum crateNum, HirId id,
+ AST::SimplePath *path)
+{
+ rust_assert (lookup_simple_path (crateNum, id) == nullptr);
+
+ astSimplePathMappings[crateNum][id] = path;
+ nodeIdToHirMappings[crateNum][path->get_node_id ()] = id;
+ insert_location (crateNum, id, path->get_locus ());
+}
+
+AST::SimplePath *
+Mappings::lookup_simple_path (CrateNum crateNum, HirId id)
+{
+ auto it = astSimplePathMappings.find (crateNum);
+ if (it == astSimplePathMappings.end ())
+ return nullptr;
+
+ auto iy = it->second.find (id);
+ if (iy == it->second.end ())
+ return nullptr;
+
+ return iy->second;
+}
+
+void
Mappings::insert_hir_generic_param (CrateNum crateNum, HirId id,
HIR::GenericParam *param)
{
diff --git a/gcc/rust/util/rust-hir-map.h b/gcc/rust/util/rust-hir-map.h
index 74fabdf..19c2f0a 100644
--- a/gcc/rust/util/rust-hir-map.h
+++ b/gcc/rust/util/rust-hir-map.h
@@ -147,6 +147,14 @@ public:
HIR::PathExprSegment *expr);
HIR::PathExprSegment *lookup_hir_path_expr_seg (CrateNum crateNum, HirId id);
+ void insert_simple_path_segment (CrateNum crateNum, HirId id,
+ AST::SimplePathSegment *path);
+ AST::SimplePathSegment *lookup_simple_path_segment (CrateNum crateNum,
+ HirId id);
+
+ void insert_simple_path (CrateNum crateNum, HirId id, AST::SimplePath *path);
+ AST::SimplePath *lookup_simple_path (CrateNum crateNum, HirId id);
+
void insert_hir_generic_param (CrateNum crateNum, HirId id,
HIR::GenericParam *expr);
HIR::GenericParam *lookup_hir_generic_param (CrateNum crateNum, HirId id);
@@ -330,6 +338,9 @@ private:
std::map<CrateNum, std::map<HirId, HIR::TraitItem *>> hirTraitItemMappings;
std::map<CrateNum, std::map<HirId, HIR::ExternalItem *>>
hirExternItemMappings;
+ std::map<CrateNum, std::map<HirId, AST::SimplePath *>> astSimplePathMappings;
+ std::map<CrateNum, std::map<HirId, AST::SimplePathSegment *>>
+ astSimplePathSegmentMappings;
std::map<CrateNum, std::map<HirId, HIR::PathExprSegment *>>
hirPathSegMappings;
std::map<CrateNum, std::map<HirId, HIR::GenericParam *>>