aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/relation
diff options
context:
space:
mode:
Diffstat (limited to 'activerecord/lib/active_record/relation')
-rw-r--r--activerecord/lib/active_record/relation/query_methods.rb15
1 files changed, 9 insertions, 6 deletions
diff --git a/activerecord/lib/active_record/relation/query_methods.rb b/activerecord/lib/active_record/relation/query_methods.rb
index ff5bce9d8b..caa55929f4 100644
--- a/activerecord/lib/active_record/relation/query_methods.rb
+++ b/activerecord/lib/active_record/relation/query_methods.rb
@@ -12,18 +12,20 @@ module ActiveRecord
next if [:where, :having, :select].include?(query_method)
class_eval <<-CEVAL, __FILE__, __LINE__ + 1
def #{query_method}(*args)
+ args.flatten!
+ args.reject! { |a| a.blank? }
new_relation = clone
- value = Array.wrap(args.flatten).reject {|x| x.blank? }
- new_relation.#{query_method}_values += value if value.present?
+ new_relation.#{query_method}_values += args if args.present?
new_relation
end
CEVAL
end
def reorder(*args)
+ args.flatten!
+ args.reject! { |a| a.blank? }
new_relation = clone
- value = Array.wrap(args.flatten).reject {|x| x.blank? }
- new_relation.order_values = value if value.present?
+ new_relation.order_values = args if args.present?
new_relation
end
@@ -31,9 +33,10 @@ module ActiveRecord
if block_given?
to_a.select { |*block_args| yield(*block_args) }
else
+ args.flatten!
+ args.reject! { |a| a.blank? }
new_relation = clone
- value = Array.wrap(args.flatten).reject {|x| x.blank? }
- new_relation.select_values += value if value.present?
+ new_relation.select_values += args if args.present?
new_relation
end
end