use crate::*; // ----------------------------------------------------------------------------- #[tracable_parser] pub(crate) fn constant_function_call(s: Span) -> IResult { let (s, a) = function_subroutine_call(s)?; Ok((s, ConstantFunctionCall { nodes: (a,) })) } #[tracable_parser] pub(crate) fn tf_call(s: Span) -> IResult { let (s, a) = ps_or_hierarchical_tf_identifier(s)?; let (s, b) = many0(attribute_instance)(s)?; let (s, c) = opt(paren(list_of_arguments))(s)?; Ok((s, TfCall { nodes: (a, b, c) })) } #[tracable_parser] pub(crate) fn system_tf_call(s: Span) -> IResult { alt(( system_tf_call_arg_optional, system_tf_call_arg_data_type, system_tf_call_arg_expression, ))(s) } #[tracable_parser] pub(crate) fn system_tf_call_arg_optional(s: Span) -> IResult { let (s, a) = system_tf_identifier(s)?; let (s, b) = opt(paren(list_of_arguments))(s)?; Ok(( s, SystemTfCall::ArgOptionl(Box::new(SystemTfCallArgOptional { nodes: (a, b) })), )) } #[tracable_parser] pub(crate) fn system_tf_call_arg_data_type(s: Span) -> IResult { let (s, a) = system_tf_identifier(s)?; let (s, b) = paren(pair(data_type, opt(pair(symbol(","), expression))))(s)?; Ok(( s, SystemTfCall::ArgDataType(Box::new(SystemTfCallArgDataType { nodes: (a, b) })), )) } #[tracable_parser] pub(crate) fn system_tf_call_arg_expression(s: Span) -> IResult { let (s, a) = system_tf_identifier(s)?; let (s, b) = paren(pair( list(symbol(","), opt(expression)), opt(pair(symbol(","), opt(clocking_event))), ))(s)?; Ok(( s, SystemTfCall::ArgExpression(Box::new(SystemTfCallArgExpression { nodes: (a, b) })), )) } #[packrat_parser] #[tracable_parser] pub(crate) fn subroutine_call(s: Span) -> IResult { alt(( map(tf_call, |x| SubroutineCall::TfCall(Box::new(x))), map(system_tf_call, |x| { SubroutineCall::SystemTfCall(Box::new(x)) }), map(method_call, |x| SubroutineCall::MethodCall(Box::new(x))), subroutine_call_randomize, ))(s) } #[tracable_parser] pub(crate) fn subroutine_call_randomize(s: Span) -> IResult { let (s, a) = opt(pair(keyword("std"), symbol("::")))(s)?; let (s, b) = randomize_call(s)?; Ok(( s, SubroutineCall::Randomize(Box::new(SubroutineCallRandomize { nodes: (a, b) })), )) } #[tracable_parser] pub(crate) fn function_subroutine_call(s: Span) -> IResult { map(subroutine_call, |x| FunctionSubroutineCall { nodes: (x,) })(s) } #[tracable_parser] pub(crate) fn list_of_arguments(s: Span) -> IResult { alt((list_of_arguments_ordered, list_of_arguments_named))(s) } #[recursive_parser] #[tracable_parser] pub(crate) fn list_of_arguments_ordered(s: Span) -> IResult { let (s, a) = list(symbol(","), opt(expression))(s)?; let (s, b) = many0(tuple(( symbol(","), symbol("."), identifier, paren(opt(expression)), )))(s)?; Ok(( s, ListOfArguments::Ordered(Box::new(ListOfArgumentsOrdered { nodes: (a, b) })), )) } #[tracable_parser] pub(crate) fn list_of_arguments_named(s: Span) -> IResult { let (s, a) = symbol(".")(s)?; let (s, b) = identifier(s)?; let (s, c) = paren(opt(expression))(s)?; let (s, d) = many0(tuple(( symbol(","), symbol("."), identifier, paren(opt(expression)), )))(s)?; Ok(( s, ListOfArguments::Named(Box::new(ListOfArgumentsNamed { nodes: (a, b, c, d), })), )) } #[recursive_parser] #[tracable_parser] pub(crate) fn method_call(s: Span) -> IResult { let (s, a) = method_call_root(s)?; let (s, b) = symbol(".")(s)?; let (s, c) = method_call_body(s)?; Ok((s, MethodCall { nodes: (a, b, c) })) } #[tracable_parser] pub(crate) fn method_call_body(s: Span) -> IResult { alt(( method_call_body_user, map(built_in_method_call, |x| { MethodCallBody::BuiltInMethodCall(Box::new(x)) }), ))(s) } #[tracable_parser] pub(crate) fn method_call_body_user(s: Span) -> IResult { let (s, a) = method_identifier(s)?; let (s, b) = many0(attribute_instance)(s)?; let (s, c) = opt(paren(list_of_arguments))(s)?; Ok(( s, MethodCallBody::User(Box::new(MethodCallBodyUser { nodes: (a, b, c) })), )) } #[tracable_parser] pub(crate) fn built_in_method_call(s: Span) -> IResult { alt(( map(array_manipulation_call, |x| { BuiltInMethodCall::ArrayManipulationCall(Box::new(x)) }), map(randomize_call, |x| { BuiltInMethodCall::RandomizeCall(Box::new(x)) }), ))(s) } #[tracable_parser] pub(crate) fn array_manipulation_call(s: Span) -> IResult { let (s, a) = array_method_name(s)?; let (s, b) = many0(attribute_instance)(s)?; let (s, c) = opt(paren(list_of_arguments))(s)?; let (s, d) = opt(pair(keyword("with"), paren(expression)))(s)?; Ok(( s, ArrayManipulationCall { nodes: (a, b, c, d), }, )) } #[tracable_parser] pub(crate) fn randomize_call(s: Span) -> IResult { let (s, a) = keyword("randomize")(s)?; let (s, b) = many0(attribute_instance)(s)?; let (s, c) = opt(paren(opt(variable_identifier_list_or_null)))(s)?; let (s, d) = opt(triple( keyword("with"), opt(paren(opt(identifier_list))), constraint_block, ))(s)?; Ok(( s, RandomizeCall { nodes: (a, b, c, d), }, )) } #[tracable_parser] pub(crate) fn variable_identifier_list_or_null( s: Span, ) -> IResult { alt(( map(variable_identifier_list, |x| { VariableIdentifierListOrNull::VariableIdentifierList(Box::new(x)) }), map(keyword("null"), |x| { VariableIdentifierListOrNull::Null(Box::new(x)) }), ))(s) } #[tracable_parser] pub(crate) fn method_call_root(s: Span) -> IResult { alt(( map(primary, |x| MethodCallRoot::Primary(Box::new(x))), map(implicit_class_handle, |x| { MethodCallRoot::ImplicitClassHandle(Box::new(x)) }), ))(s) } #[tracable_parser] pub(crate) fn array_method_name(s: Span) -> IResult { alt(( map(keyword("unique"), |x| ArrayMethodName::Unique(Box::new(x))), map(keyword("and"), |x| ArrayMethodName::And(Box::new(x))), map(keyword("or"), |x| ArrayMethodName::Or(Box::new(x))), map(keyword("xor"), |x| ArrayMethodName::Xor(Box::new(x))), map(method_identifier, |x| { ArrayMethodName::MethodIdentifier(Box::new(x)) }), ))(s) }