#[cfg(test)]
mod tests;
use crate::{
parser::{
AllowAwait, AllowDefault, AllowYield, Cursor, ParseResult, TokenParser,
statement::declaration::hoistable::{CallableDeclaration, parse_callable_declaration},
},
source::ReadChar,
};
use boa_ast::{Keyword, function::FunctionDeclaration as FunctionDeclarationNode};
use boa_interner::Interner;
#[derive(Debug, Clone, Copy)]
pub(in crate::parser) struct FunctionDeclaration {
allow_yield: AllowYield,
allow_await: AllowAwait,
is_default: AllowDefault,
}
impl FunctionDeclaration {
pub(in crate::parser) fn new<Y, A, D>(allow_yield: Y, allow_await: A, is_default: D) -> Self
where
Y: Into<AllowYield>,
A: Into<AllowAwait>,
D: Into<AllowDefault>,
{
Self {
allow_yield: allow_yield.into(),
allow_await: allow_await.into(),
is_default: is_default.into(),
}
}
}
impl CallableDeclaration for FunctionDeclaration {
fn error_context(&self) -> &'static str {
"function declaration"
}
fn is_default(&self) -> bool {
self.is_default.0
}
fn name_allow_yield(&self) -> bool {
self.allow_yield.0
}
fn name_allow_await(&self) -> bool {
self.allow_await.0
}
fn parameters_allow_yield(&self) -> bool {
false
}
fn parameters_allow_await(&self) -> bool {
false
}
fn body_allow_yield(&self) -> bool {
false
}
fn body_allow_await(&self) -> bool {
false
}
}
impl<R> TokenParser<R> for FunctionDeclaration
where
R: ReadChar,
{
type Output = FunctionDeclarationNode;
fn parse(self, cursor: &mut Cursor<R>, interner: &mut Interner) -> ParseResult<Self::Output> {
let func_token =
cursor.expect((Keyword::Function, false), "function declaration", interner)?;
let func_token_span = func_token.linear_span();
let result = parse_callable_declaration(&self, cursor, interner)?;
let linear_pos_end = result.2.linear_pos_end();
let span = func_token_span.union(linear_pos_end);
Ok(FunctionDeclarationNode::new(
result.0, result.1, result.2, span,
))
}
}