aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrancesco Rodriguez <lrodriguezsanc@gmail.com>2012-05-18 00:22:32 -0500
committerFrancesco Rodriguez <lrodriguezsanc@gmail.com>2012-05-18 00:22:32 -0500
commit10d375efaa85cbfab11def8ddff7069b18da7064 (patch)
tree7640654c578d99988eff977a614043d469bbaa68
parent3ef1f9448332d8e73676ceb15e94d5482c75f1d3 (diff)
downloadrails-10d375efaa85cbfab11def8ddff7069b18da7064.tar.gz
rails-10d375efaa85cbfab11def8ddff7069b18da7064.tar.bz2
rails-10d375efaa85cbfab11def8ddff7069b18da7064.zip
add examples to CollectionAssociation#concat
-rw-r--r--activerecord/lib/active_record/associations/collection_association.rb17
1 files changed, 14 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/associations/collection_association.rb b/activerecord/lib/active_record/associations/collection_association.rb
index b00483a421..bfc2058a2c 100644
--- a/activerecord/lib/active_record/associations/collection_association.rb
+++ b/activerecord/lib/active_record/associations/collection_association.rb
@@ -124,8 +124,19 @@ module ActiveRecord
create_record(attributes, options, true, &block)
end
- # Add +records+ to this association. Returns +self+ so method calls may be chained.
- # Since << flattens its argument list and inserts each record, +push+ and +concat+ behave identically.
+ # Add +records+ to this association. Returns +self+ so method calls may
+ # be chained. Since << flattens its argument list and inserts each record,
+ # +push+ and +concat+ behave identically.
+ #
+ # class Person < ActiveRecord::Base
+ # pets :has_many
+ # end
+ #
+ # person.pets << Person.new(name: 'Nemo')
+ # person.pets.concat(Person.new(name: 'Droopy'))
+ # person.pets.push(Person.new(name: 'Ren'))
+ #
+ # person.pets # => [#<Pet name: "Nemo">, #<Pet name: "Droopy">, #<Pet name: "Ren">]
def concat(*records)
load_target if owner.new_record?
@@ -151,7 +162,7 @@ module ActiveRecord
end
end
- # Remove all records from this association
+ # Remove all records from this association.
#
# See delete for more info.
def delete_all