command: support .sh commands

Closes Homebrew/homebrew#48192.

Signed-off-by: Baptiste Fontaine <batifon@yahoo.fr>
This commit is contained in:
Baptiste Fontaine 2016-01-18 01:22:35 +01:00
parent c1e673e19a
commit 5775d3b326
2 changed files with 35 additions and 4 deletions

View File

@ -4,9 +4,7 @@ module Homebrew
cmd = ARGV.first
cmd = HOMEBREW_INTERNAL_COMMAND_ALIASES.fetch(cmd, cmd)
if (path = HOMEBREW_LIBRARY_PATH/"cmd/#{cmd}.rb").file?
puts path
elsif ARGV.homebrew_developer? && (path = HOMEBREW_LIBRARY_PATH/"dev-cmd/#{cmd}.rb").file?
if (path = internal_command_path cmd)
puts path
elsif (path = which("brew-#{cmd}") || which("brew-#{cmd}.rb"))
puts path
@ -14,4 +12,17 @@ module Homebrew
odie "Unknown command: #{cmd}"
end
end
private
def internal_command_path(cmd)
extensions = %w[rb sh]
paths = extensions.map { |ext| HOMEBREW_LIBRARY_PATH/"cmd/#{cmd}.#{ext}" }
if ARGV.homebrew_developer?
paths += extensions.map { |ext| HOMEBREW_LIBRARY_PATH/"dev-cmd/#{cmd}.#{ext}" }
end
paths.find { |p| p.file? }
end
end

View File

@ -1,8 +1,9 @@
require "testing_env"
require "cmd/command"
require "cmd/commands"
require "fileutils"
class CommandsCommandTests < Homebrew::TestCase
class CommandsTests < Homebrew::TestCase
def setup
@cmds = [
# internal commands
@ -59,4 +60,23 @@ class CommandsCommandTests < Homebrew::TestCase
ensure
ENV.replace(env)
end
def test_internal_command_path
assert_equal HOMEBREW_LIBRARY_PATH/"cmd/rbcmd.rb",
Homebrew.send(:internal_command_path, "rbcmd")
assert_equal HOMEBREW_LIBRARY_PATH/"cmd/shcmd.sh",
Homebrew.send(:internal_command_path, "shcmd")
assert_nil Homebrew.send(:internal_command_path, "idontexist1234")
end
def test_internal_dev_command_path
ARGV.stubs(:homebrew_developer?).returns false
assert_nil Homebrew.send(:internal_command_path, "rbdevcmd")
ARGV.stubs(:homebrew_developer?).returns true
assert_equal HOMEBREW_LIBRARY_PATH/"dev-cmd/rbdevcmd.rb",
Homebrew.send(:internal_command_path, "rbdevcmd")
assert_equal HOMEBREW_LIBRARY_PATH/"dev-cmd/shdevcmd.sh",
Homebrew.send(:internal_command_path, "shdevcmd")
end
end