line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package SQL::Translator::Types; |
2
|
|
|
|
|
|
|
|
3
|
72
|
|
|
72
|
|
530
|
use warnings; |
|
72
|
|
|
|
|
245
|
|
|
72
|
|
|
|
|
2474
|
|
4
|
72
|
|
|
72
|
|
442
|
use strict; |
|
72
|
|
|
|
|
160
|
|
|
72
|
|
|
|
|
2202
|
|
5
|
|
|
|
|
|
|
|
6
|
|
|
|
|
|
|
=head1 NAME |
7
|
|
|
|
|
|
|
|
8
|
|
|
|
|
|
|
SQL::Translator::Types - Type checking functions |
9
|
|
|
|
|
|
|
|
10
|
|
|
|
|
|
|
=head1 SYNOPSIS |
11
|
|
|
|
|
|
|
|
12
|
|
|
|
|
|
|
package Foo; |
13
|
|
|
|
|
|
|
use Moo; |
14
|
|
|
|
|
|
|
use SQL::Translator::Types qw(schema_obj enum); |
15
|
|
|
|
|
|
|
|
16
|
|
|
|
|
|
|
has foo => ( is => 'rw', isa => schema_obj('Trigger') ); |
17
|
|
|
|
|
|
|
has bar => ( is => 'rw', isa => enum([qw(baz quux quuz)], { |
18
|
|
|
|
|
|
|
msg => "Invalid value for bar: '%s'", icase => 1, |
19
|
|
|
|
|
|
|
}); |
20
|
|
|
|
|
|
|
|
21
|
|
|
|
|
|
|
=head1 DESCRIPTIONS |
22
|
|
|
|
|
|
|
|
23
|
|
|
|
|
|
|
This module exports functions that return coderefs suitable for L |
24
|
|
|
|
|
|
|
C type checks. |
25
|
|
|
|
|
|
|
Errors are reported using L. |
26
|
|
|
|
|
|
|
|
27
|
|
|
|
|
|
|
=cut |
28
|
|
|
|
|
|
|
|
29
|
72
|
|
|
72
|
|
433
|
use SQL::Translator::Utils qw(throw); |
|
72
|
|
|
|
|
205
|
|
|
72
|
|
|
|
|
3414
|
|
30
|
72
|
|
|
72
|
|
473
|
use Scalar::Util qw(blessed); |
|
72
|
|
|
|
|
221
|
|
|
72
|
|
|
|
|
3510
|
|
31
|
|
|
|
|
|
|
|
32
|
72
|
|
|
72
|
|
522
|
use Exporter qw(import); |
|
72
|
|
|
|
|
254
|
|
|
72
|
|
|
|
|
29765
|
|
33
|
|
|
|
|
|
|
our @EXPORT_OK = qw(schema_obj enum); |
34
|
|
|
|
|
|
|
|
35
|
|
|
|
|
|
|
=head1 FUNCTIONS |
36
|
|
|
|
|
|
|
|
37
|
|
|
|
|
|
|
=head2 schema_obj($type) |
38
|
|
|
|
|
|
|
|
39
|
|
|
|
|
|
|
Returns a coderef that checks that its arguments is an object of the |
40
|
|
|
|
|
|
|
class C<< SQL::Translator::Schema::I<$type> >>. |
41
|
|
|
|
|
|
|
|
42
|
|
|
|
|
|
|
=cut |
43
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
sub schema_obj { |
45
|
629
|
|
|
629
|
1
|
2037
|
my ($class) = @_; |
46
|
629
|
|
|
|
|
2054
|
my $name = lc $class; |
47
|
629
|
100
|
|
|
|
2639
|
$class = 'SQL::Translator::Schema' . ($class eq 'Schema' ? '' : "::$class"); |
48
|
|
|
|
|
|
|
return sub { |
49
|
2562
|
50
|
33
|
2562
|
|
113147
|
throw("Not a $name object") |
50
|
|
|
|
|
|
|
unless blessed($_[0]) and $_[0]->isa($class); |
51
|
629
|
|
|
|
|
4579
|
}; |
52
|
|
|
|
|
|
|
} |
53
|
|
|
|
|
|
|
|
54
|
|
|
|
|
|
|
=head2 enum(\@strings, [$msg | \%parameters]) |
55
|
|
|
|
|
|
|
|
56
|
|
|
|
|
|
|
Returns a coderef that checks that the argument is one of the provided |
57
|
|
|
|
|
|
|
C<@strings>. |
58
|
|
|
|
|
|
|
|
59
|
|
|
|
|
|
|
=head3 Parameters |
60
|
|
|
|
|
|
|
|
61
|
|
|
|
|
|
|
=over |
62
|
|
|
|
|
|
|
|
63
|
|
|
|
|
|
|
=item msg |
64
|
|
|
|
|
|
|
|
65
|
|
|
|
|
|
|
L string for the error message. |
66
|
|
|
|
|
|
|
If no other parameters are needed, this can be provided on its own, |
67
|
|
|
|
|
|
|
instead of the C<%parameters> hashref. |
68
|
|
|
|
|
|
|
The invalid value is passed as the only argument. |
69
|
|
|
|
|
|
|
Defaults to C. |
70
|
|
|
|
|
|
|
|
71
|
|
|
|
|
|
|
=item icase |
72
|
|
|
|
|
|
|
|
73
|
|
|
|
|
|
|
If true, folds the values to lower case before checking for equality. |
74
|
|
|
|
|
|
|
|
75
|
|
|
|
|
|
|
=item allow_undef |
76
|
|
|
|
|
|
|
|
77
|
|
|
|
|
|
|
If true, allow C in addition to the specified strings. |
78
|
|
|
|
|
|
|
|
79
|
|
|
|
|
|
|
=item allow_false |
80
|
|
|
|
|
|
|
|
81
|
|
|
|
|
|
|
If true, allow any false value in addition to the specified strings. |
82
|
|
|
|
|
|
|
|
83
|
|
|
|
|
|
|
=back |
84
|
|
|
|
|
|
|
|
85
|
|
|
|
|
|
|
=cut |
86
|
|
|
|
|
|
|
|
87
|
|
|
|
|
|
|
sub enum { |
88
|
349
|
|
|
349
|
1
|
41980
|
my ($values, $args) = @_; |
89
|
349
|
|
50
|
|
|
1408
|
$args ||= {}; |
90
|
349
|
50
|
|
|
|
1472
|
$args = { msg => $args } unless ref($args) eq 'HASH'; |
91
|
349
|
|
|
|
|
996
|
my $icase = !!$args->{icase}; |
92
|
349
|
100
|
|
|
|
667
|
my %values = map { ($icase ? lc : $_) => undef } @{$values}; |
|
1195
|
|
|
|
|
3885
|
|
|
349
|
|
|
|
|
829
|
|
93
|
349
|
|
50
|
|
|
1483
|
my $msg = $args->{msg} || "Invalid value: '%s'"; |
94
|
|
|
|
|
|
|
my $extra_test = |
95
|
47
|
|
|
47
|
|
986
|
$args->{allow_undef} ? sub { defined $_[0] } : |
96
|
349
|
50
|
|
1196
|
|
2183
|
$args->{allow_false} ? sub { !!$_[0] } : undef; |
|
1196
|
100
|
|
|
|
24052
|
|
97
|
|
|
|
|
|
|
|
98
|
|
|
|
|
|
|
return sub { |
99
|
1243
|
100
|
|
1243
|
|
48510
|
my $val = $icase ? lc $_[0] : $_[0]; |
100
|
|
|
|
|
|
|
throw(sprintf($msg, $val)) |
101
|
|
|
|
|
|
|
if (!defined($extra_test) || $extra_test->($val)) |
102
|
1243
|
100
|
66
|
|
|
4166
|
&& !exists $values{$val}; |
|
|
|
100
|
|
|
|
|
103
|
349
|
|
|
|
|
2956
|
}; |
104
|
|
|
|
|
|
|
} |
105
|
|
|
|
|
|
|
|
106
|
|
|
|
|
|
|
1; |