aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-09-06 18:56:16 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-09-06 18:56:16 -0700
commitb541a963bd94e189219619553476321f4be37490 (patch)
tree88695bdd8b617441ed5bb98172a4faf17c0c24a8
parent32157a2dd208f7417ba09c645be6cd28a1dca988 (diff)
downloadrails-b541a963bd94e189219619553476321f4be37490.tar.gz
rails-b541a963bd94e189219619553476321f4be37490.tar.bz2
rails-b541a963bd94e189219619553476321f4be37490.zip
cleaning up confusing logic
-rw-r--r--activerecord/lib/active_record/relation/query_methods.rb9
1 files changed, 6 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/relation/query_methods.rb b/activerecord/lib/active_record/relation/query_methods.rb
index 6005105cc9..f410492b0a 100644
--- a/activerecord/lib/active_record/relation/query_methods.rb
+++ b/activerecord/lib/active_record/relation/query_methods.rb
@@ -274,10 +274,13 @@ module ActiveRecord
@implicit_readonly = false
# TODO: fix this ugly hack, we should refactor the callers to get an ARel compatible array.
# Before this change we were passing to ARel the last element only, and ARel is capable of handling an array
- if selects.all? {|s| s.is_a?(String) || !s.is_a?(Arel::Expression) } && !(selects.last =~ /^COUNT\(/)
- arel.project(*selects)
+ case select = selects.last
+ when Arel::Expression, Arel::SqlLiteral
+ arel.project(select)
+ when /^COUNT\(/
+ arel.project(Arel::SqlLiteral.new(select))
else
- arel.project(selects.last)
+ arel.project(*selects)
end
else
arel.project(Arel::SqlLiteral.new(@klass.quoted_table_name + '.*'))