https://gcc.gnu.org/g:97539b7c20eb08d5b6532016654ecc6ba6c9a09f

commit r15-2565-g97539b7c20eb08d5b6532016654ecc6ba6c9a09f
Author: Pierre-Emmanuel Patry <pierre-emmanuel.pa...@embecosm.com>
Date:   Wed Jan 24 17:04:51 2024 +0100

    gccrs: Unit struct constructor shall be resolved
    
    Unit struct have a special constructor that should be added to the struct
    namespace in order to be resolved later when called. As it is a function
    it should be added in the value namespace.
    
    gcc/rust/ChangeLog:
    
            * resolve/rust-toplevel-name-resolver-2.0.cc 
(GlobbingVisitor::visit):
            Add the struct constructor when the struct is a unit.
    
    Signed-off-by: Pierre-Emmanuel Patry <pierre-emmanuel.pa...@embecosm.com>

Diff:
---
 gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc | 9 +++++++--
 1 file changed, 7 insertions(+), 2 deletions(-)

diff --git a/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc 
b/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc
index 4134b9a46202..75d9bb82131f 100644
--- a/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc
+++ b/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc
@@ -68,8 +68,13 @@ void
 GlobbingVisitor::visit (AST::StructStruct &struct_item)
 {
   if (struct_item.get_visibility ().is_public ())
-    ctx.insert_shadowable (struct_item.get_identifier (),
-                          struct_item.get_node_id (), Namespace::Values);
+    {
+      ctx.insert_shadowable (struct_item.get_identifier (),
+                            struct_item.get_node_id (), Namespace::Types);
+      if (struct_item.is_unit_struct ())
+       ctx.insert_shadowable (struct_item.get_identifier (),
+                              struct_item.get_node_id (), Namespace::Values);
+    }
 }
 
 void

Reply via email to