X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=lib%2FSQL%2FAbstract%2FClauses.pm;h=fd98e731a33a9b8afdffa20b836c92bfb0dcb408;hb=1ba47f38ffd3b99b3ae3be9520edafd560bfb026;hp=877117df2920e21997e971d11f39a61f60f40197;hpb=58ebc7fa5f9ccaabc1ce23d57ab642c6825bdebc;p=scpubgit%2FQ-Branch.git diff --git a/lib/SQL/Abstract/Clauses.pm b/lib/SQL/Abstract/Clauses.pm index 877117d..fd98e73 100644 --- a/lib/SQL/Abstract/Clauses.pm +++ b/lib/SQL/Abstract/Clauses.pm @@ -164,7 +164,7 @@ sub _render_statement { next unless defined($sql) and length($sql); push @parts, \@part; } - my ($sql, @bind) = $self->_join_parts(' ', @parts); + my ($sql, @bind) = $self->join_clauses(' ', @parts); return ( (our $Render_Top_Level ? $sql : '('.$sql.')'), @bind @@ -260,7 +260,7 @@ sub _expand_values { sub _render_values { my ($self, $values) = @_; - my ($v_sql, @bind) = $self->_join_parts( + my ($v_sql, @bind) = $self->join_clauses( ', ', map [ $self->render_aqt($_) ], ref($values) eq 'ARRAY' ? @$values : $values @@ -274,14 +274,14 @@ sub _render_values { sub _ext_rw { my ($self, $name, $key, $value) = @_; - return $self->{$name}{$key} unless @_ > 2; + return $self->{$name}{$key} unless @_ > 3; $self->{$name}{$key} = $value; return $self; } BEGIN { foreach my $type (qw( - expand op_expand render op_renderer clause_expand clause_render + expand op_expand render op_render clause_expand clause_render )) { my $key = join '_', reverse split '_', $type; my $singular = "${type}er"; @@ -302,6 +302,9 @@ sub clauses_of { unless (@clauses) { return @{$self->{clauses_of}{$of}||[]}; } + if (ref($clauses[0]) eq 'CODE') { + @clauses = $self->${\($clauses[0])}(@{$self->{clauses_of}{$of}||[]}); + } $self->{clauses_of}{$of} = \@clauses; return $self; }