Skip to content

Commit

Permalink
late: Start storing mappings properly in the resolver
Browse files Browse the repository at this point in the history
gcc/rust/ChangeLog:

	* resolve/rust-late-name-resolver-2.0.cc (Late::visit): Store mappings
	after having resolved them.
	* resolve/rust-late-name-resolver-2.0.h: Add `TypePath` visitor.
  • Loading branch information
CohenArthur committed Nov 22, 2023
1 parent 163012c commit 3fbc2a8
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 5 deletions.
33 changes: 28 additions & 5 deletions gcc/rust/resolve/rust-late-name-resolver-2.0.cc
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
#include "rust-ast-full.h"
#include "rust-late-name-resolver-2.0.h"
#include "rust-default-resolver.h"
#include "rust-path.h"
#include "rust-tyty.h"
#include "rust-hir-type-check.h"

Expand Down Expand Up @@ -121,11 +122,24 @@ Late::visit (AST::IdentifierExpr &expr)
{
// TODO: same thing as visit(PathInExpression) here?

tl::optional<NodeId> resolved = tl::nullopt;
auto label = ctx.labels.get (expr.get_ident ());
auto value = ctx.values.get (expr.get_ident ());

rust_debug ("[ARTHUR] label: %d", label ? *label : -1);
rust_debug ("[ARTHUR] value: %d", value ? *value : -1);
if (label)
resolved = label;
else if (value)
resolved = value;
// TODO: else emit error?

ctx.map_usage (expr.get_node_id (), *resolved);

// in the old resolver, resolutions are kept in the resolver, not the mappings
// :/ how do we deal with that?
// ctx.mappings.insert_resolved_name(expr, resolved);

// For empty types, do we perform a lookup in ctx.types or should the
// toplevel instead insert a name in ctx.values? (like it currently does)
}

void
Expand All @@ -136,11 +150,20 @@ Late::visit (AST::PathInExpression &expr)
// do we emit it in `get<Namespace::Labels>`?

auto label = ctx.labels.resolve_path (expr.get_segments ());

auto value = ctx.values.resolve_path (expr.get_segments ());
}

void
Late::visit (AST::TypePath &type)
{
// should we add type path resolution in `ForeverStack` directly? Since it's
// quite more complicated.
// maybe we can overload `resolve_path<Namespace::Types>` to only do
// typepath-like path resolution? that sounds good

auto resolved = ctx.types.get (type.get_segments ().back ()->as_string ());

rust_debug ("[ARTHUR] label: %d", label ? *label : -1);
rust_debug ("[ARTHUR] value: %d", value ? *value : -1);
ctx.map_usage (type.get_node_id (), *resolved);
}

} // namespace Resolver2_0
Expand Down
1 change: 1 addition & 0 deletions gcc/rust/resolve/rust-late-name-resolver-2.0.h
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ class Late : public DefaultResolver
// resolutions
void visit (AST::IdentifierExpr &) override;
void visit (AST::PathInExpression &) override;
void visit (AST::TypePath &) override;

private:
/* Setup Rust's builtin types (u8, i32, !...) in the resolver */
Expand Down

0 comments on commit 3fbc2a8

Please sign in to comment.