diff options
author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2022-04-26 18:54:01 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-04-26 18:54:01 +0000 |
commit | d69dd650367fa7fcfac38001b6406c1bff2601e1 (patch) | |
tree | fa16ce49470a14c6e63f36b3b73ef3125651641f /gcc/rust/util/rust-hir-map.cc | |
parent | 8b2e6da73956c8f12a4a150b5b9dcf8f1b5656ba (diff) | |
parent | 6f07a7689284a89d25a6e236193fca0b06f8e82e (diff) | |
download | gcc-d69dd650367fa7fcfac38001b6406c1bff2601e1.zip gcc-d69dd650367fa7fcfac38001b6406c1bff2601e1.tar.gz gcc-d69dd650367fa7fcfac38001b6406c1bff2601e1.tar.bz2 |
Merge #1176
1176: Keep `SimplePath{Segment}`s in mappings r=CohenArthur a=CohenArthur
Addresses #1159
Co-authored-by: Arthur Cohen <arthur.cohen@embecosm.com>
Diffstat (limited to 'gcc/rust/util/rust-hir-map.cc')
-rw-r--r-- | gcc/rust/util/rust-hir-map.cc | 50 |
1 files changed, 50 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) { |