aboutsummaryrefslogtreecommitdiffstats
path: root/railties/guides/source/initialization.textile
diff options
context:
space:
mode:
authorRyan Bigg <radarlistener@gmail.com>2010-04-14 20:28:49 +1000
committerRyan Bigg <radarlistener@gmail.com>2010-04-14 20:29:15 +1000
commita77b86d57c3d46f954efc66714a0c18517d6fe12 (patch)
tree2e2e235cd38d0dcc282c752e2eca3e5799660e4d /railties/guides/source/initialization.textile
parent50aa106fa5ccc643fd4e47636a70aebeb0499a6d (diff)
downloadrails-a77b86d57c3d46f954efc66714a0c18517d6fe12.tar.gz
rails-a77b86d57c3d46f954efc66714a0c18517d6fe12.tar.bz2
rails-a77b86d57c3d46f954efc66714a0c18517d6fe12.zip
Begun documenting YourApp::Application and how it ties in with the backend.
Diffstat (limited to 'railties/guides/source/initialization.textile')
-rw-r--r--railties/guides/source/initialization.textile43
1 files changed, 43 insertions, 0 deletions
diff --git a/railties/guides/source/initialization.textile b/railties/guides/source/initialization.textile
index 14849fdd57..e9480408f8 100644
--- a/railties/guides/source/initialization.textile
+++ b/railties/guides/source/initialization.textile
@@ -1796,6 +1796,49 @@ Bundler was +require+'d back in _config/boot.rb_, and so that is what makes it a
The +Bundler.require+ method adds all the gems not specified inside a +group+ in the +Gemfile+ and the ones specified in groups for the +Rails.env+ (in this case, _development_), to the load path. This is how an application is able to find them.
+The rest of this file is spent defining your application's main class. This is it without the comments:
+
+<ruby>
+ module YourApp
+ class Application < Rails::Application
+ config.encoding = "utf-8"
+ config.filter_parameters += [:password]
+ end
+ end
+</ruby>
+
+h3. Return to Rails
+
+On the surface, this looks like a simple class inheritance. There's more underneath though. back in +Rails::Application+, the +inherited+ method is defined:
+
+<ruby>
+ def inherited(base)
+ raise "You cannot have more than one Rails::Application" if Rails.application
+ super
+ Rails.application = base.instance
+ end
+</ruby>
+
+We do not already have a +Rails.application+, so instead this resorts to calling +super+. +Rails::Application+ descends from +Rails::Engine+ and so will call the +inherited+ method in +Rails::Engine+, but before that it's important to note that +called_from+ is defined an +attr_accessor+ on +Rails::Engine+:
+
+<ruby>
+ def inherited(base)
+ unless base.abstract_railtie?
+ base.called_from = begin
+ # Remove the line number from backtraces making sure we don't leave anything behind
+ call_stack = caller.map { |p| p.split(':')[0..-2].join(':') }
+ File.dirname(call_stack.detect { |p| p !~ %r[railties[\w\-\.]*/lib/rails|rack[\w\-\.]*/lib/rack] })
+ end
+ end
+
+ super
+ end
+</ruby>
+
+This +called_from+ setting looks a little overwhelming to begin with, but the short end of it is that it returns the route to your application's config directory, something like: _/home/you/yourapp/config_. After +called_from+ has been set, +super+ is again called and this means the +Rails::Railtie#inherited+ method.
+
+
+
h3. Firing it up!