module Rails

Attributes

app_class[RW]
application[W]
cache[RW]
logger[RW]

Public Class Methods

application() Show source
# File railties/lib/rails.rb, line 39
def application
  @application ||= (app_class.instance if app_class)
end
backtrace_cleaner() Show source
# File railties/lib/rails.rb, line 50
def backtrace_cleaner
  @backtrace_cleaner ||= begin
    # Relies on Active Support, so we have to lazy load to postpone definition until Active Support has been loaded
    require "rails/backtrace_cleaner"
    Rails::BacktraceCleaner.new
  end
end
configuration() Show source
# File railties/lib/rails.rb, line 46
def configuration
  application.config
end

The Configuration instance used to configure the Rails environment

env() Show source
# File railties/lib/rails.rb, line 72
def env
  @_env ||= ActiveSupport::StringInquirer.new(ENV["RAILS_ENV"].presence || ENV["RACK_ENV"].presence || "development")
end

Returns the current Rails environment.

Rails.env # => "development"
Rails.env.development? # => true
Rails.env.production? # => false
env=(environment) Show source
# File railties/lib/rails.rb, line 79
def env=(environment)
  @_env = ActiveSupport::StringInquirer.new(environment)
end

Sets the Rails environment.

Rails.env = "staging" # => "staging"
gem_version() Show source
# File railties/lib/rails/gem_version.rb, line 5
def self.gem_version
  Gem::Version.new VERSION::STRING
end

Returns the version of the currently loaded Rails as a Gem::Version

groups(*groups) Show source
# File railties/lib/rails.rb, line 94
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 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;

    groups assets: [:development, :test]

    # Returns # => [:default, “development”, :assets] for ::env == “development” # => [:default, “production”] for ::env == “production”

public_path() Show source
# File railties/lib/rails.rb, line 110
def public_path
  application && Pathname.new(application.paths["public"].first)
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>
root() Show source
# File railties/lib/rails.rb, line 63
def root
  application && application.config.root
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>
version() Show source
# File railties/lib/rails/version.rb, line 7
def self.version
  VERSION::STRING
end

Returns the version of the currently loaded Rails as a string.

© 2004–2018 David Heinemeier Hansson
Licensed under the MIT License.