File Coverage

blib/lib/DBI/Gofer/Response.pm
Criterion Covered Total %
statement 24 103 23.3
branch 4 70 5.7
condition 1 54 1.8
subroutine 8 11 72.7
pod 0 6 0.0
total 37 244 15.1


line stmt bran cond sub pod time code
1             package DBI::Gofer::Response;
2              
3             # $Id: Response.pm 11565 2008-07-22 20:17:33Z Tim $
4             #
5             # Copyright (c) 2007, Tim Bunce, Ireland
6             #
7             # You may distribute under the terms of either the GNU General Public
8             # License or the Artistic License, as specified in the Perl README file.
9              
10 56     56   338 use strict;
  56         118  
  56         1511  
11              
12 56     56   271 use Carp;
  56         107  
  56         3543  
13 56     56   297 use DBI qw(neat neat_list);
  56         124  
  56         2442  
14              
15 56     56   315 use base qw(DBI::Util::_accessor Exporter);
  56         109  
  56         5737  
16              
17             our $VERSION = "0.011566";
18              
19 56     56   337 use constant GOf_RESPONSE_EXECUTED => 0x0001;
  56         125  
  56         61284  
20              
21             our @EXPORT = qw(GOf_RESPONSE_EXECUTED);
22              
23              
24             __PACKAGE__->mk_accessors(qw(
25             version
26             rv
27             err
28             errstr
29             state
30             flags
31             last_insert_id
32             dbh_attributes
33             sth_resultsets
34             warnings
35             ));
36             __PACKAGE__->mk_accessors_using(make_accessor_autoviv_hashref => qw(
37             meta
38             ));
39              
40              
41             sub new {
42 6454     6454 0 12306 my ($self, $args) = @_;
43 6454   33     25545 $args->{version} ||= $VERSION;
44 6454 100       12484 chomp $args->{errstr} if $args->{errstr};
45 6454         17083 return $self->SUPER::new($args);
46             }
47              
48              
49             sub err_errstr_state {
50 7138     7138 0 10512 my $self = shift;
51 7138         10607 return @{$self}{qw(err errstr state)};
  7138         25376  
52             }
53              
54             sub executed_flag_set {
55 2990 100   2990 0 29945 my $flags = shift->flags
56             or return 0;
57 132         652 return $flags & GOf_RESPONSE_EXECUTED;
58             }
59              
60              
61             sub add_err {
62 0     0 0   my ($self, $err, $errstr, $state, $trace) = @_;
63              
64             # acts like the DBI's set_err method.
65             # this code copied from DBI::PurePerl's set_err method.
66              
67 0 0         chomp $errstr if $errstr;
68 0   0       $state ||= '';
69 0 0 0       carp ref($self)."->add_err($err, $errstr, $state)"
      0        
70             if $trace and defined($err) || $errstr;
71              
72 0           my ($r_err, $r_errstr, $r_state) = ($self->{err}, $self->{errstr}, $self->{state});
73              
74 0 0         if ($r_errstr) {
75 0 0 0       $r_errstr .= sprintf " [err was %s now %s]", $r_err, $err
      0        
76             if $r_err && $err && $r_err ne $err;
77 0 0 0       $r_errstr .= sprintf " [state was %s now %s]", $r_state, $state
      0        
      0        
78             if $r_state and $r_state ne "S1000" && $state && $r_state ne $state;
79 0 0         $r_errstr .= "\n$errstr" if $r_errstr ne $errstr;
80             }
81             else {
82 0           $r_errstr = $errstr;
83             }
84              
85             # assign if higher priority: err > "0" > "" > undef
86 0           my $err_changed;
87 0 0 0       if ($err # new error: so assign
      0        
      0        
88             or !defined $r_err # no existing warn/info: so assign
89             # new warn ("0" len 1) > info ("" len 0): so assign
90             or defined $err && length($err) > length($r_err)
91             ) {
92 0           $r_err = $err;
93 0           ++$err_changed;
94             }
95              
96 0 0 0       $r_state = ($state eq "00000") ? "" : $state
    0          
97             if $state && $err_changed;
98              
99 0           ($self->{err}, $self->{errstr}, $self->{state}) = ($r_err, $r_errstr, $r_state);
100              
101 0           return undef;
102             }
103              
104              
105             sub summary_as_text {
106 0     0 0   my $self = shift;
107 0           my ($context) = @_;
108              
109 0           my ($rv, $err, $errstr, $state) = ($self->{rv}, $self->{err}, $self->{errstr}, $self->{state});
110              
111 0 0         my @s = sprintf("\trv=%s", (ref $rv) ? "[".neat_list($rv)."]" : neat($rv));
112 0 0         $s[-1] .= sprintf(", err=%s, errstr=%s", $err, neat($errstr))
113             if defined $err;
114             $s[-1] .= sprintf(", flags=0x%x", $self->{flags})
115 0 0         if defined $self->{flags};
116              
117 0 0         push @s, "last_insert_id=%s", $self->last_insert_id
118             if defined $self->last_insert_id;
119              
120 0 0         if (my $dbh_attr = $self->dbh_attributes) {
121 0           my @keys = sort keys %$dbh_attr;
122 0 0         push @s, sprintf "dbh= { %s }", join(", ", map { "$_=>".neat($dbh_attr->{$_},100) } @keys)
  0            
123             if @keys;
124             }
125              
126 0 0         for my $rs (@{$self->sth_resultsets || []}) {
  0            
127             my ($rowset, $err, $errstr, $state)
128 0           = @{$rs}{qw(rowset err errstr state)};
  0            
129 0           my $summary = "rowset: ";
130 0   0       my $NUM_OF_FIELDS = $rs->{NUM_OF_FIELDS} || 0;
131 0 0         my $rows = $rowset ? @$rowset : 0;
132 0 0 0       if ($rowset || $NUM_OF_FIELDS > 0) {
133 0           $summary .= sprintf "%d rows, %d columns", $rows, $NUM_OF_FIELDS;
134             }
135 0 0         $summary .= sprintf ", err=%s, errstr=%s", $err, neat($errstr) if defined $err;
136 0 0         if ($rows) {
137 0           my $NAME = $rs->{NAME};
138             # generate
139 0           my @colinfo = map { "$NAME->[$_]=".neat($rowset->[0][$_], 30) } 0..@{$NAME}-1;
  0            
  0            
140 0           $summary .= sprintf " [%s]", join ", ", @colinfo;
141 0 0         $summary .= ",..." if $rows > 1;
142             # we can be a little more helpful for Sybase/MSSQL user
143             $summary .= " syb_result_type=$rs->{syb_result_type}"
144 0 0 0       if $rs->{syb_result_type} and $rs->{syb_result_type} != 4040;
145             }
146 0           push @s, $summary;
147             }
148 0 0         for my $w (@{$self->warnings || []}) {
  0            
149 0           chomp $w;
150 0           push @s, "warning: $w";
151             }
152 0 0 0       if ($context && %$context) {
153 0           my @keys = sort keys %$context;
154 0           push @s, join(", ", map { "$_=>".$context->{$_} } @keys);
  0            
155             }
156 0           return join("\n\t", @s). "\n";
157             }
158              
159              
160             sub outline_as_text { # one-line version of summary_as_text
161 0     0 0   my $self = shift;
162 0           my ($context) = @_;
163              
164 0           my ($rv, $err, $errstr, $state) = ($self->{rv}, $self->{err}, $self->{errstr}, $self->{state});
165              
166 0 0         my $s = sprintf("rv=%s", (ref $rv) ? "[".neat_list($rv)."]" : neat($rv));
167 0 0         $s .= sprintf(", err=%s %s", $err, neat($errstr))
168             if defined $err;
169             $s .= sprintf(", flags=0x%x", $self->{flags})
170 0 0         if $self->{flags};
171              
172 0 0         if (my $sth_resultsets = $self->sth_resultsets) {
173 0           $s .= sprintf(", %d resultsets ", scalar @$sth_resultsets);
174              
175 0           my @rs;
176 0 0         for my $rs (@{$self->sth_resultsets || []}) {
  0            
177 0           my $summary = "";
178             my ($rowset, $err, $errstr)
179 0           = @{$rs}{qw(rowset err errstr)};
  0            
180 0   0       my $NUM_OF_FIELDS = $rs->{NUM_OF_FIELDS} || 0;
181 0 0         my $rows = $rowset ? @$rowset : 0;
182 0 0 0       if ($rowset || $NUM_OF_FIELDS > 0) {
183 0           $summary .= sprintf "%dr x %dc", $rows, $NUM_OF_FIELDS;
184             }
185 0 0         $summary .= sprintf "%serr %s %s", ($summary?", ":""), $err, neat($errstr)
    0          
186             if defined $err;
187 0           push @rs, $summary;
188             }
189 0           $s .= join "; ", map { "[$_]" } @rs;
  0            
190             }
191              
192 0           return $s;
193             }
194              
195              
196             1;
197              
198             =head1 NAME
199              
200             DBI::Gofer::Response - Encapsulate a response from DBI::Gofer::Execute to DBD::Gofer
201              
202             =head1 DESCRIPTION
203              
204             This is an internal class.
205              
206             =head1 AUTHOR
207              
208             Tim Bunce, L
209              
210             =head1 LICENCE AND COPYRIGHT
211              
212             Copyright (c) 2007, Tim Bunce, Ireland. All rights reserved.
213              
214             This module is free software; you can redistribute it and/or
215             modify it under the same terms as Perl itself. See L.
216              
217             =cut
218