]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gccrs: nr2.0: Handle StructPatternFieldIdent
authorOwen Avery <powerboat9.gamer@gmail.com>
Thu, 17 Apr 2025 18:02:45 +0000 (14:02 -0400)
committerArthur Cohen <arthur.cohen@embecosm.com>
Mon, 28 Apr 2025 14:18:54 +0000 (16:18 +0200)
gcc/rust/ChangeLog:

* resolve/rust-late-name-resolver-2.0.cc
(Late::visit): Handle StructPatternFieldIdent.
* resolve/rust-late-name-resolver-2.0.h
(Late::visit): Likewise.

gcc/testsuite/ChangeLog:

* rust/compile/nr2/exclude: Remove entry.

Signed-off-by: Owen Avery <powerboat9.gamer@gmail.com>
gcc/rust/resolve/rust-late-name-resolver-2.0.cc
gcc/rust/resolve/rust-late-name-resolver-2.0.h
gcc/testsuite/rust/compile/nr2/exclude

index f743e1e03f342527f29f73217d34b71c824bed53..cd81080ce1575889d6572396f894657239afad48 100644 (file)
@@ -172,6 +172,14 @@ Late::visit (AST::IdentifierPattern &identifier)
                                              identifier.get_node_id ());
 }
 
+void
+Late::visit (AST::StructPatternFieldIdent &field)
+{
+  // We do want to ignore duplicated data because some situations rely on it.
+  std::ignore = ctx.values.insert_shadowable (field.get_identifier (),
+                                             field.get_node_id ());
+}
+
 void
 Late::visit (AST::SelfParam &param)
 {
index 5703b152f7e7ee1b05e2d19e714d71881062b31f..2be932834d43f3964f3856635db259fb9a73b4fb 100644 (file)
@@ -42,6 +42,7 @@ public:
   // TODO: Do we need this?
   // void visit (AST::Method &) override;
   void visit (AST::IdentifierPattern &) override;
+  void visit (AST::StructPatternFieldIdent &) override;
   void visit (AST::SelfParam &) override;
 
   // resolutions
index 4772517c47e40388788a40e726927890ba126d76..5c52a3cababa62280d930ddda70c6ef975e4a31d 100644 (file)
@@ -16,7 +16,6 @@ derive_clone_enum3.rs
 derive-debug1.rs
 derive-default1.rs
 derive-eq-invalid.rs
-derive-hash1.rs
 torture/alt_patterns1.rs
 torture/name_resolve1.rs
 issue-3568.rs