aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust/backend/rust-compile-resolve-path.cc
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2022-05-18 14:50:31 +0000
committerGitHub <noreply@github.com>2022-05-18 14:50:31 +0000
commit9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad (patch)
treeeb502effa494d5446a8da49aca8ff8d54e49f9f1 /gcc/rust/backend/rust-compile-resolve-path.cc
parent8cad07cfd2244ad9a40027a4306b81b4553a4797 (diff)
parent4a4206c017654af7a3468690e4e21fdaf86bcb5c (diff)
downloadgcc-9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad.zip
gcc-9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad.tar.gz
gcc-9e61c6eb220cf54b3fcac3d3fe7a7f1f59bcc7ad.tar.bz2
Merge #1250
1250: Support extern-blocks defined within blocks r=philberty a=philberty This adds support for declaring extern blocks within blocks. So this adds the missing name resolution visitor for the statement context. Then we extract out a common extern block hir lowering function for both contexts. The type resolution step needs to be updated to be like the code-generation step so that we can solve these paths in a query rather than a top-down approach but this is a known issue. The final step was to support query-based compilation to extern functions. Fixes #976 Co-authored-by: Philip Herron <philip.herron@embecosm.com>
Diffstat (limited to 'gcc/rust/backend/rust-compile-resolve-path.cc')
-rw-r--r--gcc/rust/backend/rust-compile-resolve-path.cc16
1 files changed, 14 insertions, 2 deletions
diff --git a/gcc/rust/backend/rust-compile-resolve-path.cc b/gcc/rust/backend/rust-compile-resolve-path.cc
index bd44bf4..ca96a27 100644
--- a/gcc/rust/backend/rust-compile-resolve-path.cc
+++ b/gcc/rust/backend/rust-compile-resolve-path.cc
@@ -23,8 +23,7 @@
#include "rust-compile-expr.h"
#include "rust-hir-trait-resolve.h"
#include "rust-hir-path-probe.h"
-
-#include "print-tree.h"
+#include "rust-compile-extern.h"
namespace Rust {
namespace Compile {
@@ -172,7 +171,11 @@ HIRCompileBase::query_compile (HirId ref, TyTy::BaseType *lookup,
{
HIR::Item *resolved_item
= ctx->get_mappings ()->lookup_hir_item (mappings.get_crate_num (), ref);
+ HIR::ExternalItem *resolved_extern_item
+ = ctx->get_mappings ()->lookup_hir_extern_item (mappings.get_crate_num (),
+ ref);
bool is_hir_item = resolved_item != nullptr;
+ bool is_hir_extern_item = resolved_extern_item != nullptr;
if (is_hir_item)
{
if (!lookup->has_subsititions_defined ())
@@ -182,6 +185,15 @@ HIRCompileBase::query_compile (HirId ref, TyTy::BaseType *lookup,
return CompileItem::compile (resolved_item, ctx, lookup, true,
expr_locus);
}
+ else if (is_hir_extern_item)
+ {
+ if (!lookup->has_subsititions_defined ())
+ return CompileExternItem::compile (resolved_extern_item, ctx, nullptr,
+ true, expr_locus);
+ else
+ return CompileExternItem::compile (resolved_extern_item, ctx, lookup,
+ true, expr_locus);
+ }
else
{
HirId parent_impl_id = UNKNOWN_HIRID;