File Coverage

blib/lib/RPerl/Operation/Statement/OperatorVoid/Named/Die.pm
Criterion Covered Total %
statement 59 78 75.6
branch 7 20 35.0
condition 3 11 27.2
subroutine 10 11 90.9
pod n/a
total 79 120 65.8


line stmt bran cond sub pod time code
1             # [[[ HEADER ]]]
2             package RPerl::Operation::Statement::OperatorVoid::Named::Die;
3 4     4   27 use strict;
  4         10  
  4         103  
4 4     4   19 use warnings;
  4         9  
  4         80  
5 4     4   19 use RPerl::AfterSubclass;
  4         7  
  4         525  
6             our $VERSION = 0.003_000;
7              
8             # [[[ OO INHERITANCE ]]]
9             # NEED FIX: is not a Grammar Rule so should not inherit from OperatorVoid, need create Grammar Production class
10 4     4   26 use parent qw(RPerl::Operation::Statement::OperatorVoid::Named);
  4         9  
  4         19  
11 4     4   220 use RPerl::Operation::Statement::OperatorVoid::Named;
  4         8  
  4         105  
12              
13             # [[[ CRITICS ]]]
14             ## no critic qw(ProhibitUselessNoCritic ProhibitMagicNumbers RequireCheckedSyscalls) # USER DEFAULT 1: allow numeric values & print operator
15             ## no critic qw(RequireInterpolationOfMetachars) # USER DEFAULT 2: allow single-quoted control characters & sigils
16             ## no critic qw(ProhibitConstantPragma ProhibitMagicNumbers) # USER DEFAULT 3: allow constants
17              
18             # [[[ CONSTANTS ]]]
19 4     4   19 use constant NAME => my string $TYPED_NAME = 'die';
  4         9  
  4         214  
20              
21             # DEV NOTE: ARGUMENTS_MIN of 0 can be ignored, no such thing as negative number of args!
22 4     4   22 use constant ARGUMENTS_MIN => my integer $TYPED_ARGUMENTS_MIN = 0;
  4         7  
  4         194  
23 4     4   25 use constant ARGUMENTS_MAX => my integer $TYPED_ARGUMENTS_MAX = 999;
  4         17  
  4         2359  
