From: Jakub Dupak Date: Tue, 17 Oct 2023 13:39:06 +0000 (+0200) Subject: gccrs: ast: Handle tuplestruct pattern with indices X-Git-Tag: basepoints/gcc-15~2071 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=259d3bd58d8969923ad66c78ea4c8f1539aafbfd;p=thirdparty%2Fgcc.git gccrs: ast: Handle tuplestruct pattern with indices gcc/rust/ChangeLog: * hir/rust-ast-lower-pattern.cc (ASTLoweringPattern::visit): Implement for tuple pat. * resolve/rust-ast-resolve-pattern.cc (PatternDeclaration::visit): Implement for tupple pat. gcc/testsuite/ChangeLog: * rust/compile/tupple_struct_pattern_tuple.rs: New test. Signed-off-by: Jakub Dupak --- diff --git a/gcc/rust/hir/rust-ast-lower-pattern.cc b/gcc/rust/hir/rust-ast-lower-pattern.cc index bfb7b71cef21..4693e7da04b1 100644 --- a/gcc/rust/hir/rust-ast-lower-pattern.cc +++ b/gcc/rust/hir/rust-ast-lower-pattern.cc @@ -122,8 +122,23 @@ ASTLoweringPattern::visit (AST::StructPattern &pattern) switch (field->get_item_type ()) { case AST::StructPatternField::ItemType::TUPLE_PAT: { - // TODO - rust_unreachable (); + AST::StructPatternFieldTuplePat &tuple + = static_cast (*field); + + auto crate_num = mappings->get_current_crate (); + Analysis::NodeMapping mapping (crate_num, tuple.get_node_id (), + mappings->get_next_hir_id ( + crate_num), + UNKNOWN_LOCAL_DEFID); + + std::unique_ptr pat (ASTLoweringPattern::translate ( + tuple.get_index_pattern ().get ())); + + f = new HIR::StructPatternFieldTuplePat (mapping, + tuple.get_index (), + std::move (pat), + tuple.get_outer_attrs (), + tuple.get_locus ()); } break; diff --git a/gcc/rust/resolve/rust-ast-resolve-pattern.cc b/gcc/rust/resolve/rust-ast-resolve-pattern.cc index 934300532d8f..545fcf82d44a 100644 --- a/gcc/rust/resolve/rust-ast-resolve-pattern.cc +++ b/gcc/rust/resolve/rust-ast-resolve-pattern.cc @@ -124,8 +124,10 @@ PatternDeclaration::visit (AST::StructPattern &pattern) switch (field->get_item_type ()) { case AST::StructPatternField::ItemType::TUPLE_PAT: { - // TODO - rust_unreachable (); + AST::StructPatternFieldTuplePat &tuple + = static_cast (*field); + + tuple.get_index_pattern ()->accept_vis (*this); } break; @@ -151,9 +153,6 @@ PatternDeclaration::visit (AST::StructPattern &pattern) break; } } - - // TODO - rust_assert (!struct_pattern_elems.has_etc ()); } void diff --git a/gcc/testsuite/rust/compile/tupple_struct_pattern_tuple.rs b/gcc/testsuite/rust/compile/tupple_struct_pattern_tuple.rs new file mode 100644 index 000000000000..053b9ce7e27e --- /dev/null +++ b/gcc/testsuite/rust/compile/tupple_struct_pattern_tuple.rs @@ -0,0 +1,4 @@ +// { dg-additional-options "-frust-compile-until=typecheck" } +struct Struct(i32); + +fn struct_pattern(Struct { 0: a }: Struct) {}