File Coverage

blib/lib/Pg/SQL/PrettyPrinter/Node/RangeFunction.pm
Criterion Covered Total %
statement 58 61 95.0
branch 6 12 50.0
condition n/a
subroutine 16 16 100.0
pod 2 2 100.0
total 82 91 90.1


line stmt bran cond sub pod time code
1             package Pg::SQL::PrettyPrinter::Node::RangeFunction;
2              
3             # UTF8 boilerplace, per http://stackoverflow.com/questions/6162484/why-does-modern-perl-avoid-utf-8-by-default/
4 3     3   4507 use v5.26;
  3         15  
5 3     3   20 use strict;
  3         8  
  3         103  
6 3     3   14 use warnings;
  3         7  
  3         205  
7 3     3   17 use warnings qw( FATAL utf8 );
  3         6  
  3         158  
8 3     3   16 use utf8;
  3         6  
  3         24  
9 3     3   100 use open qw( :std :utf8 );
  3         20  
  3         23  
10 3     3   590 use Unicode::Normalize qw( NFC );
  3         7  
  3         248  
11 3     3   20 use Unicode::Collate;
  3         7  
  3         107  
12 3     3   15 use Encode qw( decode );
  3         7  
  3         482  
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   21 use autodie;
  3         9  
  3         26  
24 3     3   20920 use Carp qw( carp croak confess cluck );
  3         8  
  3         397  
25 3     3   29 use English qw( -no_match_vars );
  3         8  
  3         29  
26 3     3   1619 use Data::Dumper qw( Dumper );
  3         10  
  3         896  
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   28 use parent qw( Pg::SQL::PrettyPrinter::Node );
  3         9  
  3         29  
44              
45             sub new {
46 3     3 1 75 my $class = shift;
47 3         22 my $self = $class->SUPER::new( @_ );
48 3         9 bless $self, $class;
49              
50 3 50       6 croak( 'Multiple RangeFunctions not yet handled' ) if 1 != scalar @{ $self->{ 'functions' } };
  3         19  
51 3         20 $self->objectify( 'functions', [ 'alias', 'colnames' ] );
52 3 50       26 croak( 'Invalid object inside RangeFunction' ) unless $self->{ 'functions' }->[ 0 ]->isa( 'Pg::SQL::PrettyPrinter::Node::List' );
53 3 50       6 croak( 'Multiple RangeFunctions not yet handled (#2)' ) if 1 != scalar @{ $self->{ 'functions' }->[ 0 ]->{ 'items' } };
  3         12  
54              
55 3         7 return $self;
56             }
57              
58             sub as_text {
59 9     9 1 18 my $self = shift;
60 9         51 my $full_name = $self->{ 'functions' }->[ 0 ]->{ 'items' }->[ 0 ]->as_text;
61              
62             # Add optional WITH ORDINALITY
63 9 50       37 $full_name .= ' WITH ORDINALITY' if $self->{ 'ordinality' };
64              
65             # Shortcut
66 9         20 my $A = $self->{ 'alias' };
67 9 50       32 return $full_name unless $A;
68              
69 9         67 my $base_with_alias = sprintf( '%s AS %s', $full_name, $self->quote_ident( $A->{ 'aliasname' } ) );
70 9 50       78 return $base_with_alias unless $A->{ 'colnames' };
71              
72 0           return sprintf( '%s ( %s )', $base_with_alias, join( ', ', map { $_->as_ident } @{ $A->{ 'colnames' } } ) );
  0            
  0            
73             }
74              
75             1;