| line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
|
1
|
|
|
|
|
|
|
package # Hide from PAUSE |
|
2
|
|
|
|
|
|
|
DBIx::Class::SQLMaker::ACCESS; |
|
3
|
|
|
|
|
|
|
|
|
4
|
3
|
|
|
3
|
|
1965
|
use strict; |
|
|
3
|
|
|
|
|
13
|
|
|
|
3
|
|
|
|
|
95
|
|
|
5
|
3
|
|
|
3
|
|
17
|
use warnings; |
|
|
3
|
|
|
|
|
5
|
|
|
|
3
|
|
|
|
|
83
|
|
|
6
|
3
|
|
|
3
|
|
13
|
use base 'DBIx::Class::SQLMaker'; |
|
|
3
|
|
|
|
|
5
|
|
|
|
3
|
|
|
|
|
840
|
|
|
7
|
|
|
|
|
|
|
|
|
8
|
|
|
|
|
|
|
# inner joins must be prefixed with 'INNER ' |
|
9
|
|
|
|
|
|
|
sub new { |
|
10
|
1
|
|
|
1
|
1
|
3
|
my $class = shift; |
|
11
|
1
|
|
|
|
|
6
|
my $self = $class->next::method(@_); |
|
12
|
|
|
|
|
|
|
|
|
13
|
1
|
|
|
|
|
118
|
$self->{_default_jointype} = 'INNER'; |
|
14
|
|
|
|
|
|
|
|
|
15
|
1
|
|
|
|
|
8
|
return $self; |
|
16
|
|
|
|
|
|
|
} |
|
17
|
|
|
|
|
|
|
|
|
18
|
|
|
|
|
|
|
# MSAccess is retarded wrt multiple joins in FROM - it requires a certain |
|
19
|
|
|
|
|
|
|
# way of parenthesizing each left part before each next right part |
|
20
|
|
|
|
|
|
|
sub _recurse_from { |
|
21
|
6
|
|
|
6
|
|
39
|
my @j = shift->_gen_from_blocks(@_); |
|
22
|
|
|
|
|
|
|
|
|
23
|
|
|
|
|
|
|
# first 2 steps need no parenthesis |
|
24
|
6
|
|
|
|
|
31
|
my $fin_join = join (' ', splice @j, 0, 2); |
|
25
|
|
|
|
|
|
|
|
|
26
|
6
|
|
|
|
|
32
|
while (@j) { |
|
27
|
5
|
|
|
|
|
36
|
$fin_join = sprintf '( %s ) %s', $fin_join, (shift @j); |
|
28
|
|
|
|
|
|
|
} |
|
29
|
|
|
|
|
|
|
|
|
30
|
|
|
|
|
|
|
# the entire FROM is *ALSO* expected parenthesized |
|
31
|
6
|
|
|
|
|
46
|
"( $fin_join )"; |
|
32
|
|
|
|
|
|
|
} |
|
33
|
|
|
|
|
|
|
|
|
34
|
|
|
|
|
|
|
1; |