File Coverage

blib/lib/Pg/SQL/PrettyPrinter/Node/XmlSerialize.pm
Criterion Covered Total %
statement 78 84 92.8
branch 6 10 60.0
condition n/a
subroutine 18 18 100.0
pod 4 4 100.0
total 106 116 91.3


line stmt bran cond sub pod time code
1             package Pg::SQL::PrettyPrinter::Node::XmlSerialize;
2              
3             # UTF8 boilerplace, per http://stackoverflow.com/questions/6162484/why-does-modern-perl-avoid-utf-8-by-default/
4 2     2   1560 use v5.26;
  2         8  
5 2     2   12 use strict;
  2         4  
  2         41  
6 2     2   10 use warnings;
  2         4  
  2         55  
7 2     2   10 use warnings qw( FATAL utf8 );
  2         4  
  2         59  
8 2     2   10 use utf8;
  2         20  
  2         13  
9 2     2   54 use open qw( :std :utf8 );
  2         4  
  2         9  
10 2     2   270 use Unicode::Normalize qw( NFC );
  2         4  
  2         106  
11 2     2   12 use Unicode::Collate;
  2         5  
  2         49  
12 2     2   10 use Encode qw( decode );
  2         4  
  2         119  
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 2     2   419 use autodie;
  2         9  
  2         15  
24 2     2   11330 use Carp qw( carp croak confess cluck );
  2         87  
  2         154  
25 2     2   13 use English qw( -no_match_vars );
  2         81  
  2         16  
26 2     2   732 use Data::Dumper qw( Dumper );
  2         5  
  2         470  
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 2     2   15 use parent qw( Pg::SQL::PrettyPrinter::Node );
  2         6  
  2         15  
44              
45             sub new {
46 2     2 1 42 my $class = shift;
47 2         8 my $self = $class->SUPER::new( @_ );
48 2         3 bless $self, $class;
49              
50 2 50       15 croak( 'Unknown XML option: ' . $self->{ 'xmloption' } ) unless $self->{ 'xmloption' } =~ m{\AXMLOPTION_(DOCUMENT|CONTENT)\z};
51              
52 2         14 $self->objectify( 'expr', [ qw( typeName names ) ], [ qw( typeName typmods ) ], [ qw( typeName arrayBounds ) ] );
53              
54 2         7 return $self;
55             }
56              
57             sub as_text {
58 2     2 1 5 my $self = shift;
59 2         5 my @elements = ();
60 2         4 push @elements, 'XMLSERIALIZE(';
61 2         4 push @elements, $self->{ 'xmloption' };
62 2         9 $elements[ -1 ] =~ s/^XMLOPTION_//;
63 2         8 push @elements, $self->{ 'expr' }->as_text;
64 2         5 push @elements, 'AS';
65 2         6 push @elements, $self->expr_type;
66 2         3 push @elements, ')';
67 2         46 return join( ' ', @elements );
68             }
69              
70             sub pretty_print {
71 2     2 1 4 my $self = shift;
72 2         4 my @lines = ();
73 2         4 push @lines, 'XMLSERIALIZE(';
74 2         11 push @lines, $self->increase_indent( $self->{ 'xmloption' } );
75 2         15 $lines[ -1 ] =~ s/^(\s+)XMLOPTION_/$1/;
76 2         8 push @lines, $self->increase_indent( $self->{ 'expr' }->pretty_print );
77 2         12 $lines[ -1 ] .= ' AS ' . $self->expr_type;
78 2         4 push @lines, ')';
79 2         8 return join( "\n", @lines );
80             }
81              
82             sub expr_type {
83 4     4 1 8 my $self = shift;
84              
85 4         5 my $typname = join( '.', map { $_->as_ident } @{ $self->{ 'typeName' }->{ 'names' } } );
  6         15  
  4         10  
86 4 100       14 $typname = 'char' if $typname eq 'pg_catalog.bpchar';
87              
88 4         5 my $typmods = '';
89 4 100       12 if ( exists $self->{ 'typeName' }->{ 'typmods' } ) {
90 2         4 $typmods = '( ' . join( ', ', map { $_->as_text } @{ $self->{ 'typeName' }->{ 'typmods' } } ) . ' )';
  2         7  
  2         5  
91             }
92 4 50       11 if ( exists $self->{ 'typeName' }->{ 'arrayBounds' } ) {
93 0         0 my @bounds_as_text = map { $_->as_text } @{ $self->{ 'typeName' }->{ 'arrayBounds' } };
  0         0  
  0         0  
94 0         0 my $array_def = sprintf '[%s]', join( ', ', @bounds_as_text );
95 0 0       0 $array_def = '[]' if $array_def eq '[-1]';
96 0         0 $typmods .= $array_def;
97             }
98 4         11 return $typname . $typmods;
99             }
100              
101             1;
102              
103             # vim: set ft=perl: