File Coverage

blib/lib/Aniki/Plugin/RangeConditionMaker.pm
Criterion Covered Total %
statement 26 26 100.0
branch 11 14 78.5
condition 5 6 83.3
subroutine 6 6 100.0
pod 0 1 0.0
total 48 53 90.5


line stmt bran cond sub pod time code
1             package Aniki::Plugin::RangeConditionMaker;
2 2     2   1116 use 5.014002;
  2         9  
3              
4 2     2   10 use namespace::autoclean;
  2         4  
  2         15  
5 2     2   529 use Mouse::Role;
  2         944  
  2         12  
6              
7 2     2   775 use Carp qw/carp croak/;
  2         5  
  2         138  
8 2     2   392 use SQL::QueryMaker qw/sql_gt sql_lt sql_and/;
  2         2926  
  2         706  
9              
10             sub make_range_condition {
11 11     11 0 84 my ($self, $range) = @_;
12              
13 11         32 my %total_range_condition;
14 11         54 for my $type (qw/lower upper gt lt/) {
15 44 100       174 next unless exists $range->{$type};
16              
17 8 50       38 ref $range->{$type} eq 'HASH'
18             or croak "$type condition *MUST* be HashRef.";
19              
20 8 50 100     71 my $func = $type eq 'lower' || $type eq 'gt' ? \&sql_gt
    100 66        
21             : $type eq 'upper' || $type eq 'lt' ? \&sql_lt
22             : die "Unknown type: $type";
23              
24 8         24 my $range_condition = $range->{$type};
25 8         31 for my $column (keys %$range_condition) {
26             croak "$column cannot be a reference value for range condition"
27 8 50       27 if ref $range_condition->{$column};
28              
29 8         38 my $condition = $func->($range_condition->{$column});
30             $total_range_condition{$column} =
31 8 100       284 exists $total_range_condition{$column} ? sql_and([$total_range_condition{$column}, $condition])
32             : $condition;
33             }
34             }
35              
36 11 100       52 return %total_range_condition ? \%total_range_condition : undef;
37             }
38              
39             1;
40             __END__
41              
42             =pod
43              
44             =encoding utf-8
45              
46             =head1 NAME
47              
48             Aniki::Plugin::RangeConditionMaker - range condition maker
49              
50             =head1 SYNOPSIS
51              
52             package MyDB;
53             use Mouse v2.4.5;
54             extends qw/Aniki/;
55             with qw/Aniki::Plugin::RangeConditionMaker/;
56              
57             package main;
58             my $db = MyDB->new(...);
59              
60             my $where = $db->make_range_condition({ upper => { id => 10 } });
61             # => { id => { '<' => 10 } }
62             $where = $db->make_range_condition({ lower => { id => 0 } });
63             # => { id => { '>' => 0 } }
64             $where = $db->make_range_condition({ upper => { id => 10 }, lower => { id => 0 } });
65             # => { id => [-and => { '>' => 0 }, { '<' => 10 }] }
66              
67             =head1 LICENSE
68              
69             Copyright (C) karupanerura.
70              
71             This library is free software; you can redistribute it and/or modify
72             it under the same terms as Perl itself.
73              
74             =head1 AUTHOR
75              
76             karupanerura E<lt>karupa@cpan.orgE<gt>
77              
78             =cut