X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=scpubgit%2FQ-Branch.git;a=blobdiff_plain;f=lib%2FSQL%2FAbstract.pm;h=406d4e54777b045f55332f4144f1d5ec70d8b03f;hp=70ff3ea59870c52a397f41e38b358482128d78f9;hb=a2ad1cf9037d7a4e562d7e7f31a92a6049f6d3b2;hpb=a8e661847de3ebb2a4bd3613b375f6850370d507 diff --git a/lib/SQL/Abstract.pm b/lib/SQL/Abstract.pm index 70ff3ea..406d4e5 100644 --- a/lib/SQL/Abstract.pm +++ b/lib/SQL/Abstract.pm @@ -139,19 +139,11 @@ sub is_plain_value ($) { our %Defaults = ( expand => { - not => '_expand_not', bool => '_expand_bool', - and => '_expand_op_andor', - or => '_expand_op_andor', nest => '_expand_nest', bind => '_expand_bind', - in => '_expand_in', - not_in => '_expand_in', row => '_expand_row', - between => '_expand_between', - not_between => '_expand_between', op => '_expand_op', - (map +($_ => '_expand_op_is'), ('is', 'is_not')), func => '_expand_func', values => '_expand_values', }, @@ -1049,7 +1041,11 @@ sub _expand_hashpair_op { return { $k => $v }; } - my $type = $self->{unknown_unop_always_func} ? -func : -op; + my $type = ( + $self->{unknown_unop_always_func} && !$self->{render_op}{$op} + ? -func + : -op + ); { # Old SQLA compat @@ -1059,7 +1055,10 @@ sub _expand_hashpair_op { and (keys %$v)[0] =~ /^-/ ) { $type = ( - (List::Util::first { $op =~ $_->{regex} } @{$self->{special_ops}}) + ( + (List::Util::first { $op =~ $_->{regex} } @{$self->{special_ops}}) + or $self->{render_op}{$op} + ) ? -op : -func ) @@ -1205,10 +1204,6 @@ sub _expand_value { +{ -bind => [ our $Cur_Col_Meta, $_[2] ] }; } -sub _expand_not { - +{ -op => [ 'not', $_[0]->_expand_expr($_[2]) ] }; -} - sub _expand_row { my ($self, undef, $args) = @_; +{ -row => [ map $self->expand_expr($_), @$args ] };