You can use ActiveRecord::Observer. For details please go to
http://blog.invisible.ch/files/rails-reference-1.1.html

However theres another funny work around for this problem
as your desired syntax is
after_destroy :update_something, true

Just tweak little bit:
after_destroy "update_something(true)"

declare the update_something method privately like:
def update_something(param = value)
   #operations based on #{param}
end

I dont know your actual scenario. But i think
 * If u need to perform same action on :after_save and :after_destroy
call-back then why do you need parameter
 * Secondly, if update_something performs differently based on the
parameter then why don't you create two separate methods

Anyway looking for the real picture from you and hope to get the best
architectural suggestion from anyone for this kind of problem :-)

Thank you
Samiron Paul
http://samironpaul.blogspot.com


On May 24, 9:52 pm, Erdwin Lianata <[email protected]>
wrote:
> What about ...
>
> def update_something(value=false)
>    # ..
> end
>
> def after_save
>    update_something(true)
> end
>
> Or use instance variable as conditional state instead of passing
> variable to a function called from macro (i.e after_save)
>
> Arpit Jain wrote:
> > I need to pass attributes to the function called in callback in rails
> > model.  For example,
>
> > after_save :update_something
> > after_destroy :update_something, true  #true is the argument that I need
> > to pass
>
> > private
> > def update_something(value = false)
> >   #...
> > end
>
> > I found a way to do it like this
>
> > after_save :update_something
> > after_destroy {|record| record.update_something(true)}
>
> > But in this case, I need to make the function update_something public,
> > which I don't want to do.
>
> > Any help ?
>
> > --
> > Arpit Jain
--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups "Ruby 
on Rails: Talk" group.
To post to this group, send email to [email protected]
To unsubscribe from this group, send email to 
[email protected]
For more options, visit this group at 
http://groups.google.com/group/rubyonrails-talk?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to