"raw address of syntax is experimental");
}
+void
+FeatureGate::visit (AST::RangePattern &pattern)
+{
+ if (pattern.get_range_kind () == AST::RangeKind::EXCLUDED)
+ gate (Feature::Name::EXCLUSIVE_RANGE_PATTERN, pattern.get_locus (),
+ "exclusive range pattern syntax is experimental");
+}
+
} // namespace Rust
void visit (AST::ForLoopExpr &expr) override {}
void visit (AST::IfExpr &expr) override {}
void visit (AST::IfExprConseqElse &expr) override {}
- void visit (AST::IfLetExpr &expr) override {}
void visit (AST::IfLetExprConseqElse &expr) override {}
- void visit (AST::MatchExpr &expr) override {}
void visit (AST::AwaitExpr &expr) override {}
void visit (AST::AsyncBlockExpr &expr) override {}
void visit (AST::TypeParam ¶m) override;
void visit (AST::RangePatternBoundLiteral &bound) override {}
void visit (AST::RangePatternBoundPath &bound) override {}
void visit (AST::RangePatternBoundQualPath &bound) override {}
- void visit (AST::RangePattern &pattern) override {}
+ void visit (AST::RangePattern &pattern) override;
void visit (AST::ReferencePattern &pattern) override {}
void visit (AST::StructPatternFieldTuplePat &field) override {}
void visit (AST::StructPatternFieldIdentPat &field) override {}
case Feature::Name::RAW_REF_OP:
return Feature (Feature::Name::RAW_REF_OP, Feature::State::ACTIVE,
"raw_ref_op", "1.41.0", 64490, tl::nullopt, "");
+ case Feature::Name::EXCLUSIVE_RANGE_PATTERN:
+ return Feature (Feature::Name::EXCLUSIVE_RANGE_PATTERN,
+ Feature::State::ACTIVE, "exclusive_range_pattern",
+ "1.11.0", 37854, tl::nullopt, "");
default:
rust_unreachable ();
}
{"box_syntax", Feature::Name::BOX_SYNTAX},
{"dropck_eyepatch", Feature::Name::DROPCK_EYEPATCH},
{"raw_ref_op", Feature::Name::RAW_REF_OP},
+ {"exclusive_range_pattern", Feature::Name::EXCLUSIVE_RANGE_PATTERN},
}; // namespace Rust
tl::optional<Feature::Name>
BOX_SYNTAX,
DROPCK_EYEPATCH,
RAW_REF_OP,
+ EXCLUSIVE_RANGE_PATTERN,
};
const std::string &as_string () { return m_name_str; }
return std::unique_ptr<AST::RangePattern> (
new AST::RangePattern (std::move (lower_bound),
std::move (upper_bound), kind,
- UNKNOWN_LOCATION));
+ next->get_locus ()));
}
case EXCLAM:
return parse_macro_invocation_partial (std::move (path),
return std::unique_ptr<AST::RangePattern> (
new AST::RangePattern (std::move (lower_bound),
std::move (upper_bound), kind,
- UNKNOWN_LOCATION));
+ t->get_locus ()));
}
case PATTERN_BIND: {
// only allow on single-segment paths