| line | stmt | bran | cond | sub | pod | time | code | 
| 1 |  |  |  |  |  |  | package Pg::SQL::PrettyPrinter::Node::RangeTableSample; | 
| 2 |  |  |  |  |  |  |  | 
| 3 |  |  |  |  |  |  | # UTF8 boilerplace, per http://stackoverflow.com/questions/6162484/why-does-modern-perl-avoid-utf-8-by-default/ | 
| 4 | 2 |  |  | 2 |  | 1563 | use v5.26; | 
|  | 2 |  |  |  |  | 8 |  | 
| 5 | 2 |  |  | 2 |  | 12 | use strict; | 
|  | 2 |  |  |  |  | 6 |  | 
|  | 2 |  |  |  |  | 41 |  | 
| 6 | 2 |  |  | 2 |  | 9 | use warnings; | 
|  | 2 |  |  |  |  | 6 |  | 
|  | 2 |  |  |  |  | 55 |  | 
| 7 | 2 |  |  | 2 |  | 9 | use warnings qw( FATAL utf8 ); | 
|  | 2 |  |  |  |  | 4 |  | 
|  | 2 |  |  |  |  | 58 |  | 
| 8 | 2 |  |  | 2 |  | 10 | use utf8; | 
|  | 2 |  |  |  |  | 5 |  | 
|  | 2 |  |  |  |  | 69 |  | 
| 9 | 2 |  |  | 2 |  | 78 | use open qw( :std :utf8 ); | 
|  | 2 |  |  |  |  | 5 |  | 
|  | 2 |  |  |  |  | 13 |  | 
| 10 | 2 |  |  | 2 |  | 294 | use Unicode::Normalize qw( NFC ); | 
|  | 2 |  |  |  |  | 5 |  | 
|  | 2 |  |  |  |  | 144 |  | 
| 11 | 2 |  |  | 2 |  | 13 | use Unicode::Collate; | 
|  | 2 |  |  |  |  | 5 |  | 
|  | 2 |  |  |  |  | 72 |  | 
| 12 | 2 |  |  | 2 |  | 12 | use Encode qw( decode ); | 
|  | 2 |  |  |  |  | 5 |  | 
|  | 2 |  |  |  |  | 118 |  | 
| 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 |  | 423 | use autodie; | 
|  | 2 |  |  |  |  | 6 |  | 
|  | 2 |  |  |  |  | 26 |  | 
| 24 | 2 |  |  | 2 |  | 11068 | use Carp         qw( carp croak confess cluck ); | 
|  | 2 |  |  |  |  | 6 |  | 
|  | 2 |  |  |  |  | 163 |  | 
| 25 | 2 |  |  | 2 |  | 14 | use English      qw( -no_match_vars ); | 
|  | 2 |  |  |  |  | 5 |  | 
|  | 2 |  |  |  |  | 13 |  | 
| 26 | 2 |  |  | 2 |  | 769 | use Data::Dumper qw( Dumper ); | 
|  | 2 |  |  |  |  | 54 |  | 
|  | 2 |  |  |  |  | 423 |  | 
| 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 |  | 62 | use parent qw( Pg::SQL::PrettyPrinter::Node ); | 
|  | 2 |  |  |  |  | 8 |  | 
|  | 2 |  |  |  |  | 13 |  | 
| 44 |  |  |  |  |  |  |  | 
| 45 |  |  |  |  |  |  | sub new { | 
| 46 | 3 |  |  | 3 | 1 | 82 | my $class = shift; | 
| 47 | 3 |  |  |  |  | 14 | my $self  = $class->SUPER::new( @_ ); | 
| 48 | 3 |  |  |  |  | 9 | bless $self, $class; | 
| 49 |  |  |  |  |  |  |  | 
| 50 | 3 | 50 |  |  |  | 6 | croak( 'More than one method in tablesample: ' . Dumper( $self ) ) if 1 < scalar @{ $self->{ 'method' } }; | 
|  | 3 |  |  |  |  | 14 |  | 
| 51 | 3 |  |  |  |  | 15 | $self->objectify( qw( relation args method repeatable ) ); | 
| 52 |  |  |  |  |  |  |  | 
| 53 | 3 |  |  |  |  | 8 | return $self; | 
| 54 |  |  |  |  |  |  | } | 
| 55 |  |  |  |  |  |  |  | 
| 56 |  |  |  |  |  |  | sub as_text { | 
| 57 | 6 |  |  | 6 | 1 | 13 | my $self     = shift; | 
| 58 | 6 |  |  |  |  | 11 | my @elements = (); | 
| 59 | 6 |  |  |  |  | 23 | push @elements, $self->{ 'relation' }->as_text; | 
| 60 | 6 |  |  |  |  | 13 | push @elements, 'TABLESAMPLE'; | 
| 61 | 6 |  |  |  |  | 20 | push @elements, $self->{ 'method' }->[ 0 ]->as_ident; | 
| 62 |  |  |  |  |  |  |  | 
| 63 |  |  |  |  |  |  | # Uppercase one of two pg-provided sampling methods | 
| 64 | 6 |  |  |  |  | 55 | $elements[ -1 ] =~ s/\A(system|bernoulli)\z/\U$1/; | 
| 65 |  |  |  |  |  |  |  | 
| 66 | 6 |  |  |  |  | 14 | push @elements, '('; | 
| 67 | 6 |  |  |  |  | 10 | push @elements, map { $_->as_text } @{ $self->{ 'args' } }; | 
|  | 6 |  |  |  |  | 20 |  | 
|  | 6 |  |  |  |  | 13 |  | 
| 68 | 6 |  |  |  |  | 15 | push @elements, ')'; | 
| 69 | 6 | 100 |  |  |  | 17 | if ( exists $self->{ 'repeatable' } ) { | 
| 70 | 2 |  |  |  |  | 7 | push @elements, 'REPEATABLE', '(', $self->{ 'repeatable' }->as_text, ')'; | 
| 71 |  |  |  |  |  |  | } | 
| 72 | 6 |  |  |  |  | 39 | return join( ' ', @elements ); | 
| 73 |  |  |  |  |  |  | } | 
| 74 |  |  |  |  |  |  |  | 
| 75 |  |  |  |  |  |  | 1; | 
| 76 |  |  |  |  |  |  |  | 
| 77 |  |  |  |  |  |  | # vim: set ft=perl: |