use crate::ast::prelude::*;
#[test]
#[cfg(not(miri))]
fn ast_parse() {
rt::<ast::ExprLet>("let x = 1");
rt::<ast::ExprLet>("#[attr] let a = f()");
}
#[derive(Debug, TryClone, PartialEq, Eq, ToTokens, Spanned)]
#[non_exhaustive]
pub struct ExprLet {
#[rune(iter)]
pub attributes: Vec<ast::Attribute>,
pub let_token: T![let],
#[rune(iter)]
pub mut_token: Option<T![mut]>,
pub pat: ast::Pat,
pub eq: T![=],
pub expr: Box<ast::Expr>,
}
impl ExprLet {
pub(crate) fn parse_with_meta(
parser: &mut Parser<'_>,
attributes: Vec<ast::Attribute>,
) -> Result<Self> {
Ok(Self {
attributes,
let_token: parser.parse()?,
mut_token: parser.parse()?,
pat: parser.parse()?,
eq: parser.parse()?,
expr: Box::try_new(ast::Expr::parse_without_eager_brace(parser)?)?,
})
}
pub(crate) fn parse_without_eager_brace(parser: &mut Parser<'_>) -> Result<Self> {
Ok(Self {
attributes: Vec::new(),
let_token: parser.parse()?,
mut_token: parser.parse()?,
pat: parser.parse()?,
eq: parser.parse()?,
expr: Box::try_new(ast::Expr::parse_without_eager_brace(parser)?)?,
})
}
}
expr_parse!(Let, ExprLet, "let expression");