aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust/util/rust-hir-map.cc
diff options
context:
space:
mode:
authorSimplyTheOther <simplytheother@gmail.com>2021-02-04 12:43:59 +0800
committerSimplyTheOther <simplytheother@gmail.com>2021-02-04 12:43:59 +0800
commit7c7c76f27f6ab999ec8fa299bde8911911fa7d90 (patch)
treee432cd20f59552da34313060fbcbd87e0ef9728a /gcc/rust/util/rust-hir-map.cc
parent877e7ac6c72608950fbe2ffde04142bbfb01b29d (diff)
parent9abf0733814c5e4131b96afb1c0abad68f4cf4ef (diff)
downloadgcc-7c7c76f27f6ab999ec8fa299bde8911911fa7d90.zip
gcc-7c7c76f27f6ab999ec8fa299bde8911911fa7d90.tar.gz
gcc-7c7c76f27f6ab999ec8fa299bde8911911fa7d90.tar.bz2
Merge branch 'master' of https://github.com/redbrain/gccrs
Diffstat (limited to 'gcc/rust/util/rust-hir-map.cc')
-rw-r--r--gcc/rust/util/rust-hir-map.cc24
1 files changed, 24 insertions, 0 deletions
diff --git a/gcc/rust/util/rust-hir-map.cc b/gcc/rust/util/rust-hir-map.cc
index 925130f..eb55581 100644
--- a/gcc/rust/util/rust-hir-map.cc
+++ b/gcc/rust/util/rust-hir-map.cc
@@ -259,6 +259,30 @@ Mappings::lookup_hir_item (CrateNum crateNum, HirId id)
}
void
+Mappings::insert_hir_implitem (CrateNum crateNum, HirId id,
+ HIR::InherentImplItem *item)
+{
+ rust_assert (lookup_hir_implitem (crateNum, id) == nullptr);
+
+ hirImplItemMappings[crateNum][id] = item;
+ nodeIdToHirMappings[crateNum][item->get_impl_mappings ().get_nodeid ()] = id;
+}
+
+HIR::InherentImplItem *
+Mappings::lookup_hir_implitem (CrateNum crateNum, HirId id)
+{
+ auto it = hirImplItemMappings.find (crateNum);
+ if (it == hirImplItemMappings.end ())
+ return nullptr;
+
+ auto iy = it->second.find (id);
+ if (iy == it->second.end ())
+ return nullptr;
+
+ return iy->second;
+}
+
+void
Mappings::insert_hir_expr (CrateNum crateNum, HirId id, HIR::Expr *expr)
{
hirExprMappings[crateNum][id] = expr;