aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorKazuya NUMATA <numata@gmail.com>2014-12-25 12:58:42 +0900
committerKazuya NUMATA <numata@gmail.com>2014-12-25 12:58:42 +0900
commit2c95c39e9345ef50a7e9c3ad573857b1d358e04a (patch)
treeb838d8bece807bb34684f6999065d0a6543d0726 /lib
parent0cd5fa9671592a16ee34f0718704b15f27911620 (diff)
downloadrails-2c95c39e9345ef50a7e9c3ad573857b1d358e04a.tar.gz
rails-2c95c39e9345ef50a7e9c3ad573857b1d358e04a.tar.bz2
rails-2c95c39e9345ef50a7e9c3ad573857b1d358e04a.zip
{Matches,DoesNotMatch} support the ESCAPE clause with PostgreSQL
to_SQL already has supported the ESCAPE clause in #318. PostgreSQL can use the ESCAPE clause too.
Diffstat (limited to 'lib')
-rw-r--r--lib/arel/visitors/postgresql.rb16
1 files changed, 14 insertions, 2 deletions
diff --git a/lib/arel/visitors/postgresql.rb b/lib/arel/visitors/postgresql.rb
index f55aaf30fe..bd23fc0a47 100644
--- a/lib/arel/visitors/postgresql.rb
+++ b/lib/arel/visitors/postgresql.rb
@@ -4,11 +4,23 @@ module Arel
private
def visit_Arel_Nodes_Matches o, collector
- infix_value o, collector, ' ILIKE '
+ collector = infix_value o, collector, ' ILIKE '
+ if o.escape
+ collector << ' ESCAPE '
+ visit o.escape, collector
+ else
+ collector
+ end
end
def visit_Arel_Nodes_DoesNotMatch o, collector
- infix_value o, collector, ' NOT ILIKE '
+ collector = infix_value o, collector, ' NOT ILIKE '
+ if o.escape
+ collector << ' ESCAPE '
+ visit o.escape, collector
+ else
+ collector
+ end
end
def visit_Arel_Nodes_Regexp o, collector