diff options
| author | Misty De Meo | 2016-09-05 15:08:49 +1000 |
|---|---|---|
| committer | GitHub | 2016-09-05 15:08:49 +1000 |
| commit | efd29ebacaf6352e79c3e3a4c45b9e85c02c8a77 (patch) | |
| tree | e4ed530ed8451093b5d68615f6474c172e3e1991 | |
| parent | dfcbefff73e90eda5801d9892303e10fc31831b6 (diff) | |
| parent | b2ac693d4742e0d345ddb2dc3ac7b7bea07eb08e (diff) | |
| download | brew-efd29ebacaf6352e79c3e3a4c45b9e85c02c8a77.tar.bz2 | |
Merge pull request #878 from mistydemeo/fix_shell_profile
Fix shell profile
| -rw-r--r-- | Library/Homebrew/formula.rb | 2 | ||||
| -rw-r--r-- | Library/Homebrew/utils/shell.rb | 24 |
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 |
