Skip to content

Commit

Permalink
nr2.0: Improve default and top-level resolvers
Browse files Browse the repository at this point in the history
gcc/rust/ChangeLog:

	* resolve/rust-default-resolver.cc
	(DefaultResolver::visit): Make sure to scope visitation of the
	children of type definition items.
	* resolve/rust-default-resolver.h
	(DefaultResolver::visit): Add overrides for TupleStruct, Union,
	and TypeAlias.
	* resolve/rust-toplevel-name-resolver-2.0.cc
	(TopLevel::visit): Rely more on DefaultResolver::visit.
	* resolve/rust-toplevel-name-resolver-2.0.h
	(TopLevel::visit): Remove override for BlockExpr.

gcc/testsuite/ChangeLog:

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

Signed-off-by: Owen Avery <[email protected]>
  • Loading branch information
powerboat9 committed Dec 29, 2024
1 parent af5fdee commit dc3a0de
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 47 deletions.
35 changes: 28 additions & 7 deletions gcc/rust/resolve/rust-default-resolver.cc
Original file line number Diff line number Diff line change
Expand Up @@ -88,27 +88,48 @@ DefaultResolver::visit (AST::TraitImpl &impl)
void
DefaultResolver::visit (AST::StructStruct &type)
{
// do we need to scope anything here? no, right?
auto inner_fn = [this, &type] () { AST::DefaultASTVisitor::visit (type); };

// we also can't visit `StructField`s by default, so there's nothing to do -
// correct? or should we do something like
ctx.scoped (Rib::Kind::Item /* FIXME: Correct? */, type.get_node_id (),
inner_fn, type.get_struct_name ());
}

AST::DefaultASTVisitor::visit (type);
void
DefaultResolver::visit (AST::TupleStruct &type)
{
auto inner_fn = [this, &type] () { AST::DefaultASTVisitor::visit (type); };

// FIXME: ???
ctx.scoped (Rib::Kind::Item /* FIXME: Correct? */, type.get_node_id (),
inner_fn, type.get_struct_name ());
}

void
DefaultResolver::visit (AST::Enum &type)
{
// FIXME: Do we need to scope anything by default?

auto variant_fn = [this, &type] () { AST::DefaultASTVisitor::visit (type); };

ctx.scoped (Rib::Kind::Item /* FIXME: Correct? */, type.get_node_id (),
variant_fn, type.get_identifier ());
}

void
DefaultResolver::visit (AST::Union &type)
{
auto inner_fn = [this, &type] () { AST::DefaultASTVisitor::visit (type); };

ctx.scoped (Rib::Kind::Item /* FIXME: Correct? */, type.get_node_id (),
inner_fn, type.get_identifier ());
}

void
DefaultResolver::visit (AST::TypeAlias &type)
{
auto inner_fn = [this, &type] () { AST::DefaultASTVisitor::visit (type); };

ctx.scoped (Rib::Kind::Item /* FIXME: Correct? */, type.get_node_id (),
inner_fn, type.get_new_type_name ());
}

void
DefaultResolver::visit (AST::ClosureExprInner &expr)
{
Expand Down
3 changes: 3 additions & 0 deletions gcc/rust/resolve/rust-default-resolver.h
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,10 @@ class DefaultResolver : public AST::DefaultASTVisitor

// type dec nodes, which visit their fields or variants by default
void visit (AST::StructStruct &) override;
void visit (AST::TupleStruct &) override;
void visit (AST::Enum &) override;
void visit (AST::Union &) override;
void visit (AST::TypeAlias &) override;

// Visitors that visit their expression node(s)
void visit (AST::ClosureExprInner &) override;
Expand Down
41 changes: 10 additions & 31 deletions gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc
Original file line number Diff line number Diff line change
Expand Up @@ -87,13 +87,7 @@ TopLevel::visit (AST::Module &module)
if (module.get_kind () == AST::Module::UNLOADED)
module.load_items ();

auto sub_visitor = [this, &module] () {
for (auto &item : module.get_items ())
item->accept_vis (*this);
};

ctx.scoped (Rib::Kind::Module, module.get_node_id (), sub_visitor,
module.get_name ());
DefaultResolver::visit (module);

if (Analysis::Mappings::get ().lookup_ast_module (module.get_node_id ())
== tl::nullopt)
Expand Down Expand Up @@ -221,23 +215,6 @@ TopLevel::visit (AST::Function &function)
DefaultResolver::visit (function);
}

