I'm creating a new engine for a rails 3 application. As you can guess, this engine is in the lib directory of my application.
However, i have some problems developing it. Indeed, I need to restart my server each time I change something in the engine.
Is there a way to avoid this ?
Can I force rails to completely reload the lib directory or a specific file and his requirements for each request ?
Thanks for your help :)
TL;DR
put this in config/application.rb
config.eager_load_paths += ["#{Rails.root}/lib"]
remove
require
statements for your lib filesGo!
Let me explain in detail.
I don't know why this answer is accepted, since it doesn't help with reloading lib folder on each request. First I thought that it works for Rails 2, but the question clearly states that it was for Rails 3 and the release date of 3.0.0 is before the date of the answer.
Other answers seem over-complicated or don't provide a real solution.
I decided to investigate things a little, because it was bothering me and I've even found out that people have a workaround for this and it involves saving lib files inside
app/models
in development and then moving it to/lib
when done. We can do better, right?My solution is tested against:
Put this into your
config/application.rb
:That's it!™
Make sure you put it here since it will not work if you put it in
config/environments/development.rb
, for example.Make sure your remove all the
require
statements for your/lib
code sincerequire
statements will also cause this solution to not work.This code implicitly requires your code, so if you do environment checks (which are unnecessary) and instead of the above code, you decide to write something like this:
you should watch out on the old
require
statements, since they are still required on all the non-development environments, in this scenario.So if you still decide to do environment checks, make sure you do inverse checks for require statements. Otherwise you'll get bitten!
You might think that writing entire paragraph about something that's unnecessary is also unnecessary, but I think that warning people about something that's necessary when doing something unnecessary is also necessary.
If you would like to know more about this topic, check out this little tutorial.
You have to add
to your Application class in config/application.rb
https://rails.lighthouseapp.com/projects/8994/tickets/5218-rails-3-rc-does-not-autoload-from-lib
Also, make sure that you comment out the following line in application.rb (in addition to @dishod's solution), and make sure that your module name is the same as your file name (otherwise, rails won't be able to find it)
Since we are talking Rails, the easiest way is to 'require' your lib/* .rb files using 'require_dependency'. So long as the controller/helper/etc (.rb files under app/) uses require_dependency instead of just require reloading works, without the need to do anything funky.
Before I went down that track, the only solution that worked was the one on hemju.com, but I really did not want to have to hack the ApplicationController for Dev speed.
Add to
application_controller.rb
or your base controller:Worked for me.
note that in Rails 3 "load_once_paths" becomes "autoload_once_paths."
Also, it appears that it should be empty unless you explicitly put something in it.