Railties – Gluing the Engine to the Rails
Railties is responsible for gluing all frameworks together. Overall, it:
-
handles the bootstrapping process for a
Railsapplication; -
manages the
railscommand line interface; -
and provides the
Railsgenerators 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::Secrets
- 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
Source: show
# File railties/lib/rails.rb, line 43 def application @application ||= (app_class.instance if app_class) end
autoloaders() Link
Source: show
# File railties/lib/rails.rb, line 123 def autoloaders application.autoloaders end
backtrace_cleaner() Link
Source: show
# File railties/lib/rails.rb, line 54 def backtrace_cleaner @backtrace_cleaner ||= Rails::BacktraceCleaner.new end
configuration() Link
The Configuration instance used to configure the Rails environment
Source: show
# File railties/lib/rails.rb, line 50 def configuration application.config end
env() Link
Returns the current Rails environment.
Rails.env # => "development"
Rails.env.development? # => true
Rails.env.production? # => false
Source: show
# File railties/lib/rails.rb, line 72 def env @_env ||= ActiveSupport::EnvironmentInquirer.new(ENV["RAILS_ENV"].presence || ENV["RACK_ENV"].presence || "development") end
env=(environment) Link
Sets the Rails environment.
Rails.env = "staging" # => "staging"
Source: show
# File railties/lib/rails.rb, line 79 def env=(environment) @_env = ActiveSupport::EnvironmentInquirer.new(environment) end
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)
Source: show
# File railties/lib/rails.rb, line 90 def error ActiveSupport.error_reporter end
gem_version() Link
Returns the currently loaded version of Rails as a Gem::Version.
Source: show
# File railties/lib/rails/gem_version.rb, line 5 def self.gem_version Gem::Version.new VERSION::STRING end
groups(*groups) Link
Returns all Rails groups for loading based on:
-
The
Railsenvironment; -
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"
Source: show
# File railties/lib/rails.rb, line 103 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>
Source: show
# File railties/lib/rails.rb, line 119 def public_path application && Pathname.new(application.paths["public"].first) end