File Coverage

blib/lib/Pg/SQL/PrettyPrinter/Node/CaseExpr.pm
Criterion Covered Total %
statement 73 73 100.0
branch 9 12 75.0
condition n/a
subroutine 17 17 100.0
pod 3 3 100.0
total 102 105 97.1


line stmt bran cond sub pod time code
1             package Pg::SQL::PrettyPrinter::Node::CaseExpr;
2              
3             # UTF8 boilerplace, per http://stackoverflow.com/questions/6162484/why-does-modern-perl-avoid-utf-8-by-default/
4 3     3   4138 use v5.26;
  3         11  
5 3     3   16 use strict;
  3         6  
  3         84  
6 3     3   12 use warnings;
  3         5  
  3         170  
7 3     3   14 use warnings qw( FATAL utf8 );
  3         5  
  3         148  
8 3     3   14 use utf8;
  3         6  
  3         20  
9 3     3   82 use open qw( :std :utf8 );
  3         6  
  3         16  
10 3     3   441 use Unicode::Normalize qw( NFC );
  3         6  
  3         170  
11 3     3   14 use Unicode::Collate;
  3         27  
  3         86  
12 3     3   56 use Encode qw( decode );
  3         7  
  3         432  
13              
14             if ( grep /\P{ASCII}/ => @ARGV ) {
15             @ARGV = map { decode( 'UTF-8', $_ ) } @ARGV;
16             }
17              
18             # If there is __DATA__,then uncomment next line:
19             # binmode( DATA, ':encoding(UTF-8)' );
20             # UTF8 boilerplace, per http://stackoverflow.com/questions/6162484/why-does-modern-perl-avoid-utf-8-by-default/
21              
22             # Useful common code
23 3     3   17 use autodie;
  3         7  
  3         22  
24 3     3   13277 use Carp qw( carp croak confess cluck );
  3         7  
  3         260  
25 3     3   19 use English qw( -no_match_vars );
  3         6  
  3         24  
26 3     3   1216 use Data::Dumper qw( Dumper );
  3         5  
  3         671  
27              
28             # give a full stack dump on any untrapped exceptions
29             local $SIG{ __DIE__ } = sub {
30             confess "Uncaught exception: @_" unless $^S;
31             };
32              
33             # now promote run-time warnings into stackdumped exceptions
34             # *unless* we're in an try block, in which
35             # case just generate a clucking stackdump instead
36             local $SIG{ __WARN__ } = sub {
37             if ( $^S ) { cluck "Trapped warning: @_" }
38             else { confess "Deadly warning: @_" }
39             };
40              
41             # Useful common code
42              
43 3     3   21 use parent qw( Pg::SQL::PrettyPrinter::Node );
  3         7  
  3         22  
44              
45             sub new {
46 2     2 1 31 my $class = shift;
47 2         8 my $self = $class->SUPER::new( @_ );
48 2         4 bless $self, $class;
49              
50 2         6 $self->objectify( 'args' );
51              
52 2 100       5 if ( exists $self->{ 'arg' } ) {
53 1         4 $self->objectify( 'arg' );
54             }
55 2 50       6 if ( exists $self->{ 'defresult' } ) {
56 2         6 $self->objectify( 'defresult' );
57             }
58 2         4 return $self;
59             }
60              
61             sub as_text {
62 2     2 1 3 my $self = shift;
63 2         4 my @elements = ();
64 2         4 push @elements, 'CASE';
65 2 100       9 push @elements, $self->{ 'arg' }->as_text if exists $self->{ 'arg' };
66 2         4 push @elements, map { $_->as_text } @{ $self->{ 'args' } };
  4         8  
  2         4  
67 2 50       4 if ( exists $self->{ 'defresult' } ) {
68 2         4 push @elements, 'ELSE';
69 2         3 push @elements, $self->{ 'defresult' }->as_text;
70             }
71 2         4 push @elements, 'END';
72 2         6 return join( ' ', @elements );
73             }
74              
75             sub pretty_print {
76 2     2 1 3 my $self = shift;
77 2         2 my @elements = ();
78 2         3 push @elements, 'CASE';
79 2 100       7 $elements[ -1 ] .= ' ' . $self->{ 'arg' }->pretty_print if exists $self->{ 'arg' };
80 2         2 push @elements, map { ' ' . $_->pretty_print } @{ $self->{ 'args' } };
  4         11  
  2         5  
81 2 50       7 if ( exists $self->{ 'defresult' } ) {
82 2         3 push @elements, ' ELSE ' . $self->{ 'defresult' }->pretty_print;
83             }
84 2         3 push @elements, 'END';
85 2         7 return join( "\n", @elements );
86             }
87              
88             1;