File Coverage

blib/lib/SQL/Functional/FromClause.pm
Criterion Covered Total %
statement 6 8 75.0
branch n/a
condition n/a
subroutine 3 3 100.0
pod n/a
total 9 11 81.8


line stmt bran cond sub pod time code
1             # Copyright (c) 2016 Timm Murray
2             # All rights reserved.
3             #
4             # Redistribution and use in source and binary forms, with or without
5             # modification, are permitted provided that the following conditions are met:
6             #
7             # * Redistributions of source code must retain the above copyright notice,
8             # this list of conditions and the following disclaimer.
9             # * Redistributions in binary form must reproduce the above copyright
10             # notice, this list of conditions and the following disclaimer in the
11             # documentation and/or other materials provided with the distribution.
12             #
13             # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
14             # AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15             # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
16             # ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
17             # LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18             # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19             # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20             # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21             # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22             # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
23             # POSSIBILITY OF SUCH DAMAGE.
24             package SQL::Functional::FromClause;
25             $SQL::Functional::FromClause::VERSION = '0.1';
26 1     1   1406 use v5.14;
  1         2  
27 1     1   3 use warnings;
  1         1  
  1         17  
28 1     1   150 use Moose;
  0            
  0            
29             use namespace::autoclean;
30             use SQL::Functional::Clause;
31             use SQL::Functional::TableClause;
32              
33             with 'SQL::Functional::Clause';
34              
35             has tables => (
36             traits => [ 'Array' ],
37             is => 'ro',
38             isa => 'ArrayRef[SQL::Functional::TableClause]',
39             auto_deref => 1,
40             required => 1,
41             handles => {
42             add => 'push',
43             },
44             );
45              
46              
47             around 'add' => sub {
48             my ($orig, $self, $val) = @_;
49              
50             my $clean_val = $val;
51             if( (! ref($val)) || (! $val->isa( 'SQL::Functional::TableClause' )) ) {
52             $clean_val = SQL::Functional::TableClause->new({
53             name => $val,
54             });
55             }
56              
57             return $self->$orig( $clean_val );
58             };
59              
60              
61             sub to_string
62             {
63             my ($self) = @_;
64             return 'FROM ' . join( ', ', map { $_->to_string } $self->tables );
65             }
66              
67              
68             no Moose;
69             __PACKAGE__->meta->make_immutable;
70             1;
71             __END__