File Coverage

blib/lib/Pg/SQL/PrettyPrinter/Node/TransactionStmt.pm
Criterion Covered Total %
statement 67 68 98.5
branch 23 26 88.4
condition n/a
subroutine 16 16 100.0
pod 2 2 100.0
total 108 112 96.4


line stmt bran cond sub pod time code
1             package Pg::SQL::PrettyPrinter::Node::TransactionStmt;
2              
3             # UTF8 boilerplace, per http://stackoverflow.com/questions/6162484/why-does-modern-perl-avoid-utf-8-by-default/
4 3     3   6429 use v5.26;
  3         17  
5 3     3   23 use strict;
  3         7  
  3         132  
6 3     3   16 use warnings;
  3         7  
  3         282  
7 3     3   20 use warnings qw( FATAL utf8 );
  3         8  
  3         244  
8 3     3   31 use utf8;
  3         6  
  3         27  
9 3     3   215 use open qw( :std :utf8 );
  3         15  
  3         28  
10 3     3   654 use Unicode::Normalize qw( NFC );
  3         21  
  3         345  
11 3     3   26 use Unicode::Collate;
  3         7  
  3         236  
12 3     3   28 use Encode qw( decode );
  3         9  
  3         660  
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   29 use autodie;
  3         8  
  3         36  
24 3     3   25951 use Carp qw( carp croak confess cluck );
  3         55  
  3         533  
25 3     3   26 use English qw( -no_match_vars );
  3         8  
  3         58  
26 3     3   2197 use Data::Dumper qw( Dumper );
  3         8  
  3         1159  
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   34 use parent qw( Pg::SQL::PrettyPrinter::Node );
  3         14  
  3         37  
44              
45             sub new {
46 24     24 1 1176 my $class = shift;
47 24         103 my $self = $class->SUPER::new( @_ );
48 24         50 bless $self, $class;
49              
50 24 50       190 croak "Invalid TransactionStmt Kind: " . $self->{ 'kind' } unless $self->{ 'kind' } =~ m{\A(?:TRANS_STMT_COMMIT|TRANS_STMT_ROLLBACK|TRANS_STMT_START|TRANS_STMT_BEGIN)\z};
51              
52 24         162 $self->objectify( 'options' );
53              
54 24         73 return $self;
55             }
56              
57             sub as_text {
58 24     24 1 143 my $self = shift;
59 24 100       86 if ( $self->{ 'kind' } eq 'TRANS_STMT_ROLLBACK' ) {
60 2 100       48 return 'ROLLBACK' . ( $self->{ 'chain' } ? ' AND CHAIN' : '' );
61             }
62 22 100       72 if ( $self->{ 'kind' } eq 'TRANS_STMT_COMMIT' ) {
63 2 100       15 return 'COMMIT' . ( $self->{ 'chain' } ? ' AND CHAIN' : '' );
64             }
65 20 50       129 if ( $self->{ 'kind' } =~ /\ATRANS_STMT_(?:START|BEGIN)\z/ ) {
66 20 100       72 my $cmd = $self->{ 'kind' } eq 'TRANS_STMT_BEGIN' ? 'BEGIN' : 'START TRANSACTION';
67 20 100       67 return $cmd unless $self->{ 'options' };
68 18         44 my @elements = ();
69 18         35 for my $opt ( @{ $self->{ 'options' } } ) {
  18         57  
70 20 100       81 if ( $opt->{ 'defname' } eq 'transaction_isolation' ) {
    100          
    50          
71 10         64 push @elements, 'ISOLATION LEVEL ' . uc( $opt->{ 'arg' }->{ 'val' }->{ 'str' } );
72             }
73             elsif ( $opt->{ 'defname' } eq 'transaction_read_only' ) {
74 4 100       19 if ( $opt->{ 'arg' }->{ 'val' }->{ 'ival' } ) {
75 2         8 push @elements, 'READ ONLY';
76             }
77             else {
78 2         8 push @elements, 'READ WRITE';
79             }
80             }
81             elsif ( $opt->{ 'defname' } eq 'transaction_deferrable' ) {
82 6 100       22 if ( $opt->{ 'arg' }->{ 'val' }->{ 'ival' } ) {
83 4         16 push @elements, 'DEFERRABLE';
84             }
85             else {
86 2         8 push @elements, 'NOT DEFERRABLE';
87             }
88             }
89             }
90 18         136 return $cmd . ' ' . join( ', ', @elements );
91             }
92 0           return 'aaa';
93             }
94              
95             1;
96              
97             # vim: set ft=perl: