File Coverage

blib/lib/RPerl/Operation/Expression/Operator/Named/Atan2.pm
Criterion Covered Total %
statement 24 24 100.0
branch n/a
condition n/a
subroutine 8 8 100.0
pod n/a
total 32 32 100.0


line stmt bran cond sub pod time code
1             # [[[ DOCUMENTATION ]]]
2             # http://perldoc.perl.org/functions/atan2.html
3             # SUPPORTED: atan2 Y,X
4              
5             # [[[ HEADER ]]]
6             package RPerl::Operation::Expression::Operator::Named::Atan2;
7 5     5   30 use strict;
  5         13  
  5         168  
8 5     5   28 use warnings;
  5         12  
  5         113  
9 5     5   26 use RPerl::AfterSubclass;
  5         12  
  5         725  
10             our $VERSION = 0.001_000;
11              
12             # [[[ OO INHERITANCE ]]]
13 5     5   35 use parent qw(RPerl::Operation::Expression::Operator::Named);
  5         15  
  5         31  
14 5     5   299 use RPerl::Operation::Expression::Operator::Named;
  5         18  
  5         137  
15              
16             # [[[ CRITICS ]]]
17             ## no critic qw(ProhibitUselessNoCritic ProhibitMagicNumbers RequireCheckedSyscalls) # USER DEFAULT 1: allow numeric values & print operator
18             ## no critic qw(RequireInterpolationOfMetachars) # USER DEFAULT 2: allow single-quoted control characters & sigils
19             ## no critic qw(ProhibitConstantPragma ProhibitMagicNumbers) # USER DEFAULT 3: allow constants
20              
21             # [[[ CONSTANTS ]]]
22 5     5   24 use constant NAME => my string $TYPED_NAME = 'atan2';
  5         11  
  5         293  
23              
24             # DEV NOTE: with min & max args of 1, compile-time args length checking short-circuited first by Parse Phase 0 ERROR ECOPAPL03 'Useless use of FOO in void context'
25             # or ERROR ECOPARP00 'Unexpected Token: ,'; short-circuited second by ERROR ECOGEASRP13 on Operator_84 & OperatorVoid_122 multiple-argument productions below;
26             # can't figure out how to create test which gets past ECOPAPL03 & ECOPARP00 to trigger ECOGEASRP13
27 5     5   31 use constant ARGUMENTS_MIN => my integer $TYPED_ARGUMENTS_MIN = 2;
  5         13  
  5         257  
28 5     5   30 use constant ARGUMENTS_MAX => my integer $TYPED_ARGUMENTS_MAX = 2;
  5         11  
  5         2949  
