diff options
| author | Mike McQuaid | 2018-02-23 08:48:12 +0000 |
|---|---|---|
| committer | GitHub | 2018-02-23 08:48:12 +0000 |
| commit | 16df75083715a9bb9597b40425f19b8bd1fb3d82 (patch) | |
| tree | 0f511c2b5feb746f13a1d61474ad3cd73cd38ef9 | |
| parent | 7ef6f4603641c0fcfb30d0777485e7b17a3fd4a1 (diff) | |
| parent | a1bf2c072c9d2064f304a1294c51b565e8a81853 (diff) | |
| download | brew-16df75083715a9bb9597b40425f19b8bd1fb3d82.tar.bz2 | |
Merge pull request #3827 from maxim-belkin/brew-unix-3
Cross-platform java detection
| -rw-r--r-- | Library/Homebrew/extend/os/mac/system_config.rb | 13 | ||||
| -rw-r--r-- | Library/Homebrew/system_config.rb | 12 |
2 files changed, 16 insertions, 9 deletions
diff --git a/Library/Homebrew/extend/os/mac/system_config.rb b/Library/Homebrew/extend/os/mac/system_config.rb index 796134781..c0a28d3e9 100644 --- a/Library/Homebrew/extend/os/mac/system_config.rb +++ b/Library/Homebrew/extend/os/mac/system_config.rb @@ -23,6 +23,19 @@ class SystemConfig @ponk.join(", ") unless @ponk.empty? end + def describe_java + # java_home doesn't exist on all macOSs; it might be missing on older versions. + return "N/A" unless File.executable? "/usr/libexec/java_home" + + java_xml = Utils.popen_read("/usr/libexec/java_home", "--xml", "--failfast", err: :close) + return "N/A" unless $CHILD_STATUS.success? + javas = [] + REXML::XPath.each(REXML::Document.new(java_xml), "//key[text()='JVMVersion']/following-sibling::string") do |item| + javas << item.text + end + javas.uniq.join(", ") + end + def describe_xquartz return "N/A" unless MacOS::XQuartz.installed? "#{MacOS::XQuartz.version} => #{describe_path(MacOS::XQuartz.prefix)}" diff --git a/Library/Homebrew/system_config.rb b/Library/Homebrew/system_config.rb index 28eecf951..63e162075 100644 --- a/Library/Homebrew/system_config.rb +++ b/Library/Homebrew/system_config.rb @@ -131,16 +131,10 @@ class SystemConfig end def describe_java - # java_home doesn't exist on all macOSs; it might be missing on older versions. - return "N/A" unless File.executable? "/usr/libexec/java_home" - - java_xml = Utils.popen_read("/usr/libexec/java_home", "--xml", "--failfast", err: :close) + return "N/A" unless which "java" + java_version = Utils.popen_read("java", "-version") return "N/A" unless $CHILD_STATUS.success? - javas = [] - REXML::XPath.each(REXML::Document.new(java_xml), "//key[text()='JVMVersion']/following-sibling::string") do |item| - javas << item.text - end - javas.uniq.join(", ") + java_version[/java version "([\d\._]+)"/, 1] || "N/A" end def describe_git |
