Module: Rails

Extended by:
ActiveSupport::Autoload
Defined in:
activejob/lib/rails/generators/job/job_generator.rb,
actionmailer/lib/rails/generators/mailer/mailer_generator.rb,
actioncable/lib/rails/generators/channel/channel_generator.rb,
railties/lib/rails.rb,
railties/lib/rails/info.rb,
railties/lib/rails/rack.rb,
railties/lib/rails/paths.rb,
railties/lib/rails/engine.rb,
railties/lib/rails/railtie.rb,
railties/lib/rails/version.rb,
railties/lib/rails/command.rb,
railties/lib/rails/api/task.rb,
railties/lib/rails/generators.rb,
railties/lib/rails/app_loader.rb,
railties/lib/rails/application.rb,
railties/lib/rails/console/app.rb,
railties/lib/rails/gem_version.rb,
railties/lib/rails/rack/logger.rb,
railties/lib/rails/configuration.rb,
railties/lib/rails/initializable.rb,
railties/lib/rails/commands/server.rb,
railties/lib/rails/engine/railties.rb,
railties/lib/rails/generators/base.rb,
railties/lib/rails/console/helpers.rb,
railties/lib/rails/commands/console.rb,
railties/lib/rails/backtrace_cleaner.rb,
railties/lib/rails/test_unit/railtie.rb,
railties/lib/rails/test_unit/reporter.rb,
railties/lib/rails/commands/dev_cache.rb,
railties/lib/rails/commands/dbconsole.rb,
railties/lib/rails/generators/actions.rb,
railties/lib/rails/generators/app_base.rb,
railties/lib/rails/commands/rake_proxy.rb,
railties/lib/rails/railtie/configurable.rb,
railties/lib/rails/application/finisher.rb,
railties/lib/rails/generators/test_case.rb,
railties/lib/rails/generators/migration.rb,
railties/lib/rails/commands/application.rb,
railties/lib/rails/engine/configuration.rb,
railties/lib/rails/application/bootstrap.rb,
railties/lib/rails/generators/named_base.rb,
railties/lib/rails/railtie/configuration.rb,
railties/lib/rails/test_unit/test_requirer.rb,
railties/lib/rails/generators/active_model.rb,
railties/lib/rails/commands/commands_tasks.rb,
railties/lib/rails/commands/console_helper.rb,
railties/lib/rails/test_unit/line_filtering.rb,
railties/lib/rails/generators/model_helpers.rb,
railties/lib/rails/application/configuration.rb,
railties/lib/rails/application/routes_reloader.rb,
railties/lib/rails/generators/resource_helpers.rb,
railties/lib/rails/generators/testing/behaviour.rb,
railties/lib/rails/generators/testing/assertions.rb,
railties/lib/rails/generators/generated_attribute.rb,
railties/lib/rails/generators/rails/app/app_generator.rb,
railties/lib/rails/generators/actions/create_migration.rb,
railties/lib/rails/application/default_middleware_stack.rb,
railties/lib/rails/generators/rails/task/task_generator.rb,
railties/lib/rails/generators/testing/setup_and_teardown.rb,
railties/lib/rails/generators/rails/model/model_generator.rb,
railties/lib/rails/generators/rails/helper/helper_generator.rb,
railties/lib/rails/generators/rails/plugin/plugin_generator.rb,
railties/lib/rails/generators/rails/assets/assets_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/migration/migration_generator.rb,
railties/lib/rails/generators/rails/generator/generator_generator.rb,
railties/lib/rails/generators/rails/controller/controller_generator.rb,
railties/lib/rails/generators/rails/resource_route/resource_route_generator.rb,
railties/lib/rails/generators/rails/integration_test/integration_test_generator.rb,
railties/lib/rails/generators/rails/scaffold_controller/scaffold_controller_generator.rb

Overview

:nodoc:

Defined Under Namespace

Modules: API, ActionMethods, AppLoader, Commands, Configuration, ConsoleHelper, ConsoleMethods, Generators, Info, Initializable, LineFiltering, Paths, Rack, RakeProxy, VERSION Classes: AppBuilder, Application, ApplicationController, BacktraceCleaner, Command, CommandsTasks, CompositeFilter, Console, DBConsole, Engine, Filter, InfoController, MailersController, PluginBuilder, Railtie, Server, TestRequirer, TestUnitRailtie, TestUnitReporter, WelcomeController

Class Attribute Summary collapse

Class Method Summary collapse

Methods included from ActiveSupport::Autoload

autoload, autoload_at, autoload_under, autoloads, eager_autoload, eager_load!, extended

Class Attribute Details

.app_classObject

Returns the value of attribute app_class



35
36
37
# File 'railties/lib/rails.rb', line 35

def app_class
  @app_class
end

.applicationObject



36
37
38
# File 'railties/lib/rails.rb', line 36

def application
  @application ||= (app_class.instance if app_class)
end

.cacheObject

Returns the value of attribute cache



35
36
37
# File 'railties/lib/rails.rb', line 35

def cache
  @cache
end

.loggerObject

Returns the value of attribute logger



35
36
37
# File 'railties/lib/rails.rb', line 35

def logger
  @logger
end

Class Method Details

.backtrace_cleanerObject



47
48
49
50
51
52
53
# File 'railties/lib/rails.rb', line 47

def backtrace_cleaner
  @backtrace_cleaner ||= begin
    # Relies on Active Support, so we have to lazy load to postpone definition until AS has been loaded
    require 'rails/backtrace_cleaner'
    Rails::BacktraceCleaner.new
  end
end

.configurationObject

The Configuration instance used to configure the Rails environment



43
44
45
# File 'railties/lib/rails.rb', line 43

def configuration
  application.config
end

.envObject

Returns the current Rails environment.

Rails.env # => "development"
Rails.env.development? # => true
Rails.env.production? # => false


69
70
71
# File 'railties/lib/rails.rb', line 69

def env
  @_env ||= ActiveSupport::StringInquirer.new(ENV["RAILS_ENV"] || ENV["RACK_ENV"] || "development")
end

.env=(environment) ⇒ Object

Sets the Rails environment.

Rails.env = "staging" # => "staging"


76
77
78
# File 'railties/lib/rails.rb', line 76

def env=(environment)
  @_env = ActiveSupport::StringInquirer.new(environment)
end

.gem_versionObject

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



3
4
5
# File 'railties/lib/rails/gem_version.rb', line 3

def self.gem_version
  Gem::Version.new VERSION::STRING
end

.groups(*groups) ⇒ Object

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 Rails.env == “development” # => [:default, :production] for Rails.env == “production”



91
92
93
94
95
96
97
98
99
100
# File 'railties/lib/rails.rb', line 91

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_pathObject

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>


107
108
109
# File 'railties/lib/rails.rb', line 107

def public_path
  application && Pathname.new(application.paths["public"].first)
end

.rootObject

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>


60
61
62
# File 'railties/lib/rails.rb', line 60

def root
  application && application.config.root
end

.versionObject

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



5
6
7
# File 'railties/lib/rails/version.rb', line 5

def self.version
  VERSION::STRING
end