Skip to Content Skip to Search

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 44
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 55
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 51
def configuration
  application.config
end

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
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 64
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

Definition files

115 More Less