module Rails
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
rails
command 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:
Attributes
[RW] | app_class |
|
[W] | application |
|
[RW] | cache |
|
[RW] | logger |
Public class methods
Source code GitHub
# File railties/lib/rails.rb, line 45
def application
@application ||= (app_class.instance if app_class)
end
Source code GitHub
# File railties/lib/rails.rb, line 125
def autoloaders
application.autoloaders
end
Source code GitHub
# File railties/lib/rails.rb, line 56
def backtrace_cleaner
@backtrace_cleaner ||= Rails::BacktraceCleaner.new
end
The Configuration instance used to configure the Rails environment
Source code GitHub
# File railties/lib/rails.rb, line 52
def configuration
application.config
end
Returns the current Rails environment.
Rails.env # => "development"
Rails.env.development? # => true
Rails.env.production? # => false
Source code GitHub
# File railties/lib/rails.rb, line 74
def env
@_env ||= ActiveSupport::EnvironmentInquirer.new(ENV["RAILS_ENV"].presence || ENV["RACK_ENV"].presence || "development")
end
Sets the Rails environment.
Rails.env = "staging" # => "staging"
Source code GitHub
# File railties/lib/rails.rb, line 81
def env=(environment)
@_env = ActiveSupport::EnvironmentInquirer.new(environment)
end
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 code GitHub
# File railties/lib/rails.rb, line 92
def error
ActiveSupport.error_reporter
end
Returns the currently loaded version of Rails as a Gem::Version
.
Source code GitHub
# File railties/lib/rails/gem_version.rb, line 5
def self.gem_version
Gem::Version.new VERSION::STRING
end
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"
Source code GitHub
# File railties/lib/rails.rb, line 105
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
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 code GitHub
# File railties/lib/rails.rb, line 121
def public_path
application && Pathname.new(application.paths["public"].first)
end
Returns a Pathname object of the current Rails project, otherwise it returns nil
if there is no project:
Rails.root
# => #<Pathname:/Users/someuser/some/path/project>
Source code GitHub
# File railties/lib/rails.rb, line 65
def root
application && application.config.root
end
Returns the currently loaded version of Rails as a string.
Source code GitHub
# File railties/lib/rails/version.rb, line 7
def self.version
VERSION::STRING
end
Namespace
Rails::
API Rails::
AppBuilder Rails::
Application Rails::
Command Rails::
Configuration Rails::
Console Rails::
ConsoleMethods Rails::
DBConsole Rails::
Engine Rails::
Generators Rails::
HealthController Rails::
Info Rails::
Paths Rails::
PluginBuilder Rails::
Rack Rails::
Railtie Rails::
Secrets Rails::
Server Rails::
SourceAnnotationExtractor Rails::
VERSION
Definition files
railties/
lib/ rails.rb railties/
lib/ rails/ api/ task.rb railties/
lib/ rails/ app_updater.rb railties/
lib/ rails/ application.rb railties/
lib/ rails/ application/ bootstrap.rb
84 More Less
railties/
lib/ rails/ application/ configuration.rb railties/
lib/ rails/ application/ default_middleware_stack.rb railties/
lib/ rails/ application/ finisher.rb railties/
lib/ rails/ backtrace_cleaner.rb railties/
lib/ rails/ command.rb railties/
lib/ rails/ command/ actions.rb railties/
lib/ rails/ command/ base.rb railties/
lib/ rails/ command/ environment_argument.rb railties/
lib/ rails/ command/ helpers/ editor.rb railties/
lib/ rails/ commands/ about/ about_command.rb railties/
lib/ rails/ commands/ application/ application_command.rb railties/
lib/ rails/ commands/ console/ console_command.rb railties/
lib/ rails/ commands/ credentials/ credentials_command.rb railties/
lib/ rails/ commands/ credentials/ credentials_command/ diffing.rb railties/
lib/ rails/ commands/ db/ system/ change/ change_command.rb railties/
lib/ rails/ commands/ dbconsole/ dbconsole_command.rb railties/
lib/ rails/ commands/ destroy/ destroy_command.rb railties/
lib/ rails/ commands/ dev/ dev_command.rb railties/
lib/ rails/ commands/ encrypted/ encrypted_command.rb railties/
lib/ rails/ commands/ gem_help/ gem_help_command.rb railties/
lib/ rails/ commands/ generate/ generate_command.rb railties/
lib/ rails/ commands/ help/ help_command.rb railties/
lib/ rails/ commands/ initializers/ initializers_command.rb railties/
lib/ rails/ commands/ middleware/ middleware_command.rb railties/
lib/ rails/ commands/ new/ new_command.rb railties/
lib/ rails/ commands/ notes/ notes_command.rb railties/
lib/ rails/ commands/ plugin/ plugin_command.rb railties/
lib/ rails/ commands/ rake/ rake_command.rb railties/
lib/ rails/ commands/ restart/ restart_command.rb railties/
lib/ rails/ commands/ routes/ routes_command.rb railties/
lib/ rails/ commands/ runner/ runner_command.rb railties/
lib/ rails/ commands/ secret/ secret_command.rb railties/
lib/ rails/ commands/ secrets/ secrets_command.rb railties/
lib/ rails/ commands/ server/ server_command.rb railties/
lib/ rails/ commands/ test/ test_command.rb railties/
lib/ rails/ commands/ unused_routes/ unused_routes_command.rb railties/
lib/ rails/ commands/ version/ version_command.rb railties/
lib/ rails/ configuration.rb railties/
lib/ rails/ console/ app.rb railties/
lib/ rails/ deprecator.rb railties/
lib/ rails/ engine.rb railties/
lib/ rails/ engine/ configuration.rb railties/
lib/ rails/ gem_version.rb railties/
lib/ rails/ generators.rb railties/
lib/ rails/ generators/ actions.rb railties/
lib/ rails/ generators/ active_model.rb railties/
lib/ rails/ generators/ app_base.rb railties/
lib/ rails/ generators/ app_name.rb railties/
lib/ rails/ generators/ base.rb railties/
lib/ rails/ generators/ database.rb railties/
lib/ rails/ generators/ devcontainer.rb railties/
lib/ rails/ generators/ generated_attribute.rb railties/
lib/ rails/ generators/ migration.rb railties/
lib/ rails/ generators/ model_helpers.rb railties/
lib/ rails/ generators/ rails/ app/ app_generator.rb railties/
lib/ rails/ generators/ rails/ application_record/ application_record_generator.rb railties/
lib/ rails/ generators/ rails/ benchmark/ benchmark_generator.rb railties/
lib/ rails/ generators/ rails/ controller/ controller_generator.rb railties/
lib/ rails/ generators/ rails/ credentials/ credentials_generator.rb railties/
lib/ rails/ generators/ rails/ db/ system/ change/ change_generator.rb railties/
lib/ rails/ generators/ rails/ encryption_key_file/ encryption_key_file_generator.rb railties/
lib/ rails/ generators/ rails/ migration/ migration_generator.rb railties/
lib/ rails/ generators/ rails/ model/ model_generator.rb railties/
lib/ rails/ generators/ rails/ plugin/ plugin_generator.rb railties/
lib/ rails/ generators/ rails/ resource/ resource_generator.rb railties/
lib/ rails/ generators/ rails/ scaffold/ scaffold_generator.rb railties/
lib/ rails/ generators/ rails/ scaffold_controller/ scaffold_controller_generator.rb railties/
lib/ rails/ generators/ test_case.rb railties/
lib/ rails/ generators/ testing/ assertions.rb railties/
lib/ rails/ generators/ testing/ behavior.rb railties/
lib/ rails/ health_controller.rb railties/
lib/ rails/ info.rb railties/
lib/ rails/ info_controller.rb railties/
lib/ rails/ mailers_controller.rb railties/
lib/ rails/ paths.rb railties/
lib/ rails/ pwa_controller.rb railties/
lib/ rails/ rack/ logger.rb railties/
lib/ rails/ railtie.rb railties/
lib/ rails/ railtie/ configurable.rb railties/
lib/ rails/ railtie/ configuration.rb railties/
lib/ rails/ secrets.rb railties/
lib/ rails/ source_annotation_extractor.rb railties/
lib/ rails/ version.rb railties/
lib/ rails/ zeitwerk_checker.rb