fluent4rs 2.3.1

Parser / codec for [Fluent FTL files](https://github.com/projectfluent/fluent/blob/master/spec/fluent.ebnf), written for [lingora](https://github.com/nigeleke/lingora) (a localization management program), and may be found to be useful outside of that context. It is not intended to replace any aspects of the [fluent-rs](https://github.com/projectfluent/fluent-rs) crate implemented by [Project Fluent](https://projectfluent.org/), and, for the majority of language translation needs, the reader is referred back to that crate.
Documentation
#[cfg(feature = "serde")]
use serde::{Deserialize, Serialize};

use super::Argument;
#[cfg(feature = "walker")]
use crate::walker::{Visitor, Walkable, Walker};

/// [CallArguments](crate::ast::CallArguments) ::= blank? "(" blank? argument_list blank? ")"
#[derive(Clone, Debug, PartialEq)]
#[cfg_attr(feature = "hash", derive(Eq, PartialOrd, Ord, Hash))]
#[cfg_attr(feature = "serde", derive(Deserialize, Serialize))]
pub struct CallArguments(Vec<Argument>);

impl CallArguments {
    /// Returns a reference to the call arguments.
    pub fn arguments(&self) -> &[Argument] {
        self.0.as_slice()
    }
}

impl From<&[Argument]> for CallArguments {
    fn from(value: &[Argument]) -> Self {
        Self(Vec::from(value))
    }
}

#[cfg(feature = "walker")]
impl Walkable for CallArguments {
    fn walk(&self, visitor: &mut dyn Visitor) {
        visitor.visit_call_arguments(self);
        self.0.iter().for_each(|a| Walker::walk(a, visitor));
    }
}

impl std::fmt::Display for CallArguments {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        let arguments = self
            .0
            .iter()
            .map(|a| a.to_string())
            .collect::<Vec<_>>()
            .join(", ");
        write!(f, "({arguments})")
    }
}