aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/relation.rb
diff options
context:
space:
mode:
authorPratik Naik <pratiknaik@gmail.com>2009-12-27 14:46:38 +0530
committerPratik Naik <pratiknaik@gmail.com>2009-12-27 14:46:38 +0530
commit85770ec7139fcba985310d239d4c57cfe6f6c60b (patch)
tree6ac06f74e46385f86ef51feb55e69730f1ca1020 /activerecord/lib/active_record/relation.rb
parentd511de0261003aae4913e3c24f76df6e03a35916 (diff)
downloadrails-85770ec7139fcba985310d239d4c57cfe6f6c60b.tar.gz
rails-85770ec7139fcba985310d239d4c57cfe6f6c60b.tar.bz2
rails-85770ec7139fcba985310d239d4c57cfe6f6c60b.zip
Make Model.find_or_create_by_* and find_or_initialize_by_* use relations and remove method caching
Diffstat (limited to 'activerecord/lib/active_record/relation.rb')
-rw-r--r--activerecord/lib/active_record/relation.rb7
1 files changed, 4 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/relation.rb b/activerecord/lib/active_record/relation.rb
index f17b889c53..89b9b9b4ff 100644
--- a/activerecord/lib/active_record/relation.rb
+++ b/activerecord/lib/active_record/relation.rb
@@ -164,11 +164,12 @@ module ActiveRecord
def find_or_instantiator_by_attributes(match, attributes, *args)
guard_protected_attributes = false
- attributes_for_create = conditions = attributes.inject({}) {|h, a| h[a] = args[attributes.index(a)]; h}
-
if args[0].is_a?(Hash)
guard_protected_attributes = true
- conditions = args[0].with_indifferent_access.slice(*attributes).symbolize_keys
+ attributes_for_create = args[0].with_indifferent_access
+ conditions = attributes_for_create.slice(*attributes).symbolize_keys
+ else
+ attributes_for_create = conditions = attributes.inject({}) {|h, a| h[a] = args[attributes.index(a)]; h}
end
record = where(conditions).first