aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew
diff options
context:
space:
mode:
authorMisty De Meo2016-09-05 15:08:49 +1000
committerGitHub2016-09-05 15:08:49 +1000
commitefd29ebacaf6352e79c3e3a4c45b9e85c02c8a77 (patch)
treee4ed530ed8451093b5d68615f6474c172e3e1991 /Library/Homebrew
parentdfcbefff73e90eda5801d9892303e10fc31831b6 (diff)
parentb2ac693d4742e0d345ddb2dc3ac7b7bea07eb08e (diff)
downloadbrew-efd29ebacaf6352e79c3e3a4c45b9e85c02c8a77.tar.bz2
Merge pull request #878 from mistydemeo/fix_shell_profile
Fix shell profile
Diffstat (limited to 'Library/Homebrew')
-rw-r--r--Library/Homebrew/formula.rb2
-rw-r--r--Library/Homebrew/utils/shell.rb24
2 files changed, 18 insertions, 8 deletions
diff --git a/Library/Homebrew/formula.rb b/Library/Homebrew/formula.rb
index 9e7bd21ca..7e25fedd1 100644
--- a/Library/Homebrew/formula.rb
+++ b/Library/Homebrew/formula.rb
@@ -3,6 +3,7 @@ require "formula_lock"
require "formula_pin"
require "hardware"
require "utils/bottles"
+require "utils/shell"
require "build_environment"
require "build_options"
require "formulary"
@@ -41,6 +42,7 @@ require "migrator"
class Formula
include FileUtils
include Utils::Inreplace
+ include Utils::Shell
extend Enumerable
# @!method inreplace(paths, before = nil, after = nil)
diff --git a/Library/Homebrew/utils/shell.rb b/Library/Homebrew/utils/shell.rb
index c0d6b90ae..c1a8f95b7 100644
--- a/Library/Homebrew/utils/shell.rb
+++ b/Library/Homebrew/utils/shell.rb
@@ -14,23 +14,26 @@ module Utils
# take a path and heuristically convert it
# to a shell name, return nil if there's no match
- def self.path_to_shell(path)
+ def path_to_shell(path)
# we only care about the basename
shell_name = File.basename(path)
# handle possible version suffix like `zsh-5.2`
shell_name.sub!(/-.*\z/m, "")
shell_name.to_sym if %w[bash csh fish ksh sh tcsh zsh].include?(shell_name)
end
+ module_function :path_to_shell
- def self.preferred_shell
+ def preferred_shell
path_to_shell(ENV.fetch("SHELL", ""))
end
+ module_function :preferred_shell
- def self.parent_shell
+ def parent_shell
path_to_shell(`ps -p #{Process.ppid} -o ucomm=`.strip)
end
+ module_function :parent_shell
- def self.csh_quote(str)
+ def csh_quote(str)
# ruby's implementation of shell_escape
str = str.to_s
return "''" if str.empty?
@@ -41,8 +44,9 @@ module Utils
str.gsub!(/\n/, "'\\\n'")
str
end
+ module_function :csh_quote
- def self.sh_quote(str)
+ def sh_quote(str)
# ruby's implementation of shell_escape
str = str.to_s
return "''" if str.empty?
@@ -52,9 +56,10 @@ module Utils
str.gsub!(/\n/, "'\n'")
str
end
+ module_function :sh_quote
# quote values. quoting keys is overkill
- def self.export_value(shell, key, value)
+ def export_value(shell, key, value)
case shell
when :bash, :ksh, :sh, :zsh
"export #{key}=\"#{sh_quote(value)}\""
@@ -67,13 +72,15 @@ module Utils
"setenv #{key} #{csh_quote(value)};"
end
end
+ module_function :export_value
# return the shell profile file based on users' preferred shell
- def self.shell_profile
+ def shell_profile
SHELL_PROFILE_MAP.fetch(preferred_shell, "~/.bash_profile")
end
+ module_function :shell_profile
- def self.prepend_path_in_shell_profile(path)
+ def prepend_path_in_shell_profile(path)
case preferred_shell
when :bash, :ksh, :sh, :zsh, nil
"echo 'export PATH=\"#{sh_quote(path)}:$PATH\"' >> #{shell_profile}"
@@ -83,5 +90,6 @@ module Utils
"echo 'set -g fish_user_paths \"#{sh_quote(path)}\" $fish_user_paths' >> #{shell_profile}"
end
end
+ module_function :prepend_path_in_shell_profile
end
end