I tried your suggestion of passing locals as :@var on ruby 1.8.6 and
rails 2.2.2 and it doesn't seem to work
Tx...
Not to hijack the thread (I'm unsure if Nike Mike's question feels answered yet), but we are having a major problem with...
- too many tests
- too many render :partial and render :inline calls
- too many @ variables magically passed without :locals
Apparently we reach a threshold where the magic stops working, and our most important @ variables disappear. This leads to a cascade of incorrect test failures on missing nils. (The infamous "whiny nil" takes over.)
So if I fix that using :locals =>{ :@q => @q } in every render call, then I impair our project for upgrading to 2.2.2...
Elaborate sigh...
The problem with :locals => { :q => @q } is you can't say 'if q' inside the partial to detect if the local is set. You can say 'if @q', because you rely on Ruby to provide a nil for decorated variables that don't exist yet...
I seem to recall you can't do 'if defined? q', either. Maybe.
This means the final recourse is too ugly for Rails: :locals =>{ :things =>{ :q => @q } }. Now the partial can use 'if things[:q]'...