use crate::nodes::{Expression, Token};
#[derive(Clone, Debug, PartialEq, Eq)]
pub struct ReturnTokens {
pub r#return: Token,
pub commas: Vec<Token>,
}
impl ReturnTokens {
super::impl_token_fns!(
target = [r#return]
iter = [commas]
);
}
#[derive(Clone, Debug, Default, PartialEq, Eq)]
pub struct ReturnStatement {
expressions: Vec<Expression>,
tokens: Option<ReturnTokens>,
}
impl ReturnStatement {
pub fn new(expressions: Vec<Expression>) -> Self {
Self {
expressions,
tokens: None,
}
}
pub fn one<E: Into<Expression>>(expression: E) -> Self {
Self {
expressions: vec![expression.into()],
tokens: None,
}
}
pub fn with_expression<E: Into<Expression>>(mut self, expression: E) -> Self {
self.expressions.push(expression.into());
self
}
#[inline]
pub fn iter_expressions(&self) -> impl Iterator<Item = &Expression> {
self.expressions.iter()
}
#[inline]
pub fn into_iter_expressions(self) -> impl Iterator<Item = Expression> {
self.expressions.into_iter()
}
#[inline]
pub fn iter_mut_expressions(&mut self) -> impl Iterator<Item = &mut Expression> {
self.expressions.iter_mut()
}
#[inline]
pub fn is_empty(&self) -> bool {
self.expressions.is_empty()
}
#[inline]
pub fn len(&self) -> usize {
self.expressions.len()
}
pub fn with_tokens(mut self, tokens: ReturnTokens) -> Self {
self.tokens = Some(tokens);
self
}
#[inline]
pub fn set_tokens(&mut self, tokens: ReturnTokens) {
self.tokens = Some(tokens);
}
#[inline]
pub fn get_tokens(&self) -> Option<&ReturnTokens> {
self.tokens.as_ref()
}
#[inline]
pub fn mutate_tokens(&mut self) -> Option<&mut ReturnTokens> {
self.tokens.as_mut()
}
super::impl_token_fns!(iter = [tokens]);
}
#[derive(Clone, Debug, PartialEq, Eq)]
pub enum LastStatement {
Break(Option<Token>),
Continue(Option<Token>),
Return(ReturnStatement),
}
impl LastStatement {
#[inline]
pub fn new_break() -> Self {
Self::Break(None)
}
#[inline]
pub fn new_continue() -> Self {
Self::Continue(None)
}
}
impl From<ReturnStatement> for LastStatement {
fn from(statement: ReturnStatement) -> Self {
Self::Return(statement)
}
}
#[cfg(test)]
mod test {
use super::*;
#[test]
fn default_return_statement_is_empty() {
assert!(ReturnStatement::default().is_empty())
}
}