aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord
diff options
context:
space:
mode:
authorDavid Celis <david@davidcelis.com>2012-08-23 07:44:43 -0700
committerDavid Celis <david@davidcelis.com>2012-08-23 07:44:43 -0700
commit230d7f760030c3400b682e4d8ffa1292ac1a9682 (patch)
treeef03347d8ebca3ecdd841c953e305819279027c3 /activerecord
parent891043d5d0d097fc51c3fccdfa563c3ba52b7f55 (diff)
downloadrails-230d7f760030c3400b682e4d8ffa1292ac1a9682.tar.gz
rails-230d7f760030c3400b682e4d8ffa1292ac1a9682.tar.bz2
rails-230d7f760030c3400b682e4d8ffa1292ac1a9682.zip
Update the documentation for the :autosave option
I've noticed a caveat with the :autosave option biting people before. Questions arise about why they must explicitly save an associated object in their own before_save callbacks. I've updated the documentation as such to note to users that the :autosave callback occurs before any user defined callbacks. They must save the associated record themselves if altering it in their own callbacks. Signed-off-by: David Celis <david@davidcelis.com>
Diffstat (limited to 'activerecord')
-rw-r--r--activerecord/lib/active_record/associations.rb4
1 files changed, 3 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/associations.rb b/activerecord/lib/active_record/associations.rb
index 9ba3323bc7..d6b8552e6e 100644
--- a/activerecord/lib/active_record/associations.rb
+++ b/activerecord/lib/active_record/associations.rb
@@ -1137,7 +1137,9 @@ module ActiveRecord
# [:autosave]
# If true, always save the associated objects or destroy them if marked for destruction,
# when saving the parent object. If false, never save or destroy the associated objects.
- # By default, only save associated objects that are new records.
+ # By default, only save associated objects that are new records. This option is implemented as a
+ # before_save callback. Because callbacks are run in the order they are defined, associated objects
+ # may need to be explicitly saved in any user-defined before_save callbacks.
#
# Note that <tt>accepts_nested_attributes_for</tt> sets <tt>:autosave</tt> to <tt>true</tt>.
# [:inverse_of]