File Coverage

blib/lib/RPerl/Operation/Expression/Operator/Named/Chomp.pm
Criterion Covered Total %
statement 34 48 70.8
branch 2 8 25.0
condition n/a
subroutine 9 11 81.8
pod n/a
total 45 67 67.1


line stmt bran cond sub pod time code
1             # [[[ DOCUMENTATION ]]]
2             # http://perldoc.perl.org/functions/chomp.html
3             # SUPPORTED: chomp VARIABLE
4             # NOT SUPPORTED: chomp( LIST )
5             # NOT SUPPORTED: chomp
6              
7             # [[[ HEADER ]]]
8             package RPerl::Operation::Expression::Operator::Named::Chomp;
9 4     4   24 use strict;
  4         10  
  4         99  
10 4     4   18 use warnings;
  4         10  
  4         95  
11 4     4   22 use RPerl::AfterSubclass;
  4         10  
  4         501  
12             our $VERSION = 0.002_000;
13              
14             # [[[ OO INHERITANCE ]]]
15 4     4   25 use parent qw(RPerl::Operation::Expression::Operator::Named);
  4         10  
  4         19  
16 4     4   231 use RPerl::Operation::Expression::Operator::Named;
  4         7  
  4         103  
17              
18             # [[[ CRITICS ]]]
19             ## no critic qw(ProhibitUselessNoCritic ProhibitMagicNumbers RequireCheckedSyscalls) # USER DEFAULT 1: allow numeric values & print operator
20             ## no critic qw(RequireInterpolationOfMetachars) # USER DEFAULT 2: allow single-quoted control characters & sigils
21             ## no critic qw(ProhibitConstantPragma ProhibitMagicNumbers) # USER DEFAULT 3: allow constants
22              
23             # [[[ CONSTANTS ]]]
24 4     4   20 use constant NAME => my string $TYPED_NAME = 'chomp';
  4         10  
  4         230  
25             # 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'
26             # or ERROR ECOPARP00 'Unexpected Token: ,'; short-circuited second by ERROR ECOGEASRP14 on Operator_95 & OperatorVoid_134 multiple-argument productions below;
27             # can't figure out how to create test which gets past ECOPAPL03 & ECOPARP00 to trigger ECOGEASRP14
28 4     4   23 use constant ARGUMENTS_MIN => my integer $TYPED_ARGUMENTS_MIN = 1;
  4         9  
  4         188  
29 4     4   23 use constant ARGUMENTS_MAX => my integer $TYPED_ARGUMENTS_MAX = 1;
  4         11  
  4         1526  
30              
31             # [[[ OO PROPERTIES ]]]
32             our hashref $properties = {};
33              
34             # [[[ SUBROUTINES & OO METHODS ]]]
35              
36             sub ast_to_rperl__generate {
37 7     7   16 { my string_hashref::method $RETURN_TYPE };
  7         20  
38 7         24 ( my object $self, my object $operator_named, my string_hashref $modes)
39             = @ARG;
40 7         22 my string_hashref $rperl_source_group = { PMC => q{} };
41              
42             # RPerl::diag( 'in Operator::Named::Chomp->ast_to_rperl__generate(), received $self = ' . "\n" . RPerl::Parser::rperl_ast__dump($self) . "\n" );
43             # RPerl::diag( 'in Operator::Named::Chomp->ast_to_rperl__generate(), received $operator_named = ' . "\n" . RPerl::Parser::rperl_ast__dump($operator_named) . "\n" );
44              
45 7         24 my string $operator_named_class = ref $operator_named;
46 7 50       39 if ( $operator_named_class eq 'Operation_90' ) { # Operation -> OP01_NAMED_SCOLON
    50          
    0          
    0          
47             die RPerl::Parser::rperl_rule__replace(
48             'ERROR ECOGEASRP16, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Named operator '
49 0         0 . $operator_named->{children}->[0]
50             . ' requires exactly one argument, dying' )
51             . "\n";
52             }
53             elsif ( $operator_named_class eq 'Operator_94' ) { # Operator -> OP01_NAMED SubExpression
54 7         26 $rperl_source_group->{PMC} .= $operator_named->{children}->[0] . q{ };
55             my string_hashref $rperl_source_subgroup
56 7         141 = $operator_named->{children}->[1]
57             ->ast_to_rperl__generate( $modes, $self );
58 7         133 RPerl::Generator::source_group_append( $rperl_source_group,
59             $rperl_source_subgroup );
60             }
61             elsif ( $operator_named_class eq 'Operator_95' ) { # Operator -> LPAREN OP01_NAMED ListElement OP21_LIST_COMMA ListElements ')'
62             die RPerl::Parser::rperl_rule__replace(
63             'ERROR ECOGEASRP14, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Named operator '
64 0         0 . $operator_named->{children}->[1]
65             . ' does not accept multiple arguments, dying' )
66             . "\n";
67             }
68             elsif ( $operator_named_class eq 'OperatorVoid_134' ) { # OperatorVoid -> OP01_NAMED ListElement OP21_LIST_COMMA ListElements ';'
69             die RPerl::Parser::rperl_rule__replace(
70             'ERROR ECOGEASRP14, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Named operator '
71 0         0 . $operator_named->{children}->[0]
72             . ' does not accept multiple arguments, dying' )
73             . "\n";
74             }
75             else {
76 0         0 die RPerl::Parser::rperl_rule__replace(
77             'ERROR ECOGEASRP00, CODE GENERATOR, ABSTRACT SYNTAX TO RPERL: Grammar rule '
78             . ($operator_named_class)
79             . ' found where Operation_90, Operator_94, Operator_95, or OperatorVoid_134 expected, dying'
80             ) . "\n";
81             }
82 7         26 return $rperl_source_group;
83             }
84              
85             sub ast_to_cpp__generate__CPPOPS_PERLTYPES {
86 0     0     { my string_hashref::method $RETURN_TYPE };
  0            
87 0           ( my object $self, my string_hashref $modes) = @ARG;
88 0           my string_hashref $cpp_source_group
89             = { CPP =>
90             q{// <<< RP::O::E::O::N::Ch __DUMMY_SOURCE_CODE CPPOPS_PERLTYPES >>>}
91             . "\n" };
92              
93             #...
94 0           return $cpp_source_group;
95             }
96              
97             sub ast_to_cpp__generate__CPPOPS_CPPTYPES {
98 0     0     { my string_hashref::method $RETURN_TYPE };
  0            
99 0           ( my object $self, my string_hashref $modes) = @ARG;
100 0           my string_hashref $cpp_source_group
101             = { CPP =>
102             q{// <<< RP::O::E::O::N::Ch __DUMMY_SOURCE_CODE CPPOPS_CPPTYPES >>>}
103             . "\n" };
104              
105             #...
106 0           return $cpp_source_group;
107             }
108              
109             1; # end of class