our
$VERSION
= 0.003_500;
use
constant
NAME
=>
my
string
$TYPED_NAME
=
'cos'
;
use
constant
ARGUMENTS_MIN
=>
my
integer
$TYPED_ARGUMENTS_MIN
= 1;
use
constant
ARGUMENTS_MAX
=>
my
integer
$TYPED_ARGUMENTS_MAX
= 1;
our
hashref
$properties
= {};
sub
ast_to_rperl__generate {
{
my
string_hashref::method
$RETURN_TYPE
};
(
my
object
$self
,
my
object
$operator_named
,
my
string_hashref
$modes
) =
@ARG
;
my
string_hashref
$rperl_source_group
= {
PMC
=>
q{}
};
my
string
$operator_named_class
=
ref
$operator_named
;
if
(
$operator_named_class
eq
'Operation_97'
) {
die
RPerl::Parser::rperl_rule__replace(
'ERROR ECOGEASRP016, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Named operator '
.
$operator_named
->{children}->[0]
.
' requires exactly one argument, dying'
)
.
"\n"
;
}
elsif
(
$operator_named_class
eq
'Operator_116'
) {
$rperl_source_group
->{PMC} .=
$operator_named
->{children}->[0] .
q{ }
;
my
string_hashref
$rperl_source_subgroup
=
$operator_named
->{children}->[1]->ast_to_rperl__generate(
$modes
,
$self
);
RPerl::Generator::source_group_append(
$rperl_source_group
,
$rperl_source_subgroup
);
}
elsif
(
$operator_named_class
eq
'Operator_117'
) {
die
RPerl::Parser::rperl_rule__replace(
'ERROR ECOGEASRP016, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Named operator '
.
$operator_named
->{children}->[0]
.
' requires exactly one argument, dying'
)
.
"\n"
;
}
else
{
die
RPerl::Parser::rperl_rule__replace(
'ERROR ECOGEASRP000, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Grammar rule '
. (
$operator_named_class
)
.
' found where Operation_97, Operator_116, or Operator_117 expected, dying'
)
.
"\n"
;
}
return
$rperl_source_group
;
}
sub
ast_to_cpp__generate__CPPOPS_PERLTYPES {
{
my
string_hashref::method
$RETURN_TYPE
};
(
my
object
$self
,
my
string_hashref
$modes
) =
@ARG
;
my
string_hashref
$cpp_source_group
= {
CPP
=>
q{// <<< RP::O::E::O::NU::C __DUMMY_SOURCE_CODE CPPOPS_PERLTYPES >>>}
.
"\n"
};
return
$cpp_source_group
;
}
sub
ast_to_cpp__generate__CPPOPS_CPPTYPES {
{
my
string_hashref::method
$RETURN_TYPE
};
(
my
object
$self
,
my
object
$operator_named
,
my
string_hashref
$modes
) =
@ARG
;
my
string_hashref
$cpp_source_group
= {
CPP
=>
q{}
};
my
string
$operator_named_class
=
ref
$operator_named
;
if
(
$operator_named_class
eq
'Operation_97'
) {
die
RPerl::Parser::rperl_rule__replace(
'ERROR EC0GEASCP16, CODE GENERATOR, ABSTRACT SYNTAX TO C++: Named operator '
.
q{'}
.
$operator_named
->{children}->[0] .
q{'}
.
' requires exactly one argument, dying'
)
.
"\n"
;
}
elsif
(
$operator_named_class
eq
'Operator_116'
) {
my
object
$subexpression
=
$operator_named
->{children}->[1];
my
string
$subexpression_class
=
ref
$subexpression
;
$cpp_source_group
->{CPP} .=
$operator_named
->{children}->[0];
$cpp_source_group
->{CPP} .=
'('
;
my
string_hashref
$cpp_source_subgroup
=
$operator_named
->{children}->[1]->ast_to_cpp__generate__CPPOPS_CPPTYPES(
$modes
,
$self
);
RPerl::Generator::source_group_append(
$cpp_source_group
,
$cpp_source_subgroup
);
$cpp_source_group
->{CPP} .=
')'
;
}
elsif
(
$operator_named_class
eq
'Operator_117'
) {
die
RPerl::Parser::rperl_rule__replace(
'ERROR EC0GEASCP16, CODE GENERATOR, ABSTRACT SYNTAX TO C++: Named operator '
.
$operator_named
->{children}->[0]
.
' requires exactly one argument, dying'
)
.
"\n"
;
}
else
{
die
RPerl::Parser::rperl_rule__replace(
'ERROR EC0GEASCP00, CODE GENERATOR, ABSTRACT SYNTAX TO C++: Grammar rule '
. (
$operator_named_class
)
.
' found where Operation_97, Operator_116, or Operator_117 expected, dying'
)
.
"\n"
;
}
return
$cpp_source_group
;
}
1;