Railties – Gluing the Engine to the Rails
Railties is responsible for gluing all frameworks together. Overall, it:
- 
handles the bootstrapping process for a Rails application;
 - 
manages the
railscommand line interface; - 
and provides the Rails generators core.
 
Download
The latest version of Railties can be installed with RubyGems:
- 
gem install railties
 
Source code can be downloaded as part of the Rails project on GitHub
License
Railties is released under the MIT license:
Support
API documentation is at
Bug reports can be filed for the Ruby on Rails project here:
Feature requests should be discussed on the rails-core mailing list here:
- MODULE Rails::API
 - MODULE Rails::Command
 - MODULE Rails::Configuration
 - MODULE Rails::ConsoleMethods
 - MODULE Rails::Generators
 - MODULE Rails::Info
 - MODULE Rails::Initializable
 - MODULE Rails::Paths
 - MODULE Rails::Rack
 - MODULE Rails::VERSION
 - CLASS Rails::AppBuilder
 - CLASS Rails::Application
 - CLASS Rails::Console
 - CLASS Rails::DBConsole
 - CLASS Rails::Engine
 - CLASS Rails::HealthController
 - CLASS Rails::PluginBuilder
 - CLASS Rails::Railtie
 - CLASS Rails::Server
 - CLASS Rails::SourceAnnotationExtractor
 
- A
 - B
 - C
 - E
 - G
 - P
 - R
 - V
 
Attributes
| [RW] | app_class | |
| [W] | application | |
| [RW] | cache | |
| [RW] | logger | 
Class Public methods
application() Link
autoloaders() Link
backtrace_cleaner() Link
configuration() Link
The Configuration instance used to configure the Rails environment
env() Link
Returns the current Rails environment.
Rails.env # => "development"
Rails.env.development? # => true
Rails.env.production? # => false
Rails.env.local? # => true              true for "development" and "test", false for anything else
            env=(environment) Link
Sets the Rails environment.
Rails.env = "staging" # => "staging"
            error() Link
Returns the ActiveSupport::ErrorReporter of the current Rails project, otherwise it returns nil if there is no project.
Rails.error.handle(IOError) do
  # ...
end
Rails.error.report(error)
            gem_version() Link
Returns the currently loaded version of Rails as a Gem::Version.
groups(*groups) Link
Returns all Rails groups for loading based on:
- 
The Rails environment;
 - 
The environment variable RAILS_GROUPS;
 - 
The optional envs given as argument and the hash with group dependencies;
 
Rails.groups assets: [:development, :test]
# => [:default, "development", :assets] for Rails.env == "development"
# => [:default, "production"]           for Rails.env == "production"
            # File railties/lib/rails.rb, line 106 def groups(*groups) hash = groups.extract_options! env = Rails.env groups.unshift(:default, env) groups.concat ENV["RAILS_GROUPS"].to_s.split(",") groups.concat hash.map { |k, v| k if v.map(&:to_s).include?(env) } groups.compact! groups.uniq! groups end
public_path() Link
Returns a Pathname object of the public folder of the current Rails project, otherwise it returns nil if there is no project:
Rails.public_path
  # => #<Pathname:/Users/someuser/some/path/project/public>