24              
25             # [[[ OO PROPERTIES ]]]
26             our hashref $properties = {};
27              
28             # [[[ SUBROUTINES & OO METHODS ]]]
29              
30             sub ast_to_rperl__generate {
31 23     23   52 { my string_hashref::method $RETURN_TYPE };
  23         44  
32 23         121 ( my object $self, my string_hashref $modes, my object $operator_void_named) = @ARG;
33 23         97 my string_hashref $rperl_source_group = { PMC => q{} };
34              
35             # RPerl::diag( 'in OperatorVoid::Named::Die->ast_to_rperl__generate(), received $self = ' . "\n" . RPerl::Parser::rperl_ast__dump($self) . "\n" );
36             # RPerl::diag( 'in OperatorVoid::Named::Die->ast_to_rperl__generate(), received $operator_void_named = ' . "\n" . RPerl::Parser::rperl_ast__dump($operator_void_named) . "\n" );
37              
38 23 50       148 if ( ref $operator_void_named eq 'OperatorVoid_131' ) { # OperatorVoid -> OP01_NAMED_VOID_SCOLON
    50          
39 0         0 $rperl_source_group->{PMC} .= $operator_void_named->{children}->[0]; # name semicolon
40             }
41             elsif ( ref $operator_void_named eq 'OperatorVoid_133' ) { # OperatorVoid -> OP01_NAMED_VOID ListElements ';'
42             $rperl_source_group->{PMC}
43 23         90 .= $operator_void_named->{children}->[0] . q{ }; # name
44 23         55 my object $arguments = $operator_void_named->{children}->[1];
45 23         559 my integer $argument_count = $arguments->length();
46 23 50       106 if ( $argument_count > ARGUMENTS_MAX() ) {
47 0         0 die 'ERROR ECOGEASRP03, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL:' . "\n"
48             . 'Argument count '
49             . $argument_count
50             . ' exceeds maximum argument limit '
51             . ARGUMENTS_MAX()
52             . ' for operator ' . q{'}
53             . NAME() . q{'}
54             . ', dying' . "\n";
55             }
56 23         530 my string_hashref $rperl_source_subgroup = $arguments->ast_to_rperl__generate( $modes, $self );
57 23         482 RPerl::Generator::source_group_append( $rperl_source_group, $rperl_source_subgroup );
58 23         93 $rperl_source_group->{PMC} .= $operator_void_named->{children}->[2]; # semicolon
59             }
60             else {
61 0         0 die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASRP00, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Grammar rule '
62             . ( ref $operator_void_named )
63             . ' found where OperatorVoid_131 or OperatorVoid_133 expected, dying' )
64             . "\n";
65             }
66              
67 23         74 $rperl_source_group->{PMC} .= "\n";
68 23         82 return $rperl_source_group;
69             }
70              
71             sub ast_to_cpp__generate__CPPOPS_PERLTYPES {
72 0     0   0 { my string_hashref::method $RETURN_TYPE };
  0         0  
73 0         0 ( my object $self, my string_hashref $modes, my object $operator_void_named) = @ARG;
74 0         0 my string_hashref $cpp_source_group = { CPP => q{// <<< RP::O::S::OV::N::D __DUMMY_SOURCE_CODE CPPOPS_PERLTYPES >>>} . "\n" };
75              
76             #...
77 0         0 return $cpp_source_group;
78             }
79              
80             sub ast_to_cpp__generate__CPPOPS_CPPTYPES {
81 1     1   4 { my string_hashref::method $RETURN_TYPE };
  1         4  
82 1         6 ( my object $self, my string_hashref $modes, my object $operator_void_named) = @ARG;
83 1         6 my string_hashref $cpp_source_group = { CPP => q{} };
84              
85             # RPerl::diag( 'in OperatorVoid::Named::Die->ast_to_cpp__generate__CPPOPS_CPPTYPES(), received $self = ' . "\n" . RPerl::Parser::rperl_ast__dump($self) . "\n" );
86             # RPerl::diag( 'in OperatorVoid::Named::Die->ast_to_cpp__generate__CPPOPS_CPPTYPES(), received $operator_void_named = ' . "\n" . RPerl::Parser::rperl_ast__dump($operator_void_named) . "\n" );
87              
88 1 50       9 if ( ref $operator_void_named eq 'OperatorVoid_131' ) { # OperatorVoid -> OP01_NAMED_VOID_SCOLON
    50          
89             # DEV NOTE, CORRELATION #rp102: renamed from Perl die to C++ Die to avoid error redefining Perl's embed.h die
90 0         0 $cpp_source_group->{CPP} .= ucfirst $operator_void_named->{children}->[0]; # Name semicolon
91             }
92             elsif ( ref $operator_void_named eq 'OperatorVoid_133' ) { # OperatorVoid -> OP01_NAMED_VOID ListElements ';'
93             # DEV NOTE, CORRELATION #rp102: renamed from Perl die to C++ Die to avoid error redefining Perl's embed.h die
94             # DEV NOTE, CORRELATION #rp102a: C++ cerr w/ recursive variadic template and exit() is equivalent to Perl die, DISABLED
95             # DEV NOTE, CORRELATION #rp102b: C++ cerr w/ inlined exit() is equivalent to Perl die
96 1         6 $cpp_source_group->{CPP} .= ucfirst $operator_void_named->{children}->[0]; # Name
97 1         3 $cpp_source_group->{CPP} .= q{(}; # left parentheses, CORRELATION #rp102a
98 1         4 $cpp_source_group->{CPP} .= q{ };
99 1         4 my object $arguments = $operator_void_named->{children}->[1];
100 1         24 my integer $argument_count = $arguments->length();
101 1 50       6 if ( $argument_count > ARGUMENTS_MAX() ) {
102 0         0 die 'ERROR ECOGEASCP03, CODE GENERATOR, ABSTRACT SYNTAX TO C++:' . "\n"
103             . 'Argument count ' . $argument_count . ' exceeds maximum argument limit ' . ARGUMENTS_MAX()
104             . ' for operator ' . q{'} . NAME() . q{'} . ', dying' . "\n";
105             }
106              
107             # save to stack of saved flags, when needed
108 1 50 33     6 if ((exists $modes->{_inside_die_operator}) and (defined $modes->{_inside_die_operator})) {
109 0 0 0     0 if ((not exists $modes->{_inside_die_operator_saved}) or (not defined $modes->{_inside_die_operator_saved})) {
110 0         0 $modes->{_inside_die_operator_saved} = [];
111             }
112 0         0 push @{$modes->{_inside_die_operator_saved}}, $modes->{_inside_die_operator};
  0         0  
113             }
114 1         5 $modes->{_inside_die_operator} = 1;
115              
116 1         22 my string_hashref $cpp_source_subgroup = $arguments->ast_to_cpp__generate__CPPOPS_CPPTYPES( $modes, $self );
117 1         20 RPerl::Generator::source_group_append( $cpp_source_group, $cpp_source_subgroup );
118 1         5 $cpp_source_group->{CPP} .= q{ )}; # right parentheses, CORRELATION #rp102a
119 1         5 $cpp_source_group->{CPP} .= $operator_void_named->{children}->[2]; # semicolon
120             # $cpp_source_group->{CPP} .= ' exit(1);'; # inlined exit(), CORRELATION #rp102b
121              
122             # restore from stack of saved flags, when needed
123 1         3 delete $modes->{_inside_die_operator};
124 1 0 33     7 if ((exists $modes->{_inside_die_operator_saved}) and (defined $modes->{_inside_die_operator_saved}) and (scalar $modes->{_inside_die_operator_saved})) {
      50        
125 0         0 $modes->{_inside_die_operator} = pop @{$modes->{_inside_die_operator_saved}};
  0         0  
126 0 0       0 if (not scalar $modes->{_inside_die_operator_saved}) { delete $modes->{_inside_die_operator_saved}; }
  0         0  
127             }
128             }
129             else {
130 0         0 die RPerl::Parser::rperl_rule__replace( 'ERROR ECOGEASRP00, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Grammar rule '
131             . ( ref $operator_void_named )
132             . ' found where OperatorVoid_131 or OperatorVoid_133 expected, dying' )
133             . "\n";
134             }
135              
136 1         3 $cpp_source_group->{CPP} .= "\n";
137 1         6 return $cpp_source_group;
138             }
139              
140             1; # end of class