diff options
author | Philip Herron <philip.herron@embecosm.com> | 2022-05-16 17:09:45 +0100 |
---|---|---|
committer | Philip Herron <philip.herron@embecosm.com> | 2022-05-17 11:18:31 +0100 |
commit | 4a4206c017654af7a3468690e4e21fdaf86bcb5c (patch) | |
tree | 4ddbcbcb3a61bc12b5025c9bf1ea8316cdb5b083 /gcc/rust/backend/rust-compile-resolve-path.cc | |
parent | e4213b9568ae8cb8a4e31326e0e78c79db0a99cc (diff) | |
download | gcc-4a4206c017654af7a3468690e4e21fdaf86bcb5c.zip gcc-4a4206c017654af7a3468690e4e21fdaf86bcb5c.tar.gz gcc-4a4206c017654af7a3468690e4e21fdaf86bcb5c.tar.bz2 |
Support extern-blocks defined within blocks
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
Diffstat (limited to 'gcc/rust/backend/rust-compile-resolve-path.cc')
-rw-r--r-- | gcc/rust/backend/rust-compile-resolve-path.cc | 16 |
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; |