From 26c832fcc2e344c222c6d6ca5cdb613b003aebf9 Mon Sep 17 00:00:00 2001 From: David Faust Date: Thu, 12 May 2022 15:47:34 -0700 Subject: resolve: Resolve range patterns --- gcc/rust/resolve/rust-ast-resolve-pattern.cc | 34 ++++++++++++++++++++++++++++ gcc/rust/resolve/rust-ast-resolve-pattern.h | 2 ++ 2 files changed, 36 insertions(+) (limited to 'gcc/rust/resolve') diff --git a/gcc/rust/resolve/rust-ast-resolve-pattern.cc b/gcc/rust/resolve/rust-ast-resolve-pattern.cc index bac5521..dc2cca4 100644 --- a/gcc/rust/resolve/rust-ast-resolve-pattern.cc +++ b/gcc/rust/resolve/rust-ast-resolve-pattern.cc @@ -131,5 +131,39 @@ PatternDeclaration::visit (AST::TuplePattern &pattern) } } +static void +resolve_range_pattern_bound (AST::RangePatternBound *bound, NodeId parent) +{ + switch (bound->get_bound_type ()) + { + case AST::RangePatternBound::RangePatternBoundType::LITERAL: + // Nothing to resolve for a literal. + break; + + case AST::RangePatternBound::RangePatternBoundType::PATH: { + AST::RangePatternBoundPath &ref + = *static_cast (bound); + + ResolvePath::go (&ref.get_path (), parent); + } + break; + + case AST::RangePatternBound::RangePatternBoundType::QUALPATH: { + AST::RangePatternBoundQualPath &ref + = *static_cast (bound); + + ResolvePath::go (&ref.get_qualified_path (), parent); + } + break; + } +} + +void +PatternDeclaration::visit (AST::RangePattern &pattern) +{ + resolve_range_pattern_bound (pattern.get_upper_bound ().get (), parent); + resolve_range_pattern_bound (pattern.get_lower_bound ().get (), parent); +} + } // namespace Resolver } // namespace Rust diff --git a/gcc/rust/resolve/rust-ast-resolve-pattern.h b/gcc/rust/resolve/rust-ast-resolve-pattern.h index 464e362..dfb05d3 100644 --- a/gcc/rust/resolve/rust-ast-resolve-pattern.h +++ b/gcc/rust/resolve/rust-ast-resolve-pattern.h @@ -103,6 +103,8 @@ public: void visit (AST::TuplePattern &pattern) override; + void visit (AST::RangePattern &pattern) override; + private: PatternDeclaration (NodeId parent) : ResolverBase (parent) {} }; -- cgit v1.1