line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package Data::Transpose::Validator::String; |
2
|
|
|
|
|
|
|
|
3
|
5
|
|
|
5
|
|
2268
|
use strict; |
|
5
|
|
|
|
|
5
|
|
|
5
|
|
|
|
|
118
|
|
4
|
5
|
|
|
5
|
|
17
|
use warnings; |
|
5
|
|
|
|
|
4
|
|
|
5
|
|
|
|
|
104
|
|
5
|
5
|
|
|
5
|
|
14
|
use base 'Data::Transpose::Validator::Base'; |
|
5
|
|
|
|
|
5
|
|
|
5
|
|
|
|
|
751
|
|
6
|
|
|
|
|
|
|
|
7
|
|
|
|
|
|
|
=head1 NAME |
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
Data::Transpose::Validator::String Validator for strings |
10
|
|
|
|
|
|
|
|
11
|
|
|
|
|
|
|
=cut |
12
|
|
|
|
|
|
|
|
13
|
|
|
|
|
|
|
=head2 is_valid |
14
|
|
|
|
|
|
|
|
15
|
|
|
|
|
|
|
Check with C[ if the argument is a string. Return true on success ] |
16
|
|
|
|
|
|
|
(the length of the string). It fails on the empty string. |
17
|
|
|
|
|
|
|
|
18
|
|
|
|
|
|
|
=cut |
19
|
|
|
|
|
|
|
|
20
|
|
|
|
|
|
|
sub is_valid { |
21
|
91
|
|
|
91
|
1
|
127
|
my ($self, $string) = @_; |
22
|
91
|
|
|
|
|
183
|
$self->reset_errors; |
23
|
91
|
100
|
|
|
|
2903
|
unless (defined $string) { |
24
|
1
|
|
|
|
|
3
|
$self->error(["undefined", "String is undefined"]); |
25
|
1
|
|
|
|
|
3
|
return 0; |
26
|
|
|
|
|
|
|
} |
27
|
90
|
100
|
|
|
|
132
|
unless (ref($string) eq '') { |
28
|
1
|
|
|
|
|
3
|
$self->error(["hash", "Not a string"]); |
29
|
1
|
|
|
|
|
3
|
return 0; |
30
|
|
|
|
|
|
|
} |
31
|
89
|
|
|
|
|
80
|
my $length = length($string); |
32
|
89
|
100
|
|
|
|
114
|
$self->error(["empty", "Empty string"]) unless $length; |
33
|
89
|
100
|
|
|
|
173
|
$self->error ? return 0 : return $length; |
34
|
|
|
|
|
|
|
} |
35
|
|
|
|
|
|
|
|
36
|
|
|
|
|
|
|
1; |