aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorPierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>2023-06-16 18:17:39 +0200
committerArthur Cohen <arthur.cohen@embecosm.com>2024-01-16 18:55:58 +0100
commit4d5f20fdbf095663ce829b42a22819093f4efc8e (patch)
tree11c801319e99e9636e83241550cec5650c38e239 /gcc
parent37451ad09f7edc081700909208f90b9eea1eb592 (diff)
downloadgcc-4d5f20fdbf095663ce829b42a22819093f4efc8e.zip
gcc-4d5f20fdbf095663ce829b42a22819093f4efc8e.tar.gz
gcc-4d5f20fdbf095663ce829b42a22819093f4efc8e.tar.bz2
gccrs: resolve: Add extern crate proc macro collection
Create a mapping for procedural macros with their crate num. gcc/rust/ChangeLog: * metadata/rust-extern-crate.h: Add proc macro getter. * rust-session-manager.cc (Session::load_extern_crate): Collect mappings and create mappings. * util/rust-hir-map.cc: Add insertion and lookup functions for every mapping. * util/rust-hir-map.h: Add function prototypes. Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/metadata/rust-extern-crate.h2
-rw-r--r--gcc/rust/rust-session-manager.cc26
-rw-r--r--gcc/rust/util/rust-hir-map.cc64
-rw-r--r--gcc/rust/util/rust-hir-map.h22
4 files changed, 114 insertions, 0 deletions
diff --git a/gcc/rust/metadata/rust-extern-crate.h b/gcc/rust/metadata/rust-extern-crate.h
index cf7eadc..fcd54f6 100644
--- a/gcc/rust/metadata/rust-extern-crate.h
+++ b/gcc/rust/metadata/rust-extern-crate.h
@@ -40,6 +40,8 @@ public:
const std::string &get_metadata () const;
+ std::vector<ProcMacro::Procmacro> &get_proc_macros () { return proc_macros; }
+
static bool string_to_int (location_t locus, const std::string &s,
bool is_neg_ok, int *ret);
diff --git a/gcc/rust/rust-session-manager.cc b/gcc/rust/rust-session-manager.cc
index 572ecfa..ee7dd08 100644
--- a/gcc/rust/rust-session-manager.cc
+++ b/gcc/rust/rust-session-manager.cc
@@ -1024,6 +1024,32 @@ Session::load_extern_crate (const std::string &crate_name, location_t locus)
Lexer lex (extern_crate.get_metadata ());
Parser<Lexer> parser (lex);
std::unique_ptr<AST::Crate> metadata_crate = parser.parse_crate ();
+
+ std::vector<ProcMacro::Attribute> attribute_macros;
+ std::vector<ProcMacro::CustomDerive> derive_macros;
+ std::vector<ProcMacro::Bang> bang_macros;
+ for (auto &macro : extern_crate.get_proc_macros ())
+ {
+ switch (macro.tag)
+ {
+ case ProcMacro::CUSTOM_DERIVE:
+ derive_macros.push_back (macro.payload.custom_derive);
+ break;
+ case ProcMacro::ATTR:
+ attribute_macros.push_back (macro.payload.attribute);
+ break;
+ case ProcMacro::BANG:
+ bang_macros.push_back (macro.payload.bang);
+ break;
+ default:
+ gcc_unreachable ();
+ }
+ }
+
+ mappings->insert_attribute_proc_macros (crate_num, attribute_macros);
+ mappings->insert_derive_proc_macros (crate_num, derive_macros);
+ mappings->insert_bang_proc_macros (crate_num, bang_macros);
+
AST::Crate &parsed_crate
= mappings->insert_ast_crate (std::move (metadata_crate), crate_num);
diff --git a/gcc/rust/util/rust-hir-map.cc b/gcc/rust/util/rust-hir-map.cc
index c969636..caf44a2 100644
--- a/gcc/rust/util/rust-hir-map.cc
+++ b/gcc/rust/util/rust-hir-map.cc
@@ -943,6 +943,70 @@ Mappings::get_exported_macros ()
}
void
+Mappings::insert_derive_proc_macros (
+ CrateNum num, std::vector<ProcMacro::CustomDerive> macros)
+{
+ auto it = procmacrosDeriveMappings.find (num);
+ rust_assert (it == procmacrosDeriveMappings.end ());
+
+ procmacrosDeriveMappings[num] = macros;
+}
+
+void
+Mappings::insert_bang_proc_macros (CrateNum num,
+ std::vector<ProcMacro::Bang> macros)
+{
+ auto it = procmacrosBangMappings.find (num);
+ rust_assert (it == procmacrosBangMappings.end ());
+
+ procmacrosBangMappings[num] = macros;
+}
+
+void
+Mappings::insert_attribute_proc_macros (
+ CrateNum num, std::vector<ProcMacro::Attribute> macros)
+{
+ auto it = procmacrosAttributeMappings.find (num);
+ rust_assert (it == procmacrosAttributeMappings.end ());
+
+ procmacrosAttributeMappings[num] = macros;
+}
+
+bool
+Mappings::lookup_derive_proc_macros (
+ CrateNum num, std::vector<ProcMacro::CustomDerive> &macros)
+{
+ auto it = procmacrosDeriveMappings.find (num);
+ if (it == procmacrosDeriveMappings.end ())
+ return false;
+
+ macros = it->second;
+ return true;
+}
+bool
+Mappings::lookup_bang_proc_macros (CrateNum num,
+ std::vector<ProcMacro::Bang> &macros)
+{
+ auto it = procmacrosBangMappings.find (num);
+ if (it == procmacrosBangMappings.end ())
+ return false;
+
+ macros = it->second;
+ return true;
+}
+bool
+Mappings::lookup_attribute_proc_macros (
+ CrateNum num, std::vector<ProcMacro::Attribute> &macros)
+{
+ auto it = procmacrosAttributeMappings.find (num);
+ if (it == procmacrosAttributeMappings.end ())
+ return false;
+
+ macros = it->second;
+ return true;
+}
+
+void
Mappings::insert_derive_proc_macro (
std::pair<std::string, std::string> hierarchy, ProcMacro::CustomDerive macro)
{
diff --git a/gcc/rust/util/rust-hir-map.h b/gcc/rust/util/rust-hir-map.h
index 7f3f4fb..a47898b 100644
--- a/gcc/rust/util/rust-hir-map.h
+++ b/gcc/rust/util/rust-hir-map.h
@@ -283,6 +283,20 @@ public:
void insert_exported_macro (AST::MacroRulesDefinition &def);
std::vector<NodeId> &get_exported_macros ();
+ void insert_derive_proc_macros (CrateNum num,
+ std::vector<ProcMacro::CustomDerive> macros);
+ void insert_bang_proc_macros (CrateNum num,
+ std::vector<ProcMacro::Bang> macros);
+ void insert_attribute_proc_macros (CrateNum num,
+ std::vector<ProcMacro::Attribute> macros);
+
+ bool lookup_derive_proc_macros (CrateNum num,
+ std::vector<ProcMacro::CustomDerive> &macros);
+ bool lookup_bang_proc_macros (CrateNum num,
+ std::vector<ProcMacro::Bang> &macros);
+ bool lookup_attribute_proc_macros (CrateNum num,
+ std::vector<ProcMacro::Attribute> &macros);
+
void insert_derive_proc_macro (std::pair<std::string, std::string> hierachy,
ProcMacro::CustomDerive macro);
void insert_bang_proc_macro (std::pair<std::string, std::string> hierachy,
@@ -376,6 +390,14 @@ private:
std::vector<NodeId> exportedMacros;
// Procedural macros
+ std::map<CrateNum, std::vector<ProcMacro::CustomDerive>>
+ procmacrosDeriveMappings;
+
+ std::map<CrateNum, std::vector<ProcMacro::Bang>> procmacrosBangMappings;
+
+ std::map<CrateNum, std::vector<ProcMacro::Attribute>>
+ procmacrosAttributeMappings;
+
std::map<std::pair<std::string, std::string>, ProcMacro::CustomDerive>
procmacroDeriveMappings;