lol, at first I thought you were messing with me. X is the apps Controllers module, correct?
Will I always have to do this when using Tilt? Or only until this patch makes it into a gem? Dave On Fri, Jul 23, 2010 at 3:09 PM, Magnus Holm <judo...@gmail.com> wrote: > Wait, forget about that Tilt patch. Try this instead: > > module App > include X > end > > // Magnus Holm > > > > On Fri, Jul 23, 2010 at 18:01, David Susco <dsu...@gmail.com> wrote: >> Hey Magnus, I patched the files and it's still the same thing. Here's >> the backtrace, let me know if you want browser dump as well. >> >> 127.0.0.1 - - [23/Jul/2010 11:48:39] "GET /Home HTTP/1.1" 500 95353 0.3607 >> ArgumentError: Anonymous modules have no name to be referenced by >> >> /usr/local/lib/ruby/gems/1.8/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:585:in >> `to_constant_name' >> >> /usr/local/lib/ruby/gems/1.8/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:391:in >> `qualified_name_for' >> >> /usr/local/lib/ruby/gems/1.8/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:104:in >> `const_missing' >> /var/www/apps/crud/riki/views/layout.haml:23:in `evaluate_source' >> /usr/local/lib/ruby/gems/1.8/gems/tilt-1.0.1/lib/tilt.rb:195:in >> `evaluate' >> /usr/local/lib/ruby/gems/1.8/gems/tilt-1.0.1/lib/tilt.rb:560:in >> `evaluate' >> /usr/local/lib/ruby/gems/1.8/gems/tilt-1.0.1/lib/tilt.rb:128:in >> `render' >> (eval):15:in `render' >> (eval):15:in `render' >> ./riki/controllers.rb:85:in `get' >> (eval):27:in `send' >> (eval):27:in `service' >> (eval):27:in `catch' >> (eval):27:in `service' >> (eval):38:in `call' >> >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/session/cookie.rb:37:in >> `call' >> (eval):42:in `call' >> >> /usr/local/lib/ruby/gems/1.8/gems/camping-2.0.392/bin/../lib/camping/server.rb:176:in >> `call' >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/lint.rb:47:in >> `_call' >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/lint.rb:35:in >> `call' >> >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/showexceptions.rb:24:in >> `call' >> >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/commonlogger.rb:18:in >> `call' >> >> /usr/local/lib/ruby/gems/1.8/gems/camping-2.0.392/bin/../lib/camping/server.rb:242:in >> `call' >> >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/content_length.rb:13:in >> `call' >> >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/handler/webrick.rb:48:in >> `service' >> /usr/local/lib/ruby/1.8/webrick/httpserver.rb:104:in `service' >> /usr/local/lib/ruby/1.8/webrick/httpserver.rb:65:in `run' >> /usr/local/lib/ruby/1.8/webrick/server.rb:173:in `start_thread' >> /usr/local/lib/ruby/1.8/webrick/server.rb:162:in `start' >> /usr/local/lib/ruby/1.8/webrick/server.rb:162:in `start_thread' >> /usr/local/lib/ruby/1.8/webrick/server.rb:95:in `start' >> /usr/local/lib/ruby/1.8/webrick/server.rb:92:in `each' >> /usr/local/lib/ruby/1.8/webrick/server.rb:92:in `start' >> /usr/local/lib/ruby/1.8/webrick/server.rb:23:in `start' >> /usr/local/lib/ruby/1.8/webrick/server.rb:82:in `start' >> >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/handler/webrick.rb:14:in >> `run' >> >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/server.rb:155:in >> `start' >> >> /usr/local/lib/ruby/gems/1.8/gems/camping-2.0.392/bin/../lib/camping/server.rb:144:in >> `start' >> /usr/local/lib/ruby/gems/1.8/gems/rack-1.1.0/lib/rack/server.rb:83:in >> `start' >> /usr/local/lib/ruby/gems/1.8/gems/camping-2.0.392/bin/camping:9 >> /usr/local/bin/camping:19:in `load' >> /usr/local/bin/camping:19 >> >> >> On Wed, Jul 21, 2010 at 5:26 PM, Magnus Holm <judo...@gmail.com> wrote: >>> A reference to a controller is also a constant. Everything which >>> starts with an uppercase letter is in fact a constant. >>> >>> Hm. Could you give me a backtrace? It seems like it's ActiveSupport's >>> const_missing or something like that. >>> >>> You don't really need to read/understand all those comments in the >>> patch. It's all related to the fact that Tilt defines the template as >>> a method under the Tilt::CompileSite (which is included in each >>> request in Camping) so when you call #render it actually calls a >>> method called #_tilt_ajdbakjasjdbakjsbdk in the background. Calling a >>> method is way faster than instance_eval, so this gives a significant >>> speed improvement. The problem by defining the method under >>> Tilt::CompileSite is that constant lookup is now relative to >>> Tilt::CompileSite instead of your request. This is what the patch >>> fixes. >>> >>> // Magnus Holm >>> >>> >>> >>> On Wed, Jul 21, 2010 at 22:53, David Susco <dsu...@gmail.com> wrote: >>>> Thanks Magnus, >>>> >>>> I gave that a shot but I'm still getting an argument error: >>>> >>>> Anonymous modules have no name to be referenced by >>>> >>>> I'm trying to wrap my mind around what this patch is doing, but I >>>> don't see the connection between constants and a reference to a >>>> controller. >>>> >>>> Dave >>>> >>>> On Wed, Jul 21, 2010 at 3:29 PM, Magnus Holm <judo...@gmail.com> wrote: >>>>> This is a well-known bug in Tilt: >>>>> http://groups.google.com/group/tiltrb/browse_thread/thread/19fef5370c4d417f >>>>> >>>>> The thread includes a quite simple patch for 1.8, and a larger, very >>>>> hackish patch for 1.8+1.9. >>>>> >>>>> >>>>> // Magnus Holm >>>>> >>>>> >>>>> >>>>> On Wed, Jul 21, 2010 at 21:05, David Susco <dsu...@gmail.com> wrote: >>>>>> When using Tilt for views I need to completely specify the controller >>>>>> within the template file. >>>>>> >>>>>> For example, in a Markaby view I can do this: >>>>>> >>>>>> URL(LogIn) >>>>>> >>>>>> But in a template file I have to do this: >>>>>> >>>>>> URL(MyApp::Controllers::LogIn) >>>>>> >>>>>> Is there anyway around this? >>>>>> >>>>>> -- >>>>>> Dave >>>>>> _______________________________________________ >>>>>> Camping-list mailing list >>>>>> Camping-list@rubyforge.org >>>>>> http://rubyforge.org/mailman/listinfo/camping-list >>>>>> >>>>> _______________________________________________ >>>>> Camping-list mailing list >>>>> Camping-list@rubyforge.org >>>>> http://rubyforge.org/mailman/listinfo/camping-list >>>>> >>>> >>>> >>>> >>>> -- >>>> Dave >>>> _______________________________________________ >>>> Camping-list mailing list >>>> Camping-list@rubyforge.org >>>> http://rubyforge.org/mailman/listinfo/camping-list >>>> >>> _______________________________________________ >>> Camping-list mailing list >>> Camping-list@rubyforge.org >>> http://rubyforge.org/mailman/listinfo/camping-list >>> >> >> >> >> -- >> Dave >> _______________________________________________ >> Camping-list mailing list >> Camping-list@rubyforge.org >> http://rubyforge.org/mailman/listinfo/camping-list >> > _______________________________________________ > Camping-list mailing list > Camping-list@rubyforge.org > http://rubyforge.org/mailman/listinfo/camping-list -- Dave _______________________________________________ Camping-list mailing list Camping-list@rubyforge.org http://rubyforge.org/mailman/listinfo/camping-list