29              
30             # [[[ OO PROPERTIES ]]]
31             our hashref $properties = {};
32              
33             # [[[ OO METHODS & SUBROUTINES ]]]
34              
35             our string_hashref::method $ast_to_rperl__generate = sub {
36             ( my object $self, my object $operator_named, my string_hashref $modes) = @_;
37             my string_hashref $rperl_source_group = { PMC => q{} };
38              
39             # RPerl::diag( 'in Operator::Named::Atan2->ast_to_rperl__generate(), received $self = ' . "\n" . RPerl::Parser::rperl_ast__dump($self) . "\n" );
40             # RPerl::diag( 'in Operator::Named::Atan2->ast_to_rperl__generate(), received $operator_named = ' . "\n" . RPerl::Parser::rperl_ast__dump($operator_named) . "\n" );
41              
42             my string $operator_named_class = ref $operator_named;
43             if ( $operator_named_class eq 'Operation_79' ) { # Operation -> OP01_NAMED_SCOLON
44             die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASRP15, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: named operator '
45             . $operator_named->{children}->[0]
46             . ' requires exactly two arguments, dying' )
47             . "\n";
48             }
49             elsif ( $operator_named_class eq 'Operator_83' ) { # Operator -> OP01_NAMED SubExpression
50             die RPerl::Parser::rperl_rule__replace(
51             'ERROR ECOGEASRP18, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Named operator '
52             . $operator_named->{children}->[0]
53             . 'requires excatly two arguments, dying' )
54             . "\n";
55             }
56             elsif ( $operator_named_class eq 'Operator_84' ) { # Operator -> LPAREN OP01_NAMED ListElement OP21_LIST_COMMA ListElements ')'
57             my string $left_paren = $operator_named->{children}->[0];
58             my string $operator_name = $operator_named->{children}->[1];
59             my object $argument0 = $operator_named->{children}->[2];
60             my string $list_comma = $operator_named->{children}->[3];
61             my object $arguments = $operator_named->{children}->[4];
62             my string $right_paren = $operator_named->{children}->[5];
63              
64             $rperl_source_group->{PMC} .= $left_paren . q{ } . $operator_name . q{ };
65             my string_hashref $rperl_source_subgroup = $argument0->ast_to_rperl__generate( $modes, $self );
66             RPerl::Generator::source_group_append( $rperl_source_group, $rperl_source_subgroup );
67             $rperl_source_group->{PMC} .= $list_comma . q{ };
68             $rperl_source_subgroup = $arguments->ast_to_rperl__generate( $modes, $self );
69             RPerl::Generator::source_group_append( $rperl_source_group, $rperl_source_subgroup );
70             $rperl_source_group->{PMC} .= q{ } . $right_paren;
71             }
72             elsif ( $operator_named_class eq 'OperatorVoid_122' ) { # OperatorVoid -> OP01_NAMED ListElement OP21_LIST_COMMA ListElements ';'
73             die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASRP13b, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: named operator '
74             . $operator_named->{children}->[0]
75             . ' does not accept multiple arguments, dying' )
76             . "\n";
77             }
78             else {
79             die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASRP00, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: grammar rule '
80             . ($operator_named_class)
81             . ' found where Operation_79, Operator_83, Operator_84, or OperatorVoid_122 expected, dying' )
82             . "\n";
83             }
84              
85             return $rperl_source_group;
86             };
87              
88             our string_hashref::method $ast_to_cpp__generate__CPPOPS_PERLTYPES = sub {
89             ( my object $self, my string_hashref $modes) = @_;
90             my string_hashref $cpp_source_group = { CPP => q{// <<< RP::O::E::O::N::Abs __DUMMY_SOURCE_CODE CPPOPS_PERLTYPES >>>} . "\n" };
91              
92             #...
93             return $cpp_source_group;
94             };
95              
96             our string_hashref::method $ast_to_cpp__generate__CPPOPS_CPPTYPES = sub {
97             ( my object $self, my object $operator_named, my string_hashref $modes) = @_;
98             my string_hashref $cpp_source_group = { CPP => q{} };
99              
100             # RPerl::diag( 'in Operator::Named::Atan2->ast_to_cpp__generate__CPPOPS_CPPTYPES(), received $self = ' . "\n" . RPerl::Parser::rperl_ast__dump($self) . "\n" );
101             # RPerl::diag( 'in Operator::Named::Atan2->ast_to_cpp__generate__CPPOPS_CPPTYPES(), received $operator_named = ' . "\n" . RPerl::Parser::rperl_ast__dump($operator_named) . "\n" );
102              
103             my string $operator_named_class = ref $operator_named;
104             if ( $operator_named_class eq 'Operation_79' ) { # Operation -> OP01_NAMED_SCOLON
105             die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASCP15, CODE GENERATOR, ABSTRACT SYNTAX TO C++: named operator '
106             . $operator_named->{children}->[0]
107             . ' requires exactly one argument, dying' )
108             . "\n";
109             }
110             elsif ( $operator_named_class eq 'Operator_83' ) { # Operator -> OP01_NAMED SubExpression
111             die RPerl::Parser::rperl_rule__replace(
112             'ERROR ECOGEASCP18, CODE GENERATOR, ABSTRACT SYNTAX TO C++ Named operator '
113             . $operator_named->{children}->[0]
114             . 'requires excatly two arguments, dying' )
115             . "\n";
116             }
117             elsif ( $operator_named_class eq 'Operator_84' ) { # Operator -> LPAREN OP01_NAMED ListElement OP21_LIST_COMMA ListElements ')'
118             my string $left_paren = $operator_named->{children}->[0];
119             my string $operator_name = $operator_named->{children}->[1];
120             my object $argument0 = $operator_named->{children}->[2];
121             my string $list_comma = $operator_named->{children}->[3];
122             my object $arguments = $operator_named->{children}->[4];
123             my string $right_paren = $operator_named->{children}->[5];
124              
125             $cpp_source_group->{CPP} .= $left_paren . q{ } . $operator_name . q{(};
126             my string_hashref $cpp_source_subgroup = $argument0->ast_to_cpp__generate__CPPOPS_CPPTYPES( $modes, $self );
127             RPerl::Generator::source_group_append( $cpp_source_group, $cpp_source_subgroup );
128             $cpp_source_group->{CPP} .= $list_comma . q{ };
129             $cpp_source_subgroup = $arguments->ast_to_cpp__generate__CPPOPS_CPPTYPES( $modes, $self );
130             RPerl::Generator::source_group_append( $cpp_source_group, $cpp_source_subgroup );
131             $cpp_source_group->{CPP} .= q{)} . $right_paren;
132             }
133             elsif ( $operator_named_class eq 'OperatorVoid_122' ) { # OperatorVoid -> OP01_NAMED ListElement OP21_LIST_COMMA ListElements ';'
134             die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASCP14b, CODE GENERATOR, ABSTRACT SYNTAX TO C++: named operator '
135             . $operator_named->{children}->[0]
136             . ' does not accept multiple arguments, dying' )
137             . "\n";
138             }
139             else {
140             die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASCP00, CODE GENERATOR, ABSTRACT SYNTAX TO C++: grammar rule '
141             . ($operator_named_class)
142             . ' found where Operation_79, Operator_83, Operator_84, or OperatorVoid_122 expected, dying' )
143             . "\n";
144             }
145              
146             return $cpp_source_group;
147             };
148              
149             1; # end of class