use crate::veryl_grammar_trait::*;
use crate::veryl_token::VerylToken;
macro_rules! before {
($x:ident, $y:ident, $z:ident) => {
if let Some(mut handlers) = $x.get_handlers() {
for handler in handlers.iter_mut() {
handler.set_point(HandlerPoint::Before);
let _ = handler.$y($z);
}
}
};
}
macro_rules! after {
($x:ident, $y:ident, $z:ident) => {
if let Some(mut handlers) = $x.get_handlers() {
for handler in handlers.iter_mut() {
handler.set_point(HandlerPoint::After);
let _ = handler.$y($z);
}
}
};
}
pub trait VerylWalker {
fn veryl_token(&mut self, _arg: &VerylToken) {}
fn start(&mut self, arg: &Start) {
before!(self, start, arg);
self.veryl_token(&arg.start_token);
after!(self, start, arg);
}
fn string_literal(&mut self, arg: &StringLiteral) {
before!(self, string_literal, arg);
self.veryl_token(&arg.string_literal_token);
after!(self, string_literal, arg);
}
fn exponent(&mut self, arg: &Exponent) {
before!(self, exponent, arg);
self.veryl_token(&arg.exponent_token);
after!(self, exponent, arg);
}
fn fixed_point(&mut self, arg: &FixedPoint) {
before!(self, fixed_point, arg);
self.veryl_token(&arg.fixed_point_token);
after!(self, fixed_point, arg);
}
fn based(&mut self, arg: &Based) {
before!(self, based, arg);
self.veryl_token(&arg.based_token);
after!(self, based, arg);
}
fn base_less(&mut self, arg: &BaseLess) {
before!(self, base_less, arg);
self.veryl_token(&arg.base_less_token);
after!(self, base_less, arg);
}
fn all_bit(&mut self, arg: &AllBit) {
before!(self, all_bit, arg);
self.veryl_token(&arg.all_bit_token);
after!(self, all_bit, arg);
}
fn assignment_operator(&mut self, arg: &AssignmentOperator) {
before!(self, assignment_operator, arg);
self.veryl_token(&arg.assignment_operator_token);
after!(self, assignment_operator, arg);
}
fn operator01(&mut self, arg: &Operator01) {
before!(self, operator01, arg);
self.veryl_token(&arg.operator01_token);
after!(self, operator01, arg);
}
fn operator02(&mut self, arg: &Operator02) {
before!(self, operator02, arg);
self.veryl_token(&arg.operator02_token);
after!(self, operator02, arg);
}
fn operator03(&mut self, arg: &Operator03) {
before!(self, operator03, arg);
self.veryl_token(&arg.operator03_token);
after!(self, operator03, arg);
}
fn operator04(&mut self, arg: &Operator04) {
before!(self, operator04, arg);
self.veryl_token(&arg.operator04_token);
after!(self, operator04, arg);
}
fn operator05(&mut self, arg: &Operator05) {
before!(self, operator05, arg);
self.veryl_token(&arg.operator05_token);
after!(self, operator05, arg);
}
fn operator06(&mut self, arg: &Operator06) {
before!(self, operator06, arg);
self.veryl_token(&arg.operator06_token);
after!(self, operator06, arg);
}
fn operator07(&mut self, arg: &Operator07) {
before!(self, operator07, arg);
self.veryl_token(&arg.operator07_token);
after!(self, operator07, arg);
}
fn operator08(&mut self, arg: &Operator08) {
before!(self, operator08, arg);
self.veryl_token(&arg.operator08_token);
after!(self, operator08, arg);
}
fn operator09(&mut self, arg: &Operator09) {
before!(self, operator09, arg);
self.veryl_token(&arg.operator09_token);
after!(self, operator09, arg);
}
fn operator10(&mut self, arg: &Operator10) {
before!(self, operator10, arg);
self.veryl_token(&arg.operator10_token);
after!(self, operator10, arg);
}
fn operator11(&mut self, arg: &Operator11) {
before!(self, operator11, arg);
self.veryl_token(&arg.operator11_token);
after!(self, operator11, arg);
}
fn unary_operator(&mut self, arg: &UnaryOperator) {
before!(self, unary_operator, arg);
self.veryl_token(&arg.unary_operator_token);
after!(self, unary_operator, arg);
}
fn colon(&mut self, arg: &Colon) {
before!(self, colon, arg);
self.veryl_token(&arg.colon_token);
after!(self, colon, arg);
}
fn colon_colon(&mut self, arg: &ColonColon) {
before!(self, colon_colon, arg);
self.veryl_token(&arg.colon_colon_token);
after!(self, colon_colon, arg);
}
fn comma(&mut self, arg: &Comma) {
before!(self, comma, arg);
self.veryl_token(&arg.comma_token);
after!(self, comma, arg);
}
fn dollar(&mut self, arg: &Dollar) {
before!(self, dollar, arg);
self.veryl_token(&arg.dollar_token);
after!(self, dollar, arg);
}
fn dot_dot(&mut self, arg: &DotDot) {
before!(self, dot_dot, arg);
self.veryl_token(&arg.dot_dot_token);
after!(self, dot_dot, arg);
}
fn dot(&mut self, arg: &Dot) {
before!(self, dot, arg);
self.veryl_token(&arg.dot_token);
after!(self, dot, arg);
}
fn equ(&mut self, arg: &Equ) {
before!(self, equ, arg);
self.veryl_token(&arg.equ_token);
after!(self, equ, arg);
}
fn hash(&mut self, arg: &Hash) {
before!(self, hash, arg);
self.veryl_token(&arg.hash_token);
after!(self, hash, arg);
}
fn l_angle(&mut self, arg: &LAngle) {
before!(self, l_angle, arg);
self.veryl_token(&arg.l_angle_token);
after!(self, l_angle, arg);
}
fn l_brace(&mut self, arg: &LBrace) {
before!(self, l_brace, arg);
self.veryl_token(&arg.l_brace_token);
after!(self, l_brace, arg);
}
fn l_bracket(&mut self, arg: &LBracket) {
before!(self, l_bracket, arg);
self.veryl_token(&arg.l_bracket_token);
after!(self, l_bracket, arg);
}
fn l_paren(&mut self, arg: &LParen) {
before!(self, l_paren, arg);
self.veryl_token(&arg.l_paren_token);
after!(self, l_paren, arg);
}
fn minus_colon(&mut self, arg: &MinusColon) {
before!(self, minus_colon, arg);
self.veryl_token(&arg.minus_colon_token);
after!(self, minus_colon, arg);
}
fn minus_g_t(&mut self, arg: &MinusGT) {
before!(self, minus_g_t, arg);
self.veryl_token(&arg.minus_g_t_token);
after!(self, minus_g_t, arg);
}
fn plus_colon(&mut self, arg: &PlusColon) {
before!(self, plus_colon, arg);
self.veryl_token(&arg.plus_colon_token);
after!(self, plus_colon, arg);
}
fn r_angle(&mut self, arg: &RAngle) {
before!(self, r_angle, arg);
self.veryl_token(&arg.r_angle_token);
after!(self, r_angle, arg);
}
fn r_brace(&mut self, arg: &RBrace) {
before!(self, r_brace, arg);
self.veryl_token(&arg.r_brace_token);
after!(self, r_brace, arg);
}
fn r_bracket(&mut self, arg: &RBracket) {
before!(self, r_bracket, arg);
self.veryl_token(&arg.r_bracket_token);
after!(self, r_bracket, arg);
}
fn r_paren(&mut self, arg: &RParen) {
before!(self, r_paren, arg);
self.veryl_token(&arg.r_paren_token);
after!(self, r_paren, arg);
}
fn semicolon(&mut self, arg: &Semicolon) {
before!(self, semicolon, arg);
self.veryl_token(&arg.semicolon_token);
after!(self, semicolon, arg);
}
fn star(&mut self, arg: &Star) {
before!(self, star, arg);
self.veryl_token(&arg.star_token);
after!(self, star, arg);
}
fn always_comb(&mut self, arg: &AlwaysComb) {
before!(self, always_comb, arg);
self.veryl_token(&arg.always_comb_token);
after!(self, always_comb, arg);
}
fn always_ff(&mut self, arg: &AlwaysFf) {
before!(self, always_ff, arg);
self.veryl_token(&arg.always_ff_token);
after!(self, always_ff, arg);
}
fn r#as(&mut self, arg: &As) {
before!(self, r#as, arg);
self.veryl_token(&arg.as_token);
after!(self, r#as, arg);
}
fn assign(&mut self, arg: &Assign) {
before!(self, assign, arg);
self.veryl_token(&arg.assign_token);
after!(self, assign, arg);
}
fn async_high(&mut self, arg: &AsyncHigh) {
before!(self, async_high, arg);
self.veryl_token(&arg.async_high_token);
after!(self, async_high, arg);
}
fn async_low(&mut self, arg: &AsyncLow) {
before!(self, async_low, arg);
self.veryl_token(&arg.async_low_token);
after!(self, async_low, arg);
}
fn bit(&mut self, arg: &Bit) {
before!(self, bit, arg);
self.veryl_token(&arg.bit_token);
after!(self, bit, arg);
}
fn case(&mut self, arg: &Case) {
before!(self, case, arg);
self.veryl_token(&arg.case_token);
after!(self, case, arg);
}
fn defaul(&mut self, arg: &Defaul) {
before!(self, defaul, arg);
self.veryl_token(&arg.default_token);
after!(self, defaul, arg);
}
fn r#else(&mut self, arg: &Else) {
before!(self, r#else, arg);
self.veryl_token(&arg.else_token);
after!(self, r#else, arg);
}
fn r#enum(&mut self, arg: &Enum) {
before!(self, r#enum, arg);
self.veryl_token(&arg.enum_token);
after!(self, r#enum, arg);
}
fn export(&mut self, arg: &Export) {
before!(self, export, arg);
self.veryl_token(&arg.export_token);
after!(self, export, arg);
}
fn f32(&mut self, arg: &F32) {
before!(self, f32, arg);
self.veryl_token(&arg.f32_token);
after!(self, f32, arg);
}
fn f64(&mut self, arg: &F64) {
before!(self, f64, arg);
self.veryl_token(&arg.f64_token);
after!(self, f64, arg);
}
fn r#for(&mut self, arg: &For) {
before!(self, r#for, arg);
self.veryl_token(&arg.for_token);
after!(self, r#for, arg);
}
fn function(&mut self, arg: &Function) {
before!(self, function, arg);
self.veryl_token(&arg.function_token);
after!(self, function, arg);
}
fn i32(&mut self, arg: &I32) {
before!(self, i32, arg);
self.veryl_token(&arg.i32_token);
after!(self, i32, arg);
}
fn i64(&mut self, arg: &I64) {
before!(self, i64, arg);
self.veryl_token(&arg.i64_token);
after!(self, i64, arg);
}
fn r#if(&mut self, arg: &If) {
before!(self, r#if, arg);
self.veryl_token(&arg.if_token);
after!(self, r#if, arg);
}
fn if_reset(&mut self, arg: &IfReset) {
before!(self, if_reset, arg);
self.veryl_token(&arg.if_reset_token);
after!(self, if_reset, arg);
}
fn import(&mut self, arg: &Import) {
before!(self, import, arg);
self.veryl_token(&arg.import_token);
after!(self, import, arg);
}
fn r#in(&mut self, arg: &In) {
before!(self, r#in, arg);
self.veryl_token(&arg.in_token);
after!(self, r#in, arg);
}
fn inout(&mut self, arg: &Inout) {
before!(self, inout, arg);
self.veryl_token(&arg.inout_token);
after!(self, inout, arg);
}
fn input(&mut self, arg: &Input) {
before!(self, input, arg);
self.veryl_token(&arg.input_token);
after!(self, input, arg);
}
fn inst(&mut self, arg: &Inst) {
before!(self, inst, arg);
self.veryl_token(&arg.inst_token);
after!(self, inst, arg);
}
fn interface(&mut self, arg: &Interface) {
before!(self, interface, arg);
self.veryl_token(&arg.interface_token);
after!(self, interface, arg);
}
fn localparam(&mut self, arg: &Localparam) {
before!(self, localparam, arg);
self.veryl_token(&arg.localparam_token);
after!(self, localparam, arg);
}
fn logic(&mut self, arg: &Logic) {
before!(self, logic, arg);
self.veryl_token(&arg.logic_token);
after!(self, logic, arg);
}
fn modport(&mut self, arg: &Modport) {
before!(self, modport, arg);
self.veryl_token(&arg.modport_token);
after!(self, modport, arg);
}
fn module(&mut self, arg: &Module) {
before!(self, module, arg);
self.veryl_token(&arg.module_token);
after!(self, module, arg);
}
fn negedge(&mut self, arg: &Negedge) {
before!(self, negedge, arg);
self.veryl_token(&arg.negedge_token);
after!(self, negedge, arg);
}
fn output(&mut self, arg: &Output) {
before!(self, output, arg);
self.veryl_token(&arg.output_token);
after!(self, output, arg);
}
fn package(&mut self, arg: &Package) {
before!(self, package, arg);
self.veryl_token(&arg.package_token);
after!(self, package, arg);
}
fn parameter(&mut self, arg: &Parameter) {
before!(self, parameter, arg);
self.veryl_token(&arg.parameter_token);
after!(self, parameter, arg);
}
fn posedge(&mut self, arg: &Posedge) {
before!(self, posedge, arg);
self.veryl_token(&arg.posedge_token);
after!(self, posedge, arg);
}
fn r#ref(&mut self, arg: &Ref) {
before!(self, r#ref, arg);
self.veryl_token(&arg.ref_token);
after!(self, r#ref, arg);
}
fn repeat(&mut self, arg: &Repeat) {
before!(self, repeat, arg);
self.veryl_token(&arg.repeat_token);
after!(self, repeat, arg);
}
fn r#return(&mut self, arg: &Return) {
before!(self, r#return, arg);
self.veryl_token(&arg.return_token);
after!(self, r#return, arg);
}
fn signed(&mut self, arg: &Signed) {
before!(self, signed, arg);
self.veryl_token(&arg.signed_token);
after!(self, signed, arg);
}
fn step(&mut self, arg: &Step) {
before!(self, step, arg);
self.veryl_token(&arg.step_token);
after!(self, step, arg);
}
fn strin(&mut self, arg: &Strin) {
before!(self, strin, arg);
self.veryl_token(&arg.string_token);
after!(self, strin, arg);
}
fn r#struct(&mut self, arg: &Struct) {
before!(self, r#struct, arg);
self.veryl_token(&arg.struct_token);
after!(self, r#struct, arg);
}
fn sync_high(&mut self, arg: &SyncHigh) {
before!(self, sync_high, arg);
self.veryl_token(&arg.sync_high_token);
after!(self, sync_high, arg);
}
fn sync_low(&mut self, arg: &SyncLow) {
before!(self, sync_low, arg);
self.veryl_token(&arg.sync_low_token);
after!(self, sync_low, arg);
}
fn tri(&mut self, arg: &Tri) {
before!(self, tri, arg);
self.veryl_token(&arg.tri_token);
after!(self, tri, arg);
}
fn r#type(&mut self, arg: &Type) {
before!(self, r#type, arg);
self.veryl_token(&arg.type_token);
after!(self, r#type, arg);
}
fn u32(&mut self, arg: &U32) {
before!(self, u32, arg);
self.veryl_token(&arg.u32_token);
after!(self, u32, arg);
}
fn u64(&mut self, arg: &U64) {
before!(self, u64, arg);
self.veryl_token(&arg.u64_token);
after!(self, u64, arg);
}
fn var(&mut self, arg: &Var) {
before!(self, var, arg);
self.veryl_token(&arg.var_token);
after!(self, var, arg);
}
fn identifier(&mut self, arg: &Identifier) {
before!(self, identifier, arg);
self.veryl_token(&arg.identifier_token);
after!(self, identifier, arg);
}
fn number(&mut self, arg: &Number) {
before!(self, number, arg);
match arg {
Number::IntegralNumber(x) => self.integral_number(&x.integral_number),
Number::RealNumber(x) => self.real_number(&x.real_number),
};
after!(self, number, arg);
}
fn integral_number(&mut self, arg: &IntegralNumber) {
before!(self, integral_number, arg);
match arg {
IntegralNumber::Based(x) => self.based(&x.based),
IntegralNumber::BaseLess(x) => self.base_less(&x.base_less),
IntegralNumber::AllBit(x) => self.all_bit(&x.all_bit),
};
after!(self, integral_number, arg);
}
fn real_number(&mut self, arg: &RealNumber) {
before!(self, real_number, arg);
match arg {
RealNumber::FixedPoint(x) => self.fixed_point(&x.fixed_point),
RealNumber::Exponent(x) => self.exponent(&x.exponent),
};
after!(self, real_number, arg);
}
fn hierarchical_identifier(&mut self, arg: &HierarchicalIdentifier) {
before!(self, hierarchical_identifier, arg);
self.identifier(&arg.identifier);
for x in &arg.hierarchical_identifier_list {
self.range(&x.range);
}
for x in &arg.hierarchical_identifier_list0 {
self.dot(&x.dot);
self.identifier(&x.identifier);
for x in &x.hierarchical_identifier_list0_list {
self.range(&x.range);
}
}
after!(self, hierarchical_identifier, arg);
}
fn scoped_identifier(&mut self, arg: &ScopedIdentifier) {
before!(self, scoped_identifier, arg);
self.identifier(&arg.identifier);
for x in &arg.scoped_identifier_list {
self.colon_colon(&x.colon_colon);
self.identifier(&x.identifier);
}
after!(self, scoped_identifier, arg);
}
fn expression_identifier(&mut self, arg: &ExpressionIdentifier) {
before!(self, expression_identifier, arg);
if let Some(ref x) = arg.expression_identifier_opt {
self.dollar(&x.dollar);
}
self.identifier(&arg.identifier);
match &*arg.expression_identifier_group {
ExpressionIdentifierGroup::ColonColonIdentifierExpressionIdentifierGroupList(x) => {
self.colon_colon(&x.colon_colon);
self.identifier(&x.identifier);
for x in &x.expression_identifier_group_list {
self.colon_colon(&x.colon_colon);
self.identifier(&x.identifier);
}
}
ExpressionIdentifierGroup::ExpressionIdentifierGroupList0ExpressionIdentifierGroupList1(x) => {
for x in &x.expression_identifier_group_list0 {
self.range(&x.range);
}
for x in &x.expression_identifier_group_list1 {
self.dot(&x.dot);
self.identifier(&x.identifier);
for x in &x.expression_identifier_group_list1_list {
self.range(&x.range);
}
}
}
}
after!(self, expression_identifier, arg);
}
fn expression(&mut self, arg: &Expression) {
before!(self, expression, arg);
self.expression01(&arg.expression01);
for x in &arg.expression_list {
self.operator01(&x.operator01);
self.expression01(&x.expression01);
}
after!(self, expression, arg);
}
fn expression01(&mut self, arg: &Expression01) {
before!(self, expression01, arg);
self.expression02(&arg.expression02);
for x in &arg.expression01_list {
self.operator02(&x.operator02);
self.expression02(&x.expression02);
}
after!(self, expression01, arg);
}
fn expression02(&mut self, arg: &Expression02) {
before!(self, expression02, arg);
self.expression03(&arg.expression03);
for x in &arg.expression02_list {
self.operator03(&x.operator03);
self.expression03(&x.expression03);
}
after!(self, expression02, arg);
}
fn expression03(&mut self, arg: &Expression03) {
before!(self, expression03, arg);
self.expression04(&arg.expression04);
for x in &arg.expression03_list {
self.operator04(&x.operator04);
self.expression04(&x.expression04);
}
after!(self, expression03, arg);
}
fn expression04(&mut self, arg: &Expression04) {
before!(self, expression04, arg);
self.expression05(&arg.expression05);
for x in &arg.expression04_list {
self.operator05(&x.operator05);
self.expression05(&x.expression05);
}
after!(self, expression04, arg);
}
fn expression05(&mut self, arg: &Expression05) {
before!(self, expression05, arg);
self.expression06(&arg.expression06);
for x in &arg.expression05_list {
self.operator06(&x.operator06);
self.expression06(&x.expression06);
}
after!(self, expression05, arg);
}
fn expression06(&mut self, arg: &Expression06) {
before!(self, expression06, arg);
self.expression07(&arg.expression07);
for x in &arg.expression06_list {
self.operator07(&x.operator07);
self.expression07(&x.expression07);
}
after!(self, expression06, arg);
}
fn expression07(&mut self, arg: &Expression07) {
before!(self, expression07, arg);
self.expression08(&arg.expression08);
for x in &arg.expression07_list {
self.operator08(&x.operator08);
self.expression08(&x.expression08);
}
after!(self, expression07, arg);
}
fn expression08(&mut self, arg: &Expression08) {
before!(self, expression08, arg);
self.expression09(&arg.expression09);
for x in &arg.expression08_list {
self.operator09(&x.operator09);
self.expression09(&x.expression09);
}
after!(self, expression08, arg);
}
fn expression09(&mut self, arg: &Expression09) {
before!(self, expression09, arg);
self.expression10(&arg.expression10);
for x in &arg.expression09_list {
match &*x.expression09_list_group {
Expression09ListGroup::Operator10(x) => self.operator10(&x.operator10),
Expression09ListGroup::Star(x) => self.star(&x.star),
}
self.expression10(&x.expression10);
}
after!(self, expression09, arg);
}
fn expression10(&mut self, arg: &Expression10) {
before!(self, expression10, arg);
self.expression11(&arg.expression11);
for x in &arg.expression10_list {
self.operator11(&x.operator11);
self.expression11(&x.expression11);
}
after!(self, expression10, arg);
}
fn expression11(&mut self, arg: &Expression11) {
before!(self, expression11, arg);
self.expression12(&arg.expression12);
for x in &arg.expression11_list {
self.r#as(&x.r#as);
self.scoped_identifier(&x.scoped_identifier);
}
after!(self, expression11, arg);
}
fn expression12(&mut self, arg: &Expression12) {
before!(self, expression12, arg);
for x in &arg.expression12_list {
match &*x.expression12_list_group {
Expression12ListGroup::UnaryOperator(x) => self.unary_operator(&x.unary_operator),
Expression12ListGroup::Operator03(x) => self.operator03(&x.operator03),
Expression12ListGroup::Operator04(x) => self.operator04(&x.operator04),
Expression12ListGroup::Operator05(x) => self.operator05(&x.operator05),
Expression12ListGroup::Operator09(x) => self.operator09(&x.operator09),
}
}
self.factor(&arg.factor);
after!(self, expression12, arg);
}
fn factor(&mut self, arg: &Factor) {
before!(self, factor, arg);
match arg {
Factor::Number(x) => self.number(&x.number),
Factor::ExpressionIdentifierFactorOpt(x) => {
self.expression_identifier(&x.expression_identifier);
if let Some(ref x) = x.factor_opt {
self.function_call(&x.function_call);
}
}
Factor::LParenExpressionRParen(x) => {
self.l_paren(&x.l_paren);
self.expression(&x.expression);
self.r_paren(&x.r_paren);
}
Factor::LBraceConcatenationListRBrace(x) => {
self.l_brace(&x.l_brace);
self.concatenation_list(&x.concatenation_list);
self.r_brace(&x.r_brace);
}
Factor::IfExpression(x) => {
self.if_expression(&x.if_expression);
}
Factor::CaseExpression(x) => {
self.case_expression(&x.case_expression);
}
Factor::StringLiteral(x) => {
self.string_literal(&x.string_literal);
}
}
after!(self, factor, arg);
}
fn function_call(&mut self, arg: &FunctionCall) {
before!(self, function_call, arg);
self.l_paren(&arg.l_paren);
if let Some(ref x) = arg.function_call_opt {
self.argument_list(&x.argument_list);
}
self.r_paren(&arg.r_paren);
after!(self, function_call, arg);
}
fn argument_list(&mut self, arg: &ArgumentList) {
before!(self, argument_list, arg);
self.argument_item(&arg.argument_item);
for x in &arg.argument_list_list {
self.comma(&x.comma);
self.argument_item(&x.argument_item);
}
if let Some(ref x) = arg.argument_list_opt {
self.comma(&x.comma);
}
after!(self, argument_list, arg);
}
fn argument_item(&mut self, arg: &ArgumentItem) {
before!(self, argument_item, arg);
self.expression(&arg.expression);
after!(self, argument_item, arg);
}
fn concatenation_list(&mut self, arg: &ConcatenationList) {
before!(self, concatenation_list, arg);
self.concatenation_item(&arg.concatenation_item);
for x in &arg.concatenation_list_list {
self.comma(&x.comma);
self.concatenation_item(&x.concatenation_item);
}
if let Some(ref x) = arg.concatenation_list_opt {
self.comma(&x.comma);
}
after!(self, concatenation_list, arg);
}
fn concatenation_item(&mut self, arg: &ConcatenationItem) {
before!(self, concatenation_item, arg);
self.expression(&arg.expression);
if let Some(ref x) = arg.concatenation_item_opt {
self.repeat(&x.repeat);
self.expression(&x.expression);
}
after!(self, concatenation_item, arg);
}
fn if_expression(&mut self, arg: &IfExpression) {
before!(self, if_expression, arg);
self.r#if(&arg.r#if);
self.expression(&arg.expression);
self.l_brace(&arg.l_brace);
self.expression(&arg.expression0);
self.r_brace(&arg.r_brace);
for x in &arg.if_expression_list {
self.r#else(&x.r#else);
self.r#if(&x.r#if);
self.expression(&x.expression);
self.l_brace(&x.l_brace);
self.expression(&x.expression0);
self.r_brace(&x.r_brace);
}
self.r#else(&arg.r#else);
self.l_brace(&arg.l_brace0);
self.expression(&arg.expression1);
self.r_brace(&arg.r_brace0);
after!(self, if_expression, arg);
}
fn case_expression(&mut self, arg: &CaseExpression) {
before!(self, case_expression, arg);
self.case(&arg.case);
self.expression(&arg.expression);
self.l_brace(&arg.l_brace);
self.expression(&arg.expression0);
self.colon(&arg.colon);
self.expression(&arg.expression1);
self.comma(&arg.comma);
for x in &arg.case_expression_list {
self.expression(&x.expression);
self.colon(&x.colon);
self.expression(&x.expression0);
self.comma(&x.comma);
}
self.defaul(&arg.defaul);
self.colon(&arg.colon0);
self.expression(&arg.expression2);
if let Some(ref x) = arg.case_expression_opt {
self.comma(&x.comma);
}
self.r_brace(&arg.r_brace);
after!(self, case_expression, arg);
}
fn type_expression(&mut self, arg: &TypeExpression) {
before!(self, type_expression, arg);
match arg {
TypeExpression::ScalarType(x) => self.scalar_type(&x.scalar_type),
TypeExpression::TypeLParenExpressionRParen(x) => {
self.r#type(&x.r#type);
self.l_paren(&x.l_paren);
self.expression(&x.expression);
self.r_paren(&x.r_paren);
}
}
after!(self, type_expression, arg);
}
fn range(&mut self, arg: &Range) {
before!(self, range, arg);
self.l_bracket(&arg.l_bracket);
self.expression(&arg.expression);
if let Some(ref x) = arg.range_opt {
self.range_operator(&x.range_operator);
self.expression(&x.expression);
}
self.r_bracket(&arg.r_bracket);
after!(self, range, arg);
}
fn range_operator(&mut self, arg: &RangeOperator) {
before!(self, range_operator, arg);
match arg {
RangeOperator::Colon(x) => self.colon(&x.colon),
RangeOperator::PlusColon(x) => self.plus_colon(&x.plus_colon),
RangeOperator::MinusColon(x) => self.minus_colon(&x.minus_colon),
RangeOperator::Step(x) => self.step(&x.step),
}
after!(self, range_operator, arg);
}
fn width(&mut self, arg: &Width) {
before!(self, width, arg);
self.l_angle(&arg.l_angle);
self.expression(&arg.expression);
for x in &arg.width_list {
self.comma(&x.comma);
self.expression(&x.expression);
}
self.r_angle(&arg.r_angle);
after!(self, width, arg);
}
fn array(&mut self, arg: &Array) {
before!(self, array, arg);
self.l_bracket(&arg.l_bracket);
self.expression(&arg.expression);
for x in &arg.array_list {
self.comma(&x.comma);
self.expression(&x.expression);
}
self.r_bracket(&arg.r_bracket);
after!(self, array, arg);
}
fn fixed_type(&mut self, arg: &FixedType) {
before!(self, fixed_type, arg);
match arg {
FixedType::U32(x) => self.u32(&x.u32),
FixedType::U64(x) => self.u64(&x.u64),
FixedType::I32(x) => self.i32(&x.i32),
FixedType::I64(x) => self.i64(&x.i64),
FixedType::F32(x) => self.f32(&x.f32),
FixedType::F64(x) => self.f64(&x.f64),
FixedType::Strin(x) => self.strin(&x.strin),
};
after!(self, fixed_type, arg);
}
fn variable_type(&mut self, arg: &VariableType) {
before!(self, variable_type, arg);
match &*arg.variable_type_group {
VariableTypeGroup::Logic(x) => self.logic(&x.logic),
VariableTypeGroup::Bit(x) => self.bit(&x.bit),
VariableTypeGroup::ScopedIdentifier(x) => self.scoped_identifier(&x.scoped_identifier),
};
if let Some(ref x) = arg.variable_type_opt {
self.width(&x.width);
}
after!(self, variable_type, arg);
}
fn type_modifier(&mut self, arg: &TypeModifier) {
before!(self, type_modifier, arg);
match arg {
TypeModifier::Tri(x) => self.tri(&x.tri),
TypeModifier::Signed(x) => self.signed(&x.signed),
}
after!(self, type_modifier, arg);
}
fn scalar_type(&mut self, arg: &ScalarType) {
before!(self, scalar_type, arg);
for x in &arg.scalar_type_list {
self.type_modifier(&x.type_modifier);
}
match &*arg.scalar_type_group {
ScalarTypeGroup::VariableType(x) => self.variable_type(&x.variable_type),
ScalarTypeGroup::FixedType(x) => self.fixed_type(&x.fixed_type),
}
after!(self, scalar_type, arg);
}
fn array_type(&mut self, arg: &ArrayType) {
before!(self, array_type, arg);
self.scalar_type(&arg.scalar_type);
if let Some(ref x) = arg.array_type_opt {
self.array(&x.array);
}
after!(self, array_type, arg);
}
fn statement(&mut self, arg: &Statement) {
before!(self, statement, arg);
match arg {
Statement::AssignmentStatement(x) => self.assignment_statement(&x.assignment_statement),
Statement::IfStatement(x) => self.if_statement(&x.if_statement),
Statement::IfResetStatement(x) => self.if_reset_statement(&x.if_reset_statement),
Statement::ReturnStatement(x) => self.return_statement(&x.return_statement),
Statement::ForStatement(x) => self.for_statement(&x.for_statement),
Statement::CaseStatement(x) => self.case_statement(&x.case_statement),
};
after!(self, statement, arg);
}
fn assignment_statement(&mut self, arg: &AssignmentStatement) {
before!(self, assignment_statement, arg);
self.hierarchical_identifier(&arg.hierarchical_identifier);
match &*arg.assignment_statement_group {
AssignmentStatementGroup::Equ(x) => self.equ(&x.equ),
AssignmentStatementGroup::AssignmentOperator(x) => {
self.assignment_operator(&x.assignment_operator)
}
}
self.expression(&arg.expression);
self.semicolon(&arg.semicolon);
after!(self, assignment_statement, arg);
}
fn if_statement(&mut self, arg: &IfStatement) {
before!(self, if_statement, arg);
self.r#if(&arg.r#if);
self.expression(&arg.expression);
self.l_brace(&arg.l_brace);
for x in &arg.if_statement_list {
self.statement(&x.statement);
}
self.r_brace(&arg.r_brace);
for x in &arg.if_statement_list0 {
self.r#else(&x.r#else);
self.r#if(&x.r#if);
self.expression(&x.expression);
self.l_brace(&x.l_brace);
for x in &x.if_statement_list0_list {
self.statement(&x.statement);
}
self.r_brace(&x.r_brace);
}
if let Some(ref x) = arg.if_statement_opt {
self.r#else(&x.r#else);
self.l_brace(&x.l_brace);
for x in &x.if_statement_opt_list {
self.statement(&x.statement);
}
self.r_brace(&x.r_brace);
}
after!(self, if_statement, arg);
}
fn if_reset_statement(&mut self, arg: &IfResetStatement) {
before!(self, if_reset_statement, arg);
self.if_reset(&arg.if_reset);
self.l_brace(&arg.l_brace);
for x in &arg.if_reset_statement_list {
self.statement(&x.statement);
}
self.r_brace(&arg.r_brace);
for x in &arg.if_reset_statement_list0 {
self.r#else(&x.r#else);
self.r#if(&x.r#if);
self.expression(&x.expression);
self.l_brace(&x.l_brace);
for x in &x.if_reset_statement_list0_list {
self.statement(&x.statement);
}
self.r_brace(&x.r_brace);
}
if let Some(ref x) = arg.if_reset_statement_opt {
self.r#else(&x.r#else);
self.l_brace(&x.l_brace);
for x in &x.if_reset_statement_opt_list {
self.statement(&x.statement);
}
self.r_brace(&x.r_brace);
}
after!(self, if_reset_statement, arg);
}
fn return_statement(&mut self, arg: &ReturnStatement) {
before!(self, return_statement, arg);
self.r#return(&arg.r#return);
self.expression(&arg.expression);
self.semicolon(&arg.semicolon);
after!(self, return_statement, arg);
}
fn for_statement(&mut self, arg: &ForStatement) {
before!(self, for_statement, arg);
self.r#for(&arg.r#for);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
self.scalar_type(&arg.scalar_type);
self.r#in(&arg.r#in);
self.expression(&arg.expression);
self.dot_dot(&arg.dot_dot);
self.expression(&arg.expression0);
if let Some(ref x) = arg.for_statement_opt {
self.step(&x.step);
self.assignment_operator(&x.assignment_operator);
self.expression(&x.expression);
}
self.l_brace(&arg.l_brace);
for x in &arg.for_statement_list {
self.statement(&x.statement);
}
self.r_brace(&arg.r_brace);
after!(self, for_statement, arg);
}
fn case_statement(&mut self, arg: &CaseStatement) {
before!(self, case_statement, arg);
self.case(&arg.case);
self.expression(&arg.expression);
self.l_brace(&arg.l_brace);
for x in &arg.case_statement_list {
self.case_item(&x.case_item);
}
self.r_brace(&arg.r_brace);
after!(self, case_statement, arg);
}
fn case_item(&mut self, arg: &CaseItem) {
before!(self, case_item, arg);
match &*arg.case_item_group {
CaseItemGroup::Expression(x) => self.expression(&x.expression),
CaseItemGroup::Defaul(x) => self.defaul(&x.defaul),
}
self.colon(&arg.colon);
match &*arg.case_item_group0 {
CaseItemGroup0::Statement(x) => self.statement(&x.statement),
CaseItemGroup0::LBraceCaseItemGroup0ListRBrace(x) => {
self.l_brace(&x.l_brace);
for x in &x.case_item_group0_list {
self.statement(&x.statement);
}
self.r_brace(&x.r_brace);
}
}
after!(self, case_item, arg);
}
fn attribute(&mut self, arg: &Attribute) {
before!(self, attribute, arg);
self.hash(&arg.hash);
self.l_bracket(&arg.l_bracket);
self.identifier(&arg.identifier);
if let Some(ref x) = arg.attribute_opt {
self.l_paren(&x.l_paren);
self.attribute_list(&x.attribute_list);
self.r_paren(&x.r_paren);
}
self.r_bracket(&arg.r_bracket);
after!(self, attribute, arg);
}
fn attribute_list(&mut self, arg: &AttributeList) {
before!(self, attribute_list, arg);
self.attribute_item(&arg.attribute_item);
for x in &arg.attribute_list_list {
self.comma(&x.comma);
self.attribute_item(&x.attribute_item);
}
if let Some(ref x) = arg.attribute_list_opt {
self.comma(&x.comma);
}
after!(self, attribute_list, arg);
}
fn attribute_item(&mut self, arg: &AttributeItem) {
before!(self, attribute_item, arg);
match arg {
AttributeItem::Identifier(x) => self.identifier(&x.identifier),
AttributeItem::StringLiteral(x) => self.string_literal(&x.string_literal),
}
after!(self, attribute_item, arg);
}
fn var_declaration(&mut self, arg: &VarDeclaration) {
before!(self, var_declaration, arg);
self.var(&arg.var);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
self.array_type(&arg.array_type);
if let Some(ref x) = arg.var_declaration_opt {
self.equ(&x.equ);
self.expression(&x.expression);
}
self.semicolon(&arg.semicolon);
after!(self, var_declaration, arg);
}
fn localparam_declaration(&mut self, arg: &LocalparamDeclaration) {
before!(self, localparam_declaration, arg);
self.localparam(&arg.localparam);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
match &*arg.localparam_declaration_group {
LocalparamDeclarationGroup::ArrayTypeEquExpression(x) => {
self.array_type(&x.array_type);
self.equ(&x.equ);
self.expression(&x.expression);
}
LocalparamDeclarationGroup::TypeEquTypeExpression(x) => {
self.r#type(&x.r#type);
self.equ(&x.equ);
self.type_expression(&x.type_expression);
}
}
self.semicolon(&arg.semicolon);
after!(self, localparam_declaration, arg);
}
fn always_ff_declaration(&mut self, arg: &AlwaysFfDeclaration) {
before!(self, always_ff_declaration, arg);
self.always_ff(&arg.always_ff);
self.l_paren(&arg.l_paren);
self.always_ff_clock(&arg.always_ff_clock);
if let Some(ref x) = arg.always_ff_declaration_opt {
self.comma(&x.comma);
self.always_ff_reset(&x.always_ff_reset);
}
self.r_paren(&arg.r_paren);
self.l_brace(&arg.l_brace);
for x in &arg.always_ff_declaration_list {
self.statement(&x.statement);
}
self.r_brace(&arg.r_brace);
after!(self, always_ff_declaration, arg);
}
fn always_ff_clock(&mut self, arg: &AlwaysFfClock) {
before!(self, always_ff_clock, arg);
if let Some(ref x) = arg.always_ff_clock_opt {
match &*x.always_ff_clock_opt_group {
AlwaysFfClockOptGroup::Posedge(x) => self.posedge(&x.posedge),
AlwaysFfClockOptGroup::Negedge(x) => self.negedge(&x.negedge),
}
}
self.hierarchical_identifier(&arg.hierarchical_identifier);
after!(self, always_ff_clock, arg);
}
fn always_ff_reset(&mut self, arg: &AlwaysFfReset) {
before!(self, always_ff_reset, arg);
if let Some(ref x) = arg.always_ff_reset_opt {
match &*x.always_ff_reset_opt_group {
AlwaysFfResetOptGroup::AsyncLow(x) => self.async_low(&x.async_low),
AlwaysFfResetOptGroup::AsyncHigh(x) => self.async_high(&x.async_high),
AlwaysFfResetOptGroup::SyncLow(x) => self.sync_low(&x.sync_low),
AlwaysFfResetOptGroup::SyncHigh(x) => self.sync_high(&x.sync_high),
}
}
self.hierarchical_identifier(&arg.hierarchical_identifier);
after!(self, always_ff_reset, arg);
}
fn always_comb_declaration(&mut self, arg: &AlwaysCombDeclaration) {
before!(self, always_comb_declaration, arg);
self.always_comb(&arg.always_comb);
self.l_brace(&arg.l_brace);
for x in &arg.always_comb_declaration_list {
self.statement(&x.statement);
}
self.r_brace(&arg.r_brace);
after!(self, always_comb_declaration, arg);
}
fn assign_declaration(&mut self, arg: &AssignDeclaration) {
before!(self, assign_declaration, arg);
self.assign(&arg.assign);
self.hierarchical_identifier(&arg.hierarchical_identifier);
self.equ(&arg.equ);
self.expression(&arg.expression);
self.semicolon(&arg.semicolon);
after!(self, assign_declaration, arg);
}
fn modport_declaration(&mut self, arg: &ModportDeclaration) {
before!(self, modport_declaration, arg);
self.modport(&arg.modport);
self.identifier(&arg.identifier);
self.l_brace(&arg.l_brace);
self.modport_list(&arg.modport_list);
self.r_brace(&arg.r_brace);
after!(self, modport_declaration, arg);
}
fn modport_list(&mut self, arg: &ModportList) {
before!(self, modport_list, arg);
self.modport_group(&arg.modport_group);
for x in &arg.modport_list_list {
self.comma(&x.comma);
self.modport_group(&x.modport_group);
}
if let Some(ref x) = arg.modport_list_opt {
self.comma(&x.comma);
}
after!(self, modport_list, arg);
}
fn modport_group(&mut self, arg: &ModportGroup) {
before!(self, modport_group, arg);
if let Some(ref x) = arg.modport_group_opt {
self.attribute(&x.attribute);
}
match &*arg.modport_group_group {
ModportGroupGroup::LBraceModportListRBrace(x) => {
self.l_brace(&x.l_brace);
self.modport_list(&x.modport_list);
self.r_brace(&x.r_brace);
}
ModportGroupGroup::ModportItem(x) => self.modport_item(&x.modport_item),
}
after!(self, modport_group, arg);
}
fn modport_item(&mut self, arg: &ModportItem) {
before!(self, modport_item, arg);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
self.direction(&arg.direction);
after!(self, modport_item, arg);
}
fn enum_declaration(&mut self, arg: &EnumDeclaration) {
before!(self, enum_declaration, arg);
self.r#enum(&arg.r#enum);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
self.scalar_type(&arg.scalar_type);
self.l_brace(&arg.l_brace);
self.enum_list(&arg.enum_list);
self.r_brace(&arg.r_brace);
after!(self, enum_declaration, arg);
}
fn enum_list(&mut self, arg: &EnumList) {
before!(self, enum_list, arg);
self.enum_group(&arg.enum_group);
for x in &arg.enum_list_list {
self.comma(&x.comma);
self.enum_group(&x.enum_group);
}
if let Some(ref x) = arg.enum_list_opt {
self.comma(&x.comma);
}
after!(self, enum_list, arg);
}
fn enum_group(&mut self, arg: &EnumGroup) {
before!(self, enum_group, arg);
if let Some(ref x) = arg.enum_group_opt {
self.attribute(&x.attribute);
}
match &*arg.enum_group_group {
EnumGroupGroup::LBraceEnumListRBrace(x) => {
self.l_brace(&x.l_brace);
self.enum_list(&x.enum_list);
self.r_brace(&x.r_brace);
}
EnumGroupGroup::EnumItem(x) => self.enum_item(&x.enum_item),
}
after!(self, enum_group, arg);
}
fn enum_item(&mut self, arg: &EnumItem) {
before!(self, enum_item, arg);
self.identifier(&arg.identifier);
if let Some(ref x) = arg.enum_item_opt {
self.equ(&x.equ);
self.expression(&x.expression);
}
after!(self, enum_item, arg);
}
fn struct_declaration(&mut self, arg: &StructDeclaration) {
before!(self, struct_declaration, arg);
self.r#struct(&arg.r#struct);
self.identifier(&arg.identifier);
self.l_brace(&arg.l_brace);
self.struct_list(&arg.struct_list);
self.r_brace(&arg.r_brace);
after!(self, struct_declaration, arg);
}
fn struct_list(&mut self, arg: &StructList) {
before!(self, struct_list, arg);
self.struct_group(&arg.struct_group);
for x in &arg.struct_list_list {
self.comma(&x.comma);
self.struct_group(&x.struct_group);
}
if let Some(ref x) = arg.struct_list_opt {
self.comma(&x.comma);
}
after!(self, struct_list, arg);
}
fn struct_group(&mut self, arg: &StructGroup) {
before!(self, struct_group, arg);
if let Some(ref x) = arg.struct_group_opt {
self.attribute(&x.attribute);
}
match &*arg.struct_group_group {
StructGroupGroup::LBraceStructListRBrace(x) => {
self.l_brace(&x.l_brace);
self.struct_list(&x.struct_list);
self.r_brace(&x.r_brace);
}
StructGroupGroup::StructItem(x) => self.struct_item(&x.struct_item),
}
after!(self, struct_group, arg);
}
fn struct_item(&mut self, arg: &StructItem) {
before!(self, struct_item, arg);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
self.scalar_type(&arg.scalar_type);
after!(self, struct_item, arg);
}
fn inst_declaration(&mut self, arg: &InstDeclaration) {
before!(self, inst_declaration, arg);
self.inst(&arg.inst);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
self.scoped_identifier(&arg.scoped_identifier);
if let Some(ref x) = arg.inst_declaration_opt {
self.array(&x.array);
}
if let Some(ref x) = arg.inst_declaration_opt0 {
self.inst_parameter(&x.inst_parameter);
}
if let Some(ref x) = arg.inst_declaration_opt1 {
self.l_paren(&x.l_paren);
if let Some(ref x) = x.inst_declaration_opt2 {
self.inst_port_list(&x.inst_port_list);
}
self.r_paren(&x.r_paren);
}
self.semicolon(&arg.semicolon);
after!(self, inst_declaration, arg);
}
fn inst_parameter(&mut self, arg: &InstParameter) {
before!(self, inst_parameter, arg);
self.hash(&arg.hash);
self.l_paren(&arg.l_paren);
if let Some(ref x) = arg.inst_parameter_opt {
self.inst_parameter_list(&x.inst_parameter_list);
}
self.r_paren(&arg.r_paren);
after!(self, inst_parameter, arg);
}
fn inst_parameter_list(&mut self, arg: &InstParameterList) {
before!(self, inst_parameter_list, arg);
self.inst_parameter_group(&arg.inst_parameter_group);
for x in &arg.inst_parameter_list_list {
self.comma(&x.comma);
self.inst_parameter_group(&x.inst_parameter_group);
}
if let Some(ref x) = arg.inst_parameter_list_opt {
self.comma(&x.comma);
}
after!(self, inst_parameter_list, arg);
}
fn inst_parameter_group(&mut self, arg: &InstParameterGroup) {
before!(self, inst_parameter_group, arg);
if let Some(ref x) = arg.inst_parameter_group_opt {
self.attribute(&x.attribute);
}
match &*arg.inst_parameter_group_group {
InstParameterGroupGroup::LBraceInstParameterListRBrace(x) => {
self.l_brace(&x.l_brace);
self.inst_parameter_list(&x.inst_parameter_list);
self.r_brace(&x.r_brace);
}
InstParameterGroupGroup::InstParameterItem(x) => {
self.inst_parameter_item(&x.inst_parameter_item)
}
}
after!(self, inst_parameter_group, arg);
}
fn inst_parameter_item(&mut self, arg: &InstParameterItem) {
before!(self, inst_parameter_item, arg);
self.identifier(&arg.identifier);
if let Some(ref x) = arg.inst_parameter_item_opt {
self.colon(&x.colon);
self.expression(&x.expression);
}
after!(self, inst_parameter_item, arg);
}
fn inst_port_list(&mut self, arg: &InstPortList) {
before!(self, inst_port_list, arg);
self.inst_port_group(&arg.inst_port_group);
for x in &arg.inst_port_list_list {
self.comma(&x.comma);
self.inst_port_group(&x.inst_port_group);
}
if let Some(ref x) = arg.inst_port_list_opt {
self.comma(&x.comma);
}
after!(self, inst_port_list, arg);
}
fn inst_port_group(&mut self, arg: &InstPortGroup) {
before!(self, inst_port_group, arg);
if let Some(ref x) = arg.inst_port_group_opt {
self.attribute(&x.attribute);
}
match &*arg.inst_port_group_group {
InstPortGroupGroup::LBraceInstPortListRBrace(x) => {
self.l_brace(&x.l_brace);
self.inst_port_list(&x.inst_port_list);
self.r_brace(&x.r_brace);
}
InstPortGroupGroup::InstPortItem(x) => self.inst_port_item(&x.inst_port_item),
}
after!(self, inst_port_group, arg);
}
fn inst_port_item(&mut self, arg: &InstPortItem) {
before!(self, inst_port_item, arg);
self.identifier(&arg.identifier);
if let Some(ref x) = arg.inst_port_item_opt {
self.colon(&x.colon);
self.expression(&x.expression);
}
after!(self, inst_port_item, arg);
}
fn with_parameter(&mut self, arg: &WithParameter) {
before!(self, with_parameter, arg);
self.hash(&arg.hash);
self.l_paren(&arg.l_paren);
if let Some(ref x) = arg.with_parameter_opt {
self.with_parameter_list(&x.with_parameter_list);
}
self.r_paren(&arg.r_paren);
after!(self, with_parameter, arg);
}
fn with_parameter_list(&mut self, arg: &WithParameterList) {
before!(self, with_parameter_list, arg);
self.with_parameter_group(&arg.with_parameter_group);
for x in &arg.with_parameter_list_list {
self.comma(&x.comma);
self.with_parameter_group(&x.with_parameter_group);
}
if let Some(ref x) = arg.with_parameter_list_opt {
self.comma(&x.comma);
}
after!(self, with_parameter_list, arg);
}
fn with_parameter_group(&mut self, arg: &WithParameterGroup) {
before!(self, with_parameter_group, arg);
if let Some(ref x) = arg.with_parameter_group_opt {
self.attribute(&x.attribute);
}
match &*arg.with_parameter_group_group {
WithParameterGroupGroup::LBraceWithParameterListRBrace(x) => {
self.l_brace(&x.l_brace);
self.with_parameter_list(&x.with_parameter_list);
self.r_brace(&x.r_brace);
}
WithParameterGroupGroup::WithParameterItem(x) => {
self.with_parameter_item(&x.with_parameter_item)
}
}
after!(self, with_parameter_group, arg);
}
fn with_parameter_item(&mut self, arg: &WithParameterItem) {
before!(self, with_parameter_item, arg);
match &*arg.with_parameter_item_group {
WithParameterItemGroup::Parameter(x) => self.parameter(&x.parameter),
WithParameterItemGroup::Localparam(x) => self.localparam(&x.localparam),
};
self.identifier(&arg.identifier);
self.colon(&arg.colon);
match &*arg.with_parameter_item_group0 {
WithParameterItemGroup0::ArrayTypeEquExpression(x) => {
self.array_type(&x.array_type);
self.equ(&x.equ);
self.expression(&x.expression);
}
WithParameterItemGroup0::TypeEquTypeExpression(x) => {
self.r#type(&x.r#type);
self.equ(&x.equ);
self.type_expression(&x.type_expression);
}
}
after!(self, with_parameter_item, arg);
}
fn port_declaration(&mut self, arg: &PortDeclaration) {
before!(self, port_declaration, arg);
self.l_paren(&arg.l_paren);
if let Some(ref x) = arg.port_declaration_opt {
self.port_declaration_list(&x.port_declaration_list);
}
self.r_paren(&arg.r_paren);
after!(self, port_declaration, arg);
}
fn port_declaration_list(&mut self, arg: &PortDeclarationList) {
before!(self, port_declaration_list, arg);
self.port_declaration_group(&arg.port_declaration_group);
for x in &arg.port_declaration_list_list {
self.comma(&x.comma);
self.port_declaration_group(&x.port_declaration_group);
}
if let Some(ref x) = arg.port_declaration_list_opt {
self.comma(&x.comma);
}
after!(self, port_declaration_list, arg);
}
fn port_declaration_group(&mut self, arg: &PortDeclarationGroup) {
before!(self, port_declaration_group, arg);
if let Some(ref x) = arg.port_declaration_group_opt {
self.attribute(&x.attribute);
}
match &*arg.port_declaration_group_group {
PortDeclarationGroupGroup::LBracePortDeclarationListRBrace(x) => {
self.l_brace(&x.l_brace);
self.port_declaration_list(&x.port_declaration_list);
self.r_brace(&x.r_brace);
}
PortDeclarationGroupGroup::PortDeclarationItem(x) => {
self.port_declaration_item(&x.port_declaration_item)
}
}
after!(self, port_declaration_group, arg);
}
fn port_declaration_item(&mut self, arg: &PortDeclarationItem) {
before!(self, port_declaration_item, arg);
self.identifier(&arg.identifier);
self.colon(&arg.colon);
match &*arg.port_declaration_item_group {
PortDeclarationItemGroup::DirectionArrayType(x) => {
self.direction(&x.direction);
self.array_type(&x.array_type);
}
PortDeclarationItemGroup::InterfacePortDeclarationItemOpt(x) => {
self.interface(&x.interface);
if let Some(ref x) = x.port_declaration_item_opt {
self.array(&x.array);
}
}
}
after!(self, port_declaration_item, arg);
}
fn direction(&mut self, arg: &Direction) {
before!(self, direction, arg);
match arg {
Direction::Input(x) => self.input(&x.input),
Direction::Output(x) => self.output(&x.output),
Direction::Inout(x) => self.inout(&x.inout),
Direction::Ref(x) => self.r#ref(&x.r#ref),
Direction::Modport(x) => self.modport(&x.modport),
};
after!(self, direction, arg);
}
fn function_declaration(&mut self, arg: &FunctionDeclaration) {
before!(self, function_declaration, arg);
self.function(&arg.function);
self.identifier(&arg.identifier);
if let Some(ref x) = arg.function_declaration_opt {
self.with_parameter(&x.with_parameter);
}
if let Some(ref x) = arg.function_declaration_opt0 {
self.port_declaration(&x.port_declaration);
}
self.minus_g_t(&arg.minus_g_t);
self.scalar_type(&arg.scalar_type);
self.l_brace(&arg.l_brace);
for x in &arg.function_declaration_list {
self.function_item(&x.function_item);
}
self.r_brace(&arg.r_brace);
after!(self, function_declaration, arg);
}
fn function_item(&mut self, arg: &FunctionItem) {
before!(self, function_item, arg);
match arg {
FunctionItem::VarDeclaration(x) => self.var_declaration(&x.var_declaration),
FunctionItem::Statement(x) => self.statement(&x.statement),
};
after!(self, function_item, arg);
}
fn import_declaration(&mut self, arg: &ImportDeclaration) {
before!(self, import_declaration, arg);
self.import(&arg.import);
self.identifier(&arg.identifier);
self.colon_colon(&arg.colon_colon);
match &*arg.import_declaration_group {
ImportDeclarationGroup::Identifier(x) => self.identifier(&x.identifier),
ImportDeclarationGroup::Star(x) => self.star(&x.star),
}
self.semicolon(&arg.semicolon);
after!(self, import_declaration, arg);
}
fn export_declaration(&mut self, arg: &ExportDeclaration) {
before!(self, export_declaration, arg);
self.export(&arg.export);
match &*arg.export_declaration_group {
ExportDeclarationGroup::Identifier(x) => self.identifier(&x.identifier),
ExportDeclarationGroup::Star(x) => self.star(&x.star),
}
self.colon_colon(&arg.colon_colon);
match &*arg.export_declaration_group0 {
ExportDeclarationGroup0::Identifier(x) => self.identifier(&x.identifier),
ExportDeclarationGroup0::Star(x) => self.star(&x.star),
}
self.semicolon(&arg.semicolon);
after!(self, export_declaration, arg);
}
fn module_declaration(&mut self, arg: &ModuleDeclaration) {
before!(self, module_declaration, arg);
self.module(&arg.module);
self.identifier(&arg.identifier);
if let Some(ref x) = arg.module_declaration_opt {
self.with_parameter(&x.with_parameter);
}
if let Some(ref x) = arg.module_declaration_opt0 {
self.port_declaration(&x.port_declaration);
}
self.l_brace(&arg.l_brace);
for x in &arg.module_declaration_list {
self.module_group(&x.module_group);
}
self.r_brace(&arg.r_brace);
after!(self, module_declaration, arg);
}
fn module_if_declaration(&mut self, arg: &ModuleIfDeclaration) {
before!(self, module_if_declaration, arg);
self.r#if(&arg.r#if);
self.expression(&arg.expression);
self.module_named_block(&arg.module_named_block);
for x in &arg.module_if_declaration_list {
self.r#else(&x.r#else);
self.r#if(&x.r#if);
self.expression(&x.expression);
self.module_optional_named_block(&x.module_optional_named_block);
}
if let Some(ref x) = arg.module_if_declaration_opt {
self.r#else(&x.r#else);
self.module_optional_named_block(&x.module_optional_named_block);
}
after!(self, module_if_declaration, arg);
}
fn module_for_declaration(&mut self, arg: &ModuleForDeclaration) {
before!(self, module_for_declaration, arg);
self.r#for(&arg.r#for);
self.identifier(&arg.identifier);
self.r#in(&arg.r#in);
self.expression(&arg.expression);
self.dot_dot(&arg.dot_dot);
self.expression(&arg.expression0);
if let Some(ref x) = arg.module_for_declaration_opt {
self.step(&x.step);
self.assignment_operator(&x.assignment_operator);
self.expression(&x.expression);
}
self.module_named_block(&arg.module_named_block);
after!(self, module_for_declaration, arg);
}
fn module_named_block(&mut self, arg: &ModuleNamedBlock) {
before!(self, module_named_block, arg);
self.colon(&arg.colon);
self.identifier(&arg.identifier);
self.l_brace(&arg.l_brace);
for x in &arg.module_named_block_list {
self.module_group(&x.module_group);
}
self.r_brace(&arg.r_brace);
after!(self, module_named_block, arg);
}
fn module_optional_named_block(&mut self, arg: &ModuleOptionalNamedBlock) {
before!(self, module_optional_named_block, arg);
if let Some(ref x) = arg.module_optional_named_block_opt {
self.colon(&x.colon);
self.identifier(&x.identifier);
}
self.l_brace(&arg.l_brace);
for x in &arg.module_optional_named_block_list {
self.module_group(&x.module_group);
}
self.r_brace(&arg.r_brace);
after!(self, module_optional_named_block, arg);
}
fn module_group(&mut self, arg: &ModuleGroup) {
before!(self, module_group, arg);
if let Some(ref x) = arg.module_group_opt {
self.attribute(&x.attribute);
}
match &*arg.module_group_group {
ModuleGroupGroup::LBraceModuleGroupGroupListRBrace(x) => {
self.l_brace(&x.l_brace);
for x in &x.module_group_group_list {
self.module_group(&x.module_group);
}
self.r_brace(&x.r_brace);
}
ModuleGroupGroup::ModuleItem(x) => self.module_item(&x.module_item),
}
after!(self, module_group, arg);
}
fn module_item(&mut self, arg: &ModuleItem) {
before!(self, module_item, arg);
match arg {
ModuleItem::VarDeclaration(x) => self.var_declaration(&x.var_declaration),
ModuleItem::InstDeclaration(x) => self.inst_declaration(&x.inst_declaration),
ModuleItem::LocalparamDeclaration(x) => {
self.localparam_declaration(&x.localparam_declaration)
}
ModuleItem::AlwaysFfDeclaration(x) => {
self.always_ff_declaration(&x.always_ff_declaration)
}
ModuleItem::AlwaysCombDeclaration(x) => {
self.always_comb_declaration(&x.always_comb_declaration)
}
ModuleItem::AssignDeclaration(x) => self.assign_declaration(&x.assign_declaration),
ModuleItem::FunctionDeclaration(x) => {
self.function_declaration(&x.function_declaration)
}
ModuleItem::ModuleIfDeclaration(x) => {
self.module_if_declaration(&x.module_if_declaration)
}
ModuleItem::ModuleForDeclaration(x) => {
self.module_for_declaration(&x.module_for_declaration)
}
ModuleItem::EnumDeclaration(x) => self.enum_declaration(&x.enum_declaration),
ModuleItem::StructDeclaration(x) => self.struct_declaration(&x.struct_declaration),
ModuleItem::ModuleNamedBlock(x) => self.module_named_block(&x.module_named_block),
ModuleItem::ImportDeclaration(x) => self.import_declaration(&x.import_declaration),
};
after!(self, module_item, arg);
}
fn interface_declaration(&mut self, arg: &InterfaceDeclaration) {
before!(self, interface_declaration, arg);
self.interface(&arg.interface);
self.identifier(&arg.identifier);
if let Some(ref x) = arg.interface_declaration_opt {
self.with_parameter(&x.with_parameter);
}
self.l_brace(&arg.l_brace);
for x in &arg.interface_declaration_list {
self.interface_group(&x.interface_group);
}
self.r_brace(&arg.r_brace);
after!(self, interface_declaration, arg);
}
fn interface_if_declaration(&mut self, arg: &InterfaceIfDeclaration) {
before!(self, interface_if_declaration, arg);
self.r#if(&arg.r#if);
self.expression(&arg.expression);
self.interface_named_block(&arg.interface_named_block);
for x in &arg.interface_if_declaration_list {
self.r#else(&x.r#else);
self.r#if(&x.r#if);
self.expression(&x.expression);
self.interface_optional_named_block(&x.interface_optional_named_block);
}
if let Some(ref x) = arg.interface_if_declaration_opt {
self.r#else(&x.r#else);
self.interface_optional_named_block(&x.interface_optional_named_block);
}
after!(self, interface_if_declaration, arg);
}
fn interface_for_declaration(&mut self, arg: &InterfaceForDeclaration) {
before!(self, interface_for_declaration, arg);
self.r#for(&arg.r#for);
self.identifier(&arg.identifier);
self.r#in(&arg.r#in);
self.expression(&arg.expression);
self.dot_dot(&arg.dot_dot);
self.expression(&arg.expression0);
if let Some(ref x) = arg.interface_for_declaration_opt {
self.step(&x.step);
self.assignment_operator(&x.assignment_operator);
self.expression(&x.expression);
}
self.interface_named_block(&arg.interface_named_block);
after!(self, interface_for_declaration, arg);
}
fn interface_named_block(&mut self, arg: &InterfaceNamedBlock) {
before!(self, interface_named_block, arg);
self.colon(&arg.colon);
self.identifier(&arg.identifier);
self.l_brace(&arg.l_brace);
for x in &arg.interface_named_block_list {
self.interface_group(&x.interface_group);
}
self.r_brace(&arg.r_brace);
after!(self, interface_named_block, arg);
}
fn interface_optional_named_block(&mut self, arg: &InterfaceOptionalNamedBlock) {
before!(self, interface_optional_named_block, arg);
if let Some(ref x) = arg.interface_optional_named_block_opt {
self.colon(&x.colon);
self.identifier(&x.identifier);
}
self.l_brace(&arg.l_brace);
for x in &arg.interface_optional_named_block_list {
self.interface_group(&x.interface_group);
}
self.r_brace(&arg.r_brace);
after!(self, interface_optional_named_block, arg);
}
fn interface_group(&mut self, arg: &InterfaceGroup) {
before!(self, interface_group, arg);
if let Some(ref x) = arg.interface_group_opt {
self.attribute(&x.attribute);
}
match &*arg.interface_group_group {
InterfaceGroupGroup::LBraceInterfaceGroupGroupListRBrace(x) => {
self.l_brace(&x.l_brace);
for x in &x.interface_group_group_list {
self.interface_group(&x.interface_group);
}
self.r_brace(&x.r_brace);
}
InterfaceGroupGroup::InterfaceItem(x) => self.interface_item(&x.interface_item),
}
after!(self, interface_group, arg);
}
fn interface_item(&mut self, arg: &InterfaceItem) {
before!(self, interface_item, arg);
match arg {
InterfaceItem::VarDeclaration(x) => self.var_declaration(&x.var_declaration),
InterfaceItem::LocalparamDeclaration(x) => {
self.localparam_declaration(&x.localparam_declaration)
}
InterfaceItem::ModportDeclaration(x) => {
self.modport_declaration(&x.modport_declaration)
}
InterfaceItem::InterfaceIfDeclaration(x) => {
self.interface_if_declaration(&x.interface_if_declaration)
}
InterfaceItem::InterfaceForDeclaration(x) => {
self.interface_for_declaration(&x.interface_for_declaration)
}
InterfaceItem::EnumDeclaration(x) => self.enum_declaration(&x.enum_declaration),
InterfaceItem::StructDeclaration(x) => self.struct_declaration(&x.struct_declaration),
InterfaceItem::InterfaceNamedBlock(x) => {
self.interface_named_block(&x.interface_named_block)
}
InterfaceItem::FunctionDeclaration(x) => {
self.function_declaration(&x.function_declaration)
}
InterfaceItem::ImportDeclaration(x) => self.import_declaration(&x.import_declaration),
};
after!(self, interface_item, arg);
}
fn package_declaration(&mut self, arg: &PackageDeclaration) {
before!(self, package_declaration, arg);
self.package(&arg.package);
self.identifier(&arg.identifier);
self.l_brace(&arg.l_brace);
for x in &arg.package_declaration_list {
self.package_group(&x.package_group);
}
self.r_brace(&arg.r_brace);
after!(self, package_declaration, arg);
}
fn package_group(&mut self, arg: &PackageGroup) {
before!(self, package_group, arg);
if let Some(ref x) = arg.package_group_opt {
self.attribute(&x.attribute);
}
match &*arg.package_group_group {
PackageGroupGroup::LBracePackageGroupGroupListRBrace(x) => {
self.l_brace(&x.l_brace);
for x in &x.package_group_group_list {
self.package_group(&x.package_group);
}
self.r_brace(&x.r_brace);
}
PackageGroupGroup::PackageItem(x) => self.package_item(&x.package_item),
}
after!(self, package_group, arg);
}
fn package_item(&mut self, arg: &PackageItem) {
before!(self, package_item, arg);
match arg {
PackageItem::VarDeclaration(x) => self.var_declaration(&x.var_declaration),
PackageItem::LocalparamDeclaration(x) => {
self.localparam_declaration(&x.localparam_declaration)
}
PackageItem::EnumDeclaration(x) => self.enum_declaration(&x.enum_declaration),
PackageItem::StructDeclaration(x) => self.struct_declaration(&x.struct_declaration),
PackageItem::FunctionDeclaration(x) => {
self.function_declaration(&x.function_declaration)
}
PackageItem::ImportDeclaration(x) => self.import_declaration(&x.import_declaration),
PackageItem::ExportDeclaration(x) => self.export_declaration(&x.export_declaration),
}
after!(self, package_item, arg);
}
fn description_group(&mut self, arg: &DescriptionGroup) {
before!(self, description_group, arg);
if let Some(ref x) = arg.description_group_opt {
self.attribute(&x.attribute);
}
match &*arg.description_group_group {
DescriptionGroupGroup::LBraceDescriptionGroupGroupListRBrace(x) => {
self.l_brace(&x.l_brace);
for x in &x.description_group_group_list {
self.description_group(&x.description_group);
}
self.r_brace(&x.r_brace);
}
DescriptionGroupGroup::DescriptionItem(x) => self.description_item(&x.description_item),
}
after!(self, description_group, arg);
}
fn description_item(&mut self, arg: &DescriptionItem) {
before!(self, description_item, arg);
match arg {
DescriptionItem::ModuleDeclaration(x) => self.module_declaration(&x.module_declaration),
DescriptionItem::InterfaceDeclaration(x) => {
self.interface_declaration(&x.interface_declaration)
}
DescriptionItem::PackageDeclaration(x) => {
self.package_declaration(&x.package_declaration)
}
DescriptionItem::ImportDeclaration(x) => self.import_declaration(&x.import_declaration),
};
after!(self, description_item, arg);
}
fn veryl(&mut self, arg: &Veryl) {
before!(self, veryl, arg);
self.start(&arg.start);
for x in &arg.veryl_list {
self.description_group(&x.description_group);
}
after!(self, veryl, arg);
}
fn get_handlers(&mut self) -> Option<Vec<&mut dyn Handler>> {
None
}
}
#[derive(Default)]
pub enum HandlerPoint {
#[default]
Before,
After,
}
pub trait Handler: VerylGrammarTrait {
fn set_point(&mut self, p: HandlerPoint);
}