void
TopLevel::visit (AST::BlockExpr &expr)
{
// extracting the lambda from the `scoped` call otherwise the code looks like
// a hot turd thanks to our .clang-format

auto sub_vis = [this, &expr] () {
for (auto &stmt : expr.get_statements ())
stmt->accept_vis (*this);

if (expr.has_tail_expr ())
expr.get_tail_expr ().accept_vis (*this);
};

ctx.scoped (Rib::Kind::Normal, expr.get_node_id (), sub_vis);
}

void
TopLevel::visit (AST::StaticItem &static_item)
{
Expand All @@ -252,6 +229,8 @@ TopLevel::visit (AST::ExternalStaticItem &static_item)
{
insert_or_error_out (static_item.get_identifier ().as_string (), static_item,
Namespace::Values);

DefaultResolver::visit (static_item);
}

void
Expand Down Expand Up @@ -285,6 +264,8 @@ TopLevel::visit (AST::TypeParam &type_param)
if (type_param.get_type_representation ().as_string () != "Self")
insert_or_error_out (type_param.get_type_representation (), type_param,
Namespace::Types);

DefaultResolver::visit (type_param);
}

void
Expand All @@ -303,6 +284,8 @@ TopLevel::visit (AST::TupleStruct &tuple_struct)

insert_or_error_out (tuple_struct.get_struct_name (), tuple_struct,
Namespace::Values);

DefaultResolver::visit (tuple_struct);
}

void
Expand Down Expand Up @@ -335,20 +318,16 @@ TopLevel::visit (AST::Enum &enum_item)
insert_or_error_out (enum_item.get_identifier (), enum_item,
Namespace::Types);

auto field_vis = [this, &enum_item] () {
for (auto &variant : enum_item.get_variants ())
variant->accept_vis (*this);
};

ctx.scoped (Rib::Kind::Item /* FIXME: Is that correct? */,
enum_item.get_node_id (), field_vis, enum_item.get_identifier ());
DefaultResolver::visit (enum_item);
}

void
TopLevel::visit (AST::Union &union_item)
{
insert_or_error_out (union_item.get_identifier (), union_item,
Namespace::Types);

DefaultResolver::visit (union_item);
}

void
Expand Down
1 change: 0 additions & 1 deletion gcc/rust/resolve/rust-toplevel-name-resolver-2.0.h
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,6 @@ class TopLevel : public DefaultResolver
void visit (AST::Trait &trait) override;
void visit (AST::MacroRulesDefinition &macro) override;
void visit (AST::Function &function) override;
void visit (AST::BlockExpr &expr) override;
void visit (AST::StaticItem &static_item) override;
void visit (AST::ExternalStaticItem &static_item) override;
void visit (AST::StructStruct &struct_item) override;
Expand Down
8 changes: 0 additions & 8 deletions gcc/testsuite/rust/compile/nr2/exclude
Original file line number Diff line number Diff line change
Expand Up @@ -25,30 +25,25 @@ derive_macro3.rs
derive_macro4.rs
derive_macro6.rs
expected_type_args2.rs
expected_type_args3.rs
feature_rust_attri0.rs
for_lifetimes.rs
format_args_basic_expansion.rs
generic-default1.rs
generics1.rs
generics10.rs
generics11.rs
generics2.rs
generics3.rs
generics4.rs
generics5.rs
generics6.rs
generics8.rs
generics9.rs
if_let_expr.rs
issue-1019.rs
issue-1031.rs
issue-1034.rs
issue-1129-2.rs
issue-1130.rs
issue-1165.rs
issue-1173.rs
issue-1235.rs
issue-1272.rs
issue-1289.rs
issue-1447.rs
Expand Down Expand Up @@ -122,7 +117,6 @@ multiple_bindings1.rs
multiple_bindings2.rs
name_resolution2.rs
name_resolution4.rs
nested_generic.rs
nested_macro_use1.rs
nested_macro_use2.rs
nested_macro_use3.rs
Expand All @@ -147,7 +141,6 @@ pub_restricted_3.rs
redef_error2.rs
redef_error4.rs
redef_error5.rs
redef_error6.rs
self-path1.rs
self-path2.rs
sizeof-stray-infer-var-bug.rs
Expand Down Expand Up @@ -199,7 +192,6 @@ if_let_expr_simple.rs
iflet.rs
issue-3033.rs
issue-3009.rs
issue-2323.rs
issue-2953-1.rs
issue-2953-2.rs
issue-1773.rs
Expand Down

0 comments on commit dc3a0de

Please sign in to comment.