Build the framework paths.
By default, the following paths will be used:
application |
|
config |
Merb.root/config |
lib |
Merb.root/lib |
log |
Merb.root/log |
view |
|
model |
|
controller |
|
helper |
|
mailer |
|
part |
To override the default, set Merb::Config in your initialization file. Merb::Config takes a Hash whose key is the name of the path, and whose values can be passed into Merb.push_path (see Merb.push_path for full details).
All paths will default to Merb.root, so you can get a flat-file structure by doing Merb::Config = {}.
Merb::Config[:framework] = { :view => Merb.root / "views", :model => Merb.root / "models", :lib => Merb.root / "lib", :public => [Merb.root / "public", nil] :router => [Merb.root / "config", "router.rb"] }
That will set up a flat directory structure with the config files and controller files under Merb.root, but with models, views, and lib with their own folders off of Merb.root.
Sets up merb paths to support the app's file layout. First, config/framework.rb is checked, next we look for Merb.root/framework.rb, finally we use the default merb layout (Merb::BootLoader.default_framework)
This method can be overriden to support other application layouts.
nil
:api: plugin @overridable
# File lib/merb-core/bootloader.rb, line 323 def build_framework if File.exists?(Merb.root / "config" / "framework.rb") require Merb.root / "config" / "framework" elsif File.exists?(Merb.root / "framework.rb") require Merb.root / "framework" else Merb::BootLoader.default_framework end (Merb::Config[:framework] || {}).each do |name, path| path = Array(path) Merb.push_path(name, path.first, path.length == 2 ? path[1] : "**/*.rb") end nil end
Generated with the Darkfish Rdoc Generator 2.