File Coverage

blib/lib/Pg/SQL/PrettyPrinter/Node/RangeSubselect.pm
Criterion Covered Total %
statement 65 66 98.4
branch 6 8 75.0
condition n/a
subroutine 17 17 100.0
pod 3 3 100.0
total 91 94 96.8


line stmt bran cond sub pod time code
1             package Pg::SQL::PrettyPrinter::Node::RangeSubselect;
2              
3             # UTF8 boilerplace, per http://stackoverflow.com/questions/6162484/why-does-modern-perl-avoid-utf-8-by-default/
4 3     3   5258 use v5.26;
  3         14  
5 3     3   18 use strict;
  3         6  
  3         82  
6 3     3   13 use warnings;
  3         7  
  3         172  
7 3     3   14 use warnings qw( FATAL utf8 );
  3         6  
  3         190  
8 3     3   18 use utf8;
  3         5  
  3         31  
9 3     3   92 use open qw( :std :utf8 );
  3         6  
  3         18  
10 3     3   434 use Unicode::Normalize qw( NFC );
  3         7  
  3         169  
11 3     3   14 use Unicode::Collate;
  3         5  
  3         92  
12 3     3   13 use Encode qw( decode );
  3         7  
  3         410  
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   15 use autodie;
  3         5  
  3         19  
24 3     3   16200 use Carp qw( carp croak confess cluck );
  3         6  
  3         328  
25 3     3   22 use English qw( -no_match_vars );
  3         7  
  3         26  
26 3     3   1644 use Data::Dumper qw( Dumper );
  3         8  
  3         777  
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   23 use parent qw( Pg::SQL::PrettyPrinter::Node );
  3         9  
  3         66  
44              
45             sub new {
46 2     2 1 36 my $class = shift;
47 2         11 my $self = $class->SUPER::new( @_ );
48 2         4 bless $self, $class;
49              
50 2         10 $self->objectify( 'subquery', [ 'alias', 'colnames' ] );
51              
52 2         4 return $self;
53             }
54              
55             sub as_text {
56 2     2 1 3 my $self = shift;
57              
58             # Shortcut
59 2         4 my $A = $self->{ 'alias' };
60              
61 2         6 my $base_with_alias = sprintf( '( %s ) AS %s', $self->{ 'subquery' }->as_text, $self->quote_ident( $A->{ 'aliasname' } ) );
62 2 50       9 $base_with_alias = 'LATERAL ' . $base_with_alias if $self->{ 'lateral' };
63 2 100       7 return $base_with_alias unless $A->{ 'colnames' };
64              
65 1         3 return sprintf( '%s ( %s )', $base_with_alias, join( ', ', map { $_->as_ident } @{ $A->{ 'colnames' } } ) );
  2         4  
  1         2  
66             }
67              
68             sub pretty_print {
69 2     2 1 5 my $self = shift;
70 2         3 my @lines = ();
71 2 50       7 if ( $self->{ 'lateral' } ) {
72 0         0 push @lines, 'LATERAL (';
73             }
74             else {
75 2         4 push @lines, '(';
76             }
77 2         8 push @lines, $self->increase_indent( $self->{ 'subquery' }->pretty_print );
78 2         6 push @lines, ') AS ' . $self->{ 'alias' }->{ 'aliasname' };
79 2 100       5 if ( $self->{ 'alias' }->{ 'colnames' } ) {
80 1         3 $lines[ -1 ] .= sprintf ' ( %s )', join( ', ', map { $_->as_ident } @{ $self->{ 'alias' }->{ 'colnames' } } );
  2         6  
  1         3  
81             }
82 2         8 return join( "\n", @lines );
83             }
84              
85             1;