]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gccrs: Retrieve def for derive & attribute proc macros
authorPierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
Tue, 29 Aug 2023 13:59:58 +0000 (15:59 +0200)
committerArthur Cohen <arthur.cohen@embecosm.com>
Tue, 16 Jan 2024 18:04:34 +0000 (19:04 +0100)
Add definition retrieval for derive and attribute proc macro types.

gcc/rust/ChangeLog:

* resolve/rust-early-name-resolver-2.0.cc (Early::visit_attributes):
Add proc macro handle retrieval for attribute and derive proc macros.

Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.patry@embecosm.com>
gcc/rust/resolve/rust-early-name-resolver-2.0.cc

index 7373e6232667338c608fd836b5584bb176c60953..57a38078f144ce2527ce87740243929914f407e6 100644 (file)
@@ -177,6 +177,8 @@ Early::visit (AST::UseTreeGlob &use)
 void
 Early::visit_attributes (std::vector<AST::Attribute> &attrs)
 {
+  auto mappings = Analysis::Mappings::get ();
+
   for (auto &attr : attrs)
     {
       auto name = attr.get_path ().get_segments ().at (0).get_segment_name ();
@@ -192,7 +194,16 @@ Early::visit_attributes (std::vector<AST::Attribute> &attrs)
                  // FIXME: Change to proper error message
                  rust_error_at (trait.get ().get_locus (),
                                 "could not resolve trait");
+                 continue;
                }
+
+             auto pm_def
+               = mappings->lookup_derive_proc_macro_def (definition.value ());
+
+             rust_assert (pm_def.has_value ());
+
+             mappings->insert_derive_proc_macro_invocation (trait,
+                                                            pm_def.value ());
            }
        }
       else if (Analysis::BuiltinAttributeMappings::get ()
@@ -207,6 +218,13 @@ Early::visit_attributes (std::vector<AST::Attribute> &attrs)
                             "could not resolve attribute macro invocation");
              return;
            }
+         auto pm_def
+           = mappings->lookup_attribute_proc_macro_def (definition.value ());
+
+         rust_assert (pm_def.has_value ());
+
+         mappings->insert_attribute_proc_macro_invocation (attr.get_path (),
+                                                           pm_def.value ());
        }
     }
 }