module Rails::Command

Constants

HELP_MAPPINGS

Public Class Methods

invoke(full_namespace, args = [], **config) Show source
# File railties/lib/rails/command.rb, line 31
def invoke(full_namespace, args = [], **config)
  namespace = full_namespace = full_namespace.to_s

  if char = namespace =~ /:(\w+)$/
    command_name, namespace = $1, namespace.slice(0, char)
  else
    command_name = namespace
  end

  command_name, namespace = "help", "help" if command_name.blank? || HELP_MAPPINGS.include?(command_name)
  command_name, namespace = "version", "version" if %w( -v --version ).include?(command_name)

  # isolate ARGV to ensure that commands depend only on the args they are given
  args = args.dup # args might *be* ARGV so dup before clearing
  old_argv = ARGV.dup
  ARGV.clear

  command = find_by_namespace(namespace, command_name)
  if command && command.all_commands[command_name]
    command.perform(command_name, args, config)
  else
    find_by_namespace("rake").perform(full_namespace, args, config)
  end
ensure
  ARGV.replace(old_argv)
end

Receives a namespace, arguments and the behavior to invoke the command.

root() Show source
# File railties/lib/rails/command.rb, line 83
def root
  if defined?(ENGINE_ROOT)
    Pathname.new(ENGINE_ROOT)
  elsif defined?(APP_PATH)
    Pathname.new(File.expand_path("../..", APP_PATH))
  end
end

Returns the root of the Rails engine or app running the command.

Private Class Methods

command_type() Show source
# File railties/lib/rails/command.rb, line 107
def command_type # :doc:
  @command_type ||= "command"
end
file_lookup_paths() Show source
# File railties/lib/rails/command.rb, line 115
def file_lookup_paths # :doc:
  @file_lookup_paths ||= [ "{#{lookup_paths.join(',')}}", "**", "*_command.rb" ]
end
lookup_paths() Show source
# File railties/lib/rails/command.rb, line 111
def lookup_paths # :doc:
  @lookup_paths ||= %w( rails/commands commands )
end

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