aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-09-07 17:42:40 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-09-07 17:42:40 -0700
commitb4bcb93276834448ad9b59e91793ad75da26ce87 (patch)
treea22aff7829d55be9570c89fe1868f16467029e2c /lib
parent49432b11c1e0ebd2c5ac0d1d673a2ea9e8799d39 (diff)
downloadrails-b4bcb93276834448ad9b59e91793ad75da26ce87.tar.gz
rails-b4bcb93276834448ad9b59e91793ad75da26ce87.tar.bz2
rails-b4bcb93276834448ad9b59e91793ad75da26ce87.zip
on can take multiple args
Diffstat (limited to 'lib')
-rw-r--r--lib/arel/select_manager.rb15
1 files changed, 13 insertions, 2 deletions
diff --git a/lib/arel/select_manager.rb b/lib/arel/select_manager.rb
index 2ad9555d27..d8e113d5ee 100644
--- a/lib/arel/select_manager.rb
+++ b/lib/arel/select_manager.rb
@@ -8,8 +8,8 @@ module Arel
@ctx = @head.cores.last
end
- def on expr
- @ctx.froms.last.constraint = Nodes::On.new(expr)
+ def on *exprs
+ @ctx.froms.last.constraint = Nodes::On.new(collapse(exprs))
self
end
@@ -89,5 +89,16 @@ module Arel
def to_a
raise NotImplementedError
end
+
+ private
+ def collapse exprs
+ return exprs.first if exprs.length == 1
+
+ right = exprs.pop
+ left = exprs.pop
+
+ right = Nodes::And.new left, right
+ exprs.reverse.inject(right) { |memo,expr| Nodes::And.new(expr, memo) }
+ end
end
end