2012-06-11 12:57:51 -07:00
|
|
|
require 'cmd/missing'
|
|
|
|
|
2010-06-28 09:39:14 -07:00
|
|
|
class Volumes
|
|
|
|
def initialize
|
2012-06-22 02:30:00 -02:30
|
|
|
@volumes = get_mounts
|
2010-06-28 09:39:14 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
def which path
|
2012-06-22 02:30:00 -02:30
|
|
|
vols = get_mounts path
|
|
|
|
|
|
|
|
# no volume found
|
|
|
|
if vols.empty?
|
|
|
|
return -1
|
|
|
|
end
|
|
|
|
|
|
|
|
vol_index = @volumes.index(vols[0])
|
|
|
|
# volume not found in volume list
|
|
|
|
if vol_index.nil?
|
|
|
|
return -1
|
2010-06-28 09:39:14 -07:00
|
|
|
end
|
2012-06-22 02:30:00 -02:30
|
|
|
return vol_index
|
|
|
|
end
|
2010-06-28 09:39:14 -07:00
|
|
|
|
2012-06-22 02:30:00 -02:30
|
|
|
def get_mounts path=nil
|
|
|
|
vols = []
|
|
|
|
# get the volume of path, if path is nil returns all volumes
|
|
|
|
raw_df = `/bin/df -P #{path}`
|
|
|
|
raw_df.split("\n").each do |line|
|
|
|
|
case line
|
|
|
|
# regex matches: /dev/disk0s2 489562928 440803616 48247312 91% /
|
|
|
|
when /^(.*)\s+([0-9]+)\s+([0-9]+)\s+([0-9]+)\s+([0-9]{1,3}\%)\s+(.*)/
|
|
|
|
vols << $6
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return vols
|
2010-06-28 09:39:14 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
class Checks
|
|
|
|
# Sorry for the lack of an indent here, the diff would have been unreadable.
|
|
|
|
|
2012-08-14 11:23:30 -04:00
|
|
|
############# HELPERS
|
2011-06-07 13:18:00 -07:00
|
|
|
def remove_trailing_slash s
|
|
|
|
(s[s.length-1] == '/') ? s[0,s.length-1] : s
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2012-12-21 17:16:24 -06:00
|
|
|
def paths
|
|
|
|
@paths ||= ENV['PATH'].split(':').collect do |p|
|
|
|
|
begin
|
|
|
|
remove_trailing_slash(File.expand_path(p))
|
2012-05-10 14:15:23 -05:00
|
|
|
rescue ArgumentError
|
|
|
|
onoe "The following PATH component is invalid: #{p}"
|
|
|
|
end
|
|
|
|
end.uniq.compact
|
2011-03-29 12:45:54 -07:00
|
|
|
end
|
|
|
|
|
2012-08-14 11:23:30 -04:00
|
|
|
# Finds files in HOMEBREW_PREFIX *and* /usr/local.
|
|
|
|
# Specify paths relative to a prefix eg. "include/foo.h".
|
|
|
|
# Sets @found for your convenience.
|
|
|
|
def find_relative_paths *relative_paths
|
|
|
|
@found = %W[#{HOMEBREW_PREFIX} /usr/local].uniq.inject([]) do |found, prefix|
|
|
|
|
found + relative_paths.map{|f| File.join(prefix, f) }.select{|f| File.exist? f }
|
|
|
|
end
|
|
|
|
end
|
2012-12-22 12:48:53 -06:00
|
|
|
|
|
|
|
def inject_file_list(list, str)
|
|
|
|
list.inject(str) { |s, f| s << " #{f}\n" }
|
|
|
|
end
|
2012-08-14 11:23:30 -04:00
|
|
|
############# END HELPERS
|
2011-03-29 12:45:54 -07:00
|
|
|
|
2012-03-21 22:03:21 -07:00
|
|
|
# See https://github.com/mxcl/homebrew/pull/9986
|
|
|
|
def check_path_for_trailing_slashes
|
|
|
|
bad_paths = ENV['PATH'].split(':').select{|p| p[p.length-1, p.length] == '/'}
|
|
|
|
return if bad_paths.empty?
|
|
|
|
s = <<-EOS.undent
|
|
|
|
Some directories in your path end in a slash.
|
|
|
|
Directories in your path should not end in a slash. This can break other
|
|
|
|
doctor checks. The following directories should be edited:
|
|
|
|
EOS
|
|
|
|
bad_paths.each{|p| s << " #{p}"}
|
|
|
|
s
|
|
|
|
end
|
|
|
|
|
2010-08-18 09:09:38 -07:00
|
|
|
# Installing MacGPG2 interferes with Homebrew in a big way
|
|
|
|
# http://sourceforge.net/projects/macgpg2/files/
|
|
|
|
def check_for_macgpg2
|
2012-12-21 17:14:01 -06:00
|
|
|
if %w{/Applications/start-gpg-agent.app
|
|
|
|
/Library/Receipts/libiconv1.pkg
|
|
|
|
/usr/local/MacGPG2}.any? { |f| File.exist? f }
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
|
|
|
You may have installed MacGPG2 via the package installer.
|
|
|
|
Several other checks in this script will turn up problems, such as stray
|
|
|
|
dylibs in /usr/local and permissions issues with share and man in /usr/local/.
|
2010-08-18 09:09:38 -07:00
|
|
|
EOS
|
2012-06-19 09:24:40 -05:00
|
|
|
end unless File.exist? '/usr/local/MacGPG2/share/gnupg/VERSION'
|
2010-08-18 09:09:38 -07:00
|
|
|
end
|
2010-06-28 09:39:14 -07:00
|
|
|
|
2010-03-31 14:58:32 -07:00
|
|
|
def check_for_stray_dylibs
|
2010-06-29 10:10:53 -07:00
|
|
|
unbrewed_dylibs = Dir['/usr/local/lib/*.dylib'].select { |f| File.file? f and not File.symlink? f }
|
|
|
|
|
|
|
|
# Dylibs which are generally OK should be added to this list,
|
|
|
|
# with a short description of the software they come with.
|
|
|
|
white_list = {
|
|
|
|
"libfuse.2.dylib" => "MacFuse",
|
|
|
|
"libfuse_ino64.2.dylib" => "MacFuse"
|
|
|
|
}
|
|
|
|
|
|
|
|
bad_dylibs = unbrewed_dylibs.reject {|d| white_list.key? File.basename(d) }
|
|
|
|
return if bad_dylibs.empty?
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
s = <<-EOS.undent
|
2011-03-28 11:51:54 -07:00
|
|
|
Unbrewed dylibs were found in /usr/local/lib.
|
|
|
|
If you didn't put them there on purpose they could cause problems when
|
|
|
|
building Homebrew formulae, and may need to be deleted.
|
|
|
|
|
|
|
|
Unexpected dylibs:
|
2010-06-29 10:10:53 -07:00
|
|
|
EOS
|
2012-12-22 12:48:53 -06:00
|
|
|
inject_file_list(bad_dylibs, s)
|
2010-03-31 14:58:32 -07:00
|
|
|
end
|
|
|
|
|
2011-05-05 09:40:03 -07:00
|
|
|
def check_for_stray_static_libs
|
|
|
|
unbrewed_alibs = Dir['/usr/local/lib/*.a'].select { |f| File.file? f and not File.symlink? f }
|
2012-11-26 09:41:02 +00:00
|
|
|
|
|
|
|
# Static libs which are generally OK should be added to this list,
|
|
|
|
# with a short description of the software they come with.
|
|
|
|
white_list = {
|
|
|
|
"libsecurity_agent_client.a" => "OS X 10.8.2 Supplemental Update",
|
|
|
|
"libsecurity_agent_server.a" => "OS X 10.8.2 Supplemental Update"
|
|
|
|
}
|
|
|
|
|
|
|
|
bad_alibs = unbrewed_alibs.reject {|d| white_list.key? File.basename(d) }
|
|
|
|
return if bad_alibs.empty?
|
2011-05-05 09:40:03 -07:00
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
s = <<-EOS.undent
|
2011-05-05 09:40:03 -07:00
|
|
|
Unbrewed static libraries were found in /usr/local/lib.
|
|
|
|
If you didn't put them there on purpose they could cause problems when
|
|
|
|
building Homebrew formulae, and may need to be deleted.
|
|
|
|
|
|
|
|
Unexpected static libraries:
|
|
|
|
EOS
|
2012-12-22 12:48:53 -06:00
|
|
|
inject_file_list(bad_alibs, s)
|
2011-05-05 09:40:03 -07:00
|
|
|
end
|
|
|
|
|
2011-05-09 17:23:35 -07:00
|
|
|
def check_for_stray_pcs
|
|
|
|
unbrewed_pcs = Dir['/usr/local/lib/pkgconfig/*.pc'].select { |f| File.file? f and not File.symlink? f }
|
|
|
|
|
|
|
|
# Package-config files which are generally OK should be added to this list,
|
|
|
|
# with a short description of the software they come with.
|
2012-11-03 15:44:51 -07:00
|
|
|
white_list = { }
|
2011-05-09 17:23:35 -07:00
|
|
|
|
|
|
|
bad_pcs = unbrewed_pcs.reject {|d| white_list.key? File.basename(d) }
|
|
|
|
return if bad_pcs.empty?
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
s = <<-EOS.undent
|
2011-05-09 17:23:35 -07:00
|
|
|
Unbrewed .pc files were found in /usr/local/lib/pkgconfig.
|
|
|
|
If you didn't put them there on purpose they could cause problems when
|
|
|
|
building Homebrew formulae, and may need to be deleted.
|
|
|
|
|
|
|
|
Unexpected .pc files:
|
|
|
|
EOS
|
2012-12-22 12:48:53 -06:00
|
|
|
inject_file_list(bad_pcs, s)
|
2011-05-09 17:23:35 -07:00
|
|
|
end
|
|
|
|
|
2011-05-12 08:10:47 -07:00
|
|
|
def check_for_stray_las
|
|
|
|
unbrewed_las = Dir['/usr/local/lib/*.la'].select { |f| File.file? f and not File.symlink? f }
|
|
|
|
|
|
|
|
white_list = {
|
|
|
|
"libfuse.la" => "MacFuse",
|
|
|
|
"libfuse_ino64.la" => "MacFuse",
|
|
|
|
}
|
|
|
|
|
|
|
|
bad_las = unbrewed_las.reject {|d| white_list.key? File.basename(d) }
|
|
|
|
return if bad_las.empty?
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
s = <<-EOS.undent
|
2011-05-12 08:10:47 -07:00
|
|
|
Unbrewed .la files were found in /usr/local/lib.
|
|
|
|
If you didn't put them there on purpose they could cause problems when
|
|
|
|
building Homebrew formulae, and may need to be deleted.
|
|
|
|
|
|
|
|
Unexpected .la files:
|
|
|
|
EOS
|
2012-12-22 12:48:53 -06:00
|
|
|
inject_file_list(bad_las, s)
|
2011-05-12 08:10:47 -07:00
|
|
|
end
|
|
|
|
|
2010-03-31 15:00:40 -07:00
|
|
|
def check_for_other_package_managers
|
2012-12-17 17:05:53 -06:00
|
|
|
ponk = MacOS.macports_or_fink
|
|
|
|
unless ponk.empty?
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
2012-12-17 17:05:53 -06:00
|
|
|
You have MacPorts or Fink installed:
|
|
|
|
#{ponk.join(", ")}
|
|
|
|
|
|
|
|
This can cause trouble. You don't have to uninstall them, but you may want to
|
|
|
|
temporarily move them out of the way, e.g.
|
2010-03-31 15:22:20 -07:00
|
|
|
|
|
|
|
sudo mv /opt/local ~/macports
|
|
|
|
EOS
|
2010-03-31 15:00:40 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-15 16:37:46 +00:00
|
|
|
def check_for_broken_symlinks
|
2012-11-05 18:08:52 -06:00
|
|
|
require 'keg'
|
2012-03-15 16:37:46 +00:00
|
|
|
broken_symlinks = []
|
2013-01-07 17:50:23 -06:00
|
|
|
Keg::PRUNEABLE_DIRECTORIES.each do |d|
|
2012-04-17 17:08:36 -05:00
|
|
|
next unless d.directory?
|
2012-03-15 16:37:46 +00:00
|
|
|
d.find do |pn|
|
|
|
|
broken_symlinks << pn if pn.symlink? and pn.readlink.expand_path.to_s =~ /^#{HOMEBREW_PREFIX}/ and not pn.exist?
|
|
|
|
end
|
|
|
|
end
|
|
|
|
unless broken_symlinks.empty? then <<-EOS.undent
|
2012-06-26 11:21:46 +02:00
|
|
|
Broken symlinks were found. Remove them with `brew prune`:
|
2012-03-15 16:37:46 +00:00
|
|
|
#{broken_symlinks * "\n "}
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-19 11:26:39 -05:00
|
|
|
def check_for_latest_xcode
|
2012-07-09 14:58:34 -05:00
|
|
|
if not MacOS::Xcode.installed?
|
2012-08-17 17:18:17 -04:00
|
|
|
if MacOS.version >= 10.7
|
2012-07-09 14:58:34 -05:00
|
|
|
if not MacOS::CLT.installed?
|
2012-08-17 17:18:17 -04:00
|
|
|
<<-EOS.undent
|
|
|
|
No developer tools installed
|
|
|
|
You should install the Command Line Tools: http://connect.apple.com
|
Core change: XCode only install, with CLT or both
Allow XCode without the Command Line Tools to
work with homebrew, so it's not necessary
to register an Apple Dev ID and/or go to the
XCode prefs and download the CLT. Yay!
Further, this commit allows to use the CLT
solely (without the need for XCode).
Saves quite some megs.
(Some furmulae require xcodebuild)
Of course XCode together with the CLT is still
fine and has been tested on 10.7 and 10.6
with Xcode 4 and Xcode 3.
Only on Lion or above, tell the user about the options,
which are
- Xcode without CLT
- CLT without Xcode
- both (ok, it's not directly stated, but implicit)
So if no Xcode is found and we are on Lion or above,
we don't fail but check for the CLTs now.
For older Macs, the old message that Xcode is needed
and the installer should be run is still displayed.
If the CLT are not found but Xcode is, then we
print out about the experimental status of this setup.
Closes Homebrew/homebrew#10510.
Signed-off-by: Adam Vandenberg <flangy@gmail.com>
2012-02-26 21:04:15 +01:00
|
|
|
EOS
|
2012-08-17 17:18:17 -04:00
|
|
|
elsif not MacOS::CLT.latest_version?
|
|
|
|
<<-EOS.undent
|
2013-01-28 23:02:25 -06:00
|
|
|
A newer Command Line Tools for Xcode release is available
|
2012-08-17 17:18:17 -04:00
|
|
|
You should install the latest version from: http://connect.apple.com
|
Core change: XCode only install, with CLT or both
Allow XCode without the Command Line Tools to
work with homebrew, so it's not necessary
to register an Apple Dev ID and/or go to the
XCode prefs and download the CLT. Yay!
Further, this commit allows to use the CLT
solely (without the need for XCode).
Saves quite some megs.
(Some furmulae require xcodebuild)
Of course XCode together with the CLT is still
fine and has been tested on 10.7 and 10.6
with Xcode 4 and Xcode 3.
Only on Lion or above, tell the user about the options,
which are
- Xcode without CLT
- CLT without Xcode
- both (ok, it's not directly stated, but implicit)
So if no Xcode is found and we are on Lion or above,
we don't fail but check for the CLTs now.
For older Macs, the old message that Xcode is needed
and the installer should be run is still displayed.
If the CLT are not found but Xcode is, then we
print out about the experimental status of this setup.
Closes Homebrew/homebrew#10510.
Signed-off-by: Adam Vandenberg <flangy@gmail.com>
2012-02-26 21:04:15 +01:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
else
|
2012-08-17 17:18:17 -04:00
|
|
|
<<-EOS.undent
|
|
|
|
Xcode not installed
|
|
|
|
Most stuff needs Xcode to build: http://developer.apple.com/xcode/
|
2012-03-21 12:47:25 -05:00
|
|
|
EOS
|
|
|
|
end
|
2012-08-17 17:18:17 -04:00
|
|
|
elsif MacOS::Xcode.version < MacOS::Xcode.latest_version then <<-EOS.undent
|
|
|
|
Your Xcode (#{MacOS::Xcode.version}) is outdated
|
|
|
|
Please install Xcode #{MacOS::Xcode.latest_version}.
|
2012-03-01 16:57:14 +00:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-09-10 12:38:17 -05:00
|
|
|
def check_for_stray_developer_directory
|
2012-09-16 14:06:50 -05:00
|
|
|
# if the uninstaller script isn't there, it's a good guess neither are
|
|
|
|
# any troublesome leftover Xcode files
|
|
|
|
if MacOS::Xcode.version >= "4.3" and File.exist? "/Developer/Library/uninstall-developer-folder"
|
2012-09-10 12:38:17 -05:00
|
|
|
return <<-EOS.undent
|
|
|
|
You have leftover files from an older version of Xcode.
|
|
|
|
You should delete them using:
|
|
|
|
/Developer/Library/uninstall-developer-folder
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
def check_cc
|
2012-07-09 14:58:34 -05:00
|
|
|
unless MacOS::CLT.installed?
|
|
|
|
if MacOS::Xcode.version >= "4.3"
|
Core change: XCode only install, with CLT or both
Allow XCode without the Command Line Tools to
work with homebrew, so it's not necessary
to register an Apple Dev ID and/or go to the
XCode prefs and download the CLT. Yay!
Further, this commit allows to use the CLT
solely (without the need for XCode).
Saves quite some megs.
(Some furmulae require xcodebuild)
Of course XCode together with the CLT is still
fine and has been tested on 10.7 and 10.6
with Xcode 4 and Xcode 3.
Only on Lion or above, tell the user about the options,
which are
- Xcode without CLT
- CLT without Xcode
- both (ok, it's not directly stated, but implicit)
So if no Xcode is found and we are on Lion or above,
we don't fail but check for the CLTs now.
For older Macs, the old message that Xcode is needed
and the installer should be run is still displayed.
If the CLT are not found but Xcode is, then we
print out about the experimental status of this setup.
Closes Homebrew/homebrew#10510.
Signed-off-by: Adam Vandenberg <flangy@gmail.com>
2012-02-26 21:04:15 +01:00
|
|
|
return <<-EOS.undent
|
|
|
|
Experimental support for using Xcode without the "Command Line Tools".
|
2012-08-06 13:24:56 -04:00
|
|
|
You have only installed Xcode. If stuff is not building, try installing the
|
2012-10-28 10:50:38 -04:00
|
|
|
"Command Line Tools for Xcode" package provided by Apple.
|
Core change: XCode only install, with CLT or both
Allow XCode without the Command Line Tools to
work with homebrew, so it's not necessary
to register an Apple Dev ID and/or go to the
XCode prefs and download the CLT. Yay!
Further, this commit allows to use the CLT
solely (without the need for XCode).
Saves quite some megs.
(Some furmulae require xcodebuild)
Of course XCode together with the CLT is still
fine and has been tested on 10.7 and 10.6
with Xcode 4 and Xcode 3.
Only on Lion or above, tell the user about the options,
which are
- Xcode without CLT
- CLT without Xcode
- both (ok, it's not directly stated, but implicit)
So if no Xcode is found and we are on Lion or above,
we don't fail but check for the CLTs now.
For older Macs, the old message that Xcode is needed
and the installer should be run is still displayed.
If the CLT are not found but Xcode is, then we
print out about the experimental status of this setup.
Closes Homebrew/homebrew#10510.
Signed-off-by: Adam Vandenberg <flangy@gmail.com>
2012-02-26 21:04:15 +01:00
|
|
|
EOS
|
|
|
|
else
|
|
|
|
return <<-EOS.undent
|
|
|
|
No compiler found in /usr/bin!
|
|
|
|
EOS
|
|
|
|
end
|
2011-09-07 12:18:05 +01:00
|
|
|
end
|
2010-03-31 15:06:46 -07:00
|
|
|
end
|
|
|
|
|
2012-04-08 11:10:22 -05:00
|
|
|
def check_standard_compilers
|
|
|
|
return if check_for_latest_xcode # only check if Xcode is up to date
|
2012-09-14 16:58:38 -05:00
|
|
|
compiler_status = MacOS.compilers_standard?
|
|
|
|
if not compiler_status and not compiler_status.nil? then <<-EOS.undent
|
2012-04-08 11:10:22 -05:00
|
|
|
Your compilers are different from the standard versions for your Xcode.
|
|
|
|
If you have Xcode 4.3 or newer, you should install the Command Line Tools for
|
|
|
|
Xcode from within Xcode's Download preferences.
|
|
|
|
Otherwise, you should reinstall Xcode.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-07-30 09:23:29 -07:00
|
|
|
def __check_subdir_access base
|
|
|
|
target = HOMEBREW_PREFIX+base
|
|
|
|
return unless target.exist?
|
2010-03-31 15:38:20 -07:00
|
|
|
|
|
|
|
cant_read = []
|
|
|
|
|
2010-07-30 09:23:29 -07:00
|
|
|
target.find do |d|
|
2010-03-31 15:38:20 -07:00
|
|
|
next unless d.directory?
|
2012-07-28 11:36:08 -07:00
|
|
|
cant_read << d unless d.writable_real?
|
2010-03-31 15:38:20 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
cant_read.sort!
|
2012-03-01 16:32:02 +00:00
|
|
|
if cant_read.length > 0 then
|
|
|
|
s = <<-EOS.undent
|
2011-12-10 17:14:38 -06:00
|
|
|
Some directories in #{target} aren't writable.
|
2010-03-31 15:38:20 -07:00
|
|
|
This can happen if you "sudo make install" software that isn't managed
|
|
|
|
by Homebrew. If a brew tries to add locale information to one of these
|
2011-12-10 17:14:38 -06:00
|
|
|
directories, then the install will fail during the link step.
|
2010-03-31 15:38:20 -07:00
|
|
|
You should probably `chown` them:
|
|
|
|
|
|
|
|
EOS
|
2012-03-01 16:32:02 +00:00
|
|
|
cant_read.each{ |f| s << " #{f}\n" }
|
|
|
|
s
|
2010-03-31 15:38:20 -07:00
|
|
|
end
|
2010-07-01 10:16:15 -07:00
|
|
|
end
|
|
|
|
|
2012-02-28 18:48:14 +00:00
|
|
|
def check_access_usr_local
|
|
|
|
return unless HOMEBREW_PREFIX.to_s == '/usr/local'
|
|
|
|
|
2012-12-21 17:12:00 -06:00
|
|
|
unless File.writable_real?("/usr/local") then <<-EOS.undent
|
2012-02-28 18:48:14 +00:00
|
|
|
The /usr/local directory is not writable.
|
2012-03-01 22:55:21 -06:00
|
|
|
Even if this directory was writable when you installed Homebrew, other
|
|
|
|
software may change permissions on this directory. Some versions of the
|
2012-02-28 18:48:14 +00:00
|
|
|
"InstantOn" component of Airfoil are known to do this.
|
|
|
|
|
|
|
|
You should probably change the ownership and permissions of /usr/local
|
|
|
|
back to your user account.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-07-30 09:23:29 -07:00
|
|
|
def check_access_share_locale
|
|
|
|
__check_subdir_access 'share/locale'
|
|
|
|
end
|
|
|
|
|
|
|
|
def check_access_share_man
|
|
|
|
__check_subdir_access 'share/man'
|
|
|
|
end
|
|
|
|
|
2011-03-28 11:48:45 -07:00
|
|
|
def __check_folder_access base, msg
|
|
|
|
folder = HOMEBREW_PREFIX+base
|
2012-07-28 11:36:08 -07:00
|
|
|
if folder.exist? and not folder.writable_real?
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
2011-03-28 11:48:45 -07:00
|
|
|
#{folder} isn't writable.
|
2010-07-01 10:16:15 -07:00
|
|
|
This can happen if you "sudo make install" software that isn't managed
|
2011-03-28 11:48:45 -07:00
|
|
|
by Homebrew.
|
|
|
|
|
|
|
|
#{msg}
|
2010-07-01 10:16:15 -07:00
|
|
|
|
2011-03-28 11:48:45 -07:00
|
|
|
You should probably `chown` #{folder}
|
2010-07-01 10:16:15 -07:00
|
|
|
EOS
|
|
|
|
end
|
2010-03-31 15:09:03 -07:00
|
|
|
end
|
|
|
|
|
2011-03-28 11:48:45 -07:00
|
|
|
def check_access_pkgconfig
|
|
|
|
__check_folder_access 'lib/pkgconfig',
|
2011-12-10 17:14:38 -06:00
|
|
|
'If a brew tries to write a .pc file to this directory, the install will\n'+
|
2011-03-28 11:48:45 -07:00
|
|
|
'fail during the link step.'
|
|
|
|
end
|
2010-09-29 11:56:58 -07:00
|
|
|
|
2011-03-28 11:48:45 -07:00
|
|
|
def check_access_include
|
|
|
|
__check_folder_access 'include',
|
2011-12-10 17:14:38 -06:00
|
|
|
'If a brew tries to write a header file to this directory, the install will\n'+
|
2011-03-28 11:48:45 -07:00
|
|
|
'fail during the link step.'
|
2010-09-29 11:56:58 -07:00
|
|
|
end
|
|
|
|
|
2010-10-20 19:28:46 -07:00
|
|
|
def check_access_etc
|
2011-03-28 11:48:45 -07:00
|
|
|
__check_folder_access 'etc',
|
2011-12-10 17:14:38 -06:00
|
|
|
'If a brew tries to write a file to this directory, the install will\n'+
|
2011-03-28 11:48:45 -07:00
|
|
|
'fail during the link step.'
|
|
|
|
end
|
2010-10-20 19:28:46 -07:00
|
|
|
|
2011-03-28 11:48:45 -07:00
|
|
|
def check_access_share
|
|
|
|
__check_folder_access 'share',
|
2011-12-10 17:14:38 -06:00
|
|
|
'If a brew tries to write a file to this directory, the install will\n'+
|
2011-03-28 11:48:45 -07:00
|
|
|
'fail during the link step.'
|
2010-10-20 19:28:46 -07:00
|
|
|
end
|
|
|
|
|
2013-01-23 20:12:55 -08:00
|
|
|
def check_access_logs
|
|
|
|
folder = Pathname.new('~/Library/Logs/Homebrew')
|
|
|
|
if folder.exist? and not folder.writable_real?
|
|
|
|
<<-EOS.undent
|
|
|
|
#{folder} isn't writable.
|
|
|
|
This can happen if you "sudo make install" software that isn't managed
|
|
|
|
by Homebrew.
|
|
|
|
|
|
|
|
Homebrew writes debugging logs to this location.
|
|
|
|
|
|
|
|
You should probably `chown` #{folder}
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-03-31 15:09:03 -07:00
|
|
|
def check_usr_bin_ruby
|
2010-03-31 15:19:19 -07:00
|
|
|
if /^1\.9/.match RUBY_VERSION
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
2010-03-31 15:19:19 -07:00
|
|
|
Ruby version #{RUBY_VERSION} is unsupported.
|
|
|
|
Homebrew is developed and tested on Ruby 1.8.x, and may not work correctly
|
2012-03-01 16:32:02 +00:00
|
|
|
on other Rubies. Patches are accepted as long as they don't break on 1.8.x.
|
2010-03-31 15:19:19 -07:00
|
|
|
EOS
|
|
|
|
end
|
2010-03-31 15:09:03 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
def check_homebrew_prefix
|
2010-03-31 15:20:13 -07:00
|
|
|
unless HOMEBREW_PREFIX.to_s == '/usr/local'
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
|
|
|
Your Homebrew is not installed to /usr/local
|
2011-07-29 14:33:59 +01:00
|
|
|
You can install Homebrew anywhere you want, but some brews may only build
|
2012-03-01 16:32:02 +00:00
|
|
|
correctly if you install in /usr/local. Sorry!
|
2010-03-31 15:20:13 -07:00
|
|
|
EOS
|
|
|
|
end
|
2010-03-31 15:09:03 -07:00
|
|
|
end
|
|
|
|
|
2011-09-01 09:39:17 -07:00
|
|
|
def check_xcode_prefix
|
2012-07-09 14:58:34 -05:00
|
|
|
prefix = MacOS::Xcode.prefix
|
2011-09-01 09:39:17 -07:00
|
|
|
return if prefix.nil?
|
|
|
|
if prefix.to_s.match(' ')
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
2011-12-10 17:14:38 -06:00
|
|
|
Xcode is installed to a directory with a space in the name.
|
2012-02-25 03:25:43 -06:00
|
|
|
This will cause some formulae to fail to build.
|
2011-09-01 09:39:17 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-10-24 11:16:57 -07:00
|
|
|
def check_xcode_prefix_exists
|
|
|
|
prefix = MacOS::Xcode.prefix
|
|
|
|
return if prefix.nil?
|
|
|
|
unless prefix.exist?
|
|
|
|
<<-EOS.undent
|
|
|
|
The folder Xcode is reportedly installed to doesn't exist:
|
|
|
|
#{prefix}
|
|
|
|
You may need to `xcode-select` the proper path if you have moved Xcode.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-01 10:19:43 +00:00
|
|
|
def check_xcode_select_path
|
Core change: XCode only install, with CLT or both
Allow XCode without the Command Line Tools to
work with homebrew, so it's not necessary
to register an Apple Dev ID and/or go to the
XCode prefs and download the CLT. Yay!
Further, this commit allows to use the CLT
solely (without the need for XCode).
Saves quite some megs.
(Some furmulae require xcodebuild)
Of course XCode together with the CLT is still
fine and has been tested on 10.7 and 10.6
with Xcode 4 and Xcode 3.
Only on Lion or above, tell the user about the options,
which are
- Xcode without CLT
- CLT without Xcode
- both (ok, it's not directly stated, but implicit)
So if no Xcode is found and we are on Lion or above,
we don't fail but check for the CLTs now.
For older Macs, the old message that Xcode is needed
and the installer should be run is still displayed.
If the CLT are not found but Xcode is, then we
print out about the experimental status of this setup.
Closes Homebrew/homebrew#10510.
Signed-off-by: Adam Vandenberg <flangy@gmail.com>
2012-02-26 21:04:15 +01:00
|
|
|
# with the advent of CLT-only support, we don't need xcode-select
|
2012-08-06 19:28:39 -04:00
|
|
|
|
|
|
|
if MacOS::Xcode.bad_xcode_select_path?
|
|
|
|
<<-EOS.undent
|
|
|
|
Your xcode-select path is set to /
|
|
|
|
You must unset it or builds will hang:
|
2012-08-21 11:57:28 -04:00
|
|
|
sudo rm /usr/share/xcode-select/xcode_dir_*
|
2012-08-06 19:28:39 -04:00
|
|
|
EOS
|
|
|
|
elsif not MacOS::CLT.installed? and not File.file? "#{MacOS::Xcode.folder}/usr/bin/xcodebuild"
|
2012-07-09 14:58:34 -05:00
|
|
|
path = MacOS.app_with_bundle_id(MacOS::Xcode::V4_BUNDLE_ID) || MacOS.app_with_bundle_id(MacOS::Xcode::V3_BUNDLE_ID)
|
2012-06-26 12:19:12 +02:00
|
|
|
path = '/Developer' if path.nil? or not path.directory?
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
|
|
|
Your Xcode is configured with an invalid path.
|
2012-06-26 12:19:12 +02:00
|
|
|
You should change it to the correct path:
|
|
|
|
sudo xcode-select -switch #{path}
|
2012-03-01 10:19:43 +00:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
def check_user_path_1
|
|
|
|
$seen_prefix_bin = false
|
|
|
|
$seen_prefix_sbin = false
|
2010-03-31 15:55:44 -07:00
|
|
|
seen_usr_bin = false
|
2010-04-08 17:50:51 -07:00
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
out = nil
|
|
|
|
|
2012-12-21 17:16:24 -06:00
|
|
|
paths.each do |p|
|
|
|
|
case p
|
2011-08-31 15:38:11 +01:00
|
|
|
when '/usr/bin'
|
2010-03-31 15:55:44 -07:00
|
|
|
seen_usr_bin = true
|
2012-03-01 16:32:02 +00:00
|
|
|
unless $seen_prefix_bin
|
2011-08-31 15:38:11 +01:00
|
|
|
# only show the doctor message if there are any conflicts
|
|
|
|
# rationale: a default install should not trigger any brew doctor messages
|
2012-02-20 18:25:13 +00:00
|
|
|
conflicts = Dir["#{HOMEBREW_PREFIX}/bin/*"].
|
2012-02-21 15:50:35 +00:00
|
|
|
map{ |fn| File.basename fn }.
|
|
|
|
select{ |bn| File.exist? "/usr/bin/#{bn}" }
|
|
|
|
|
2012-03-01 16:59:18 +00:00
|
|
|
if conflicts.size > 0
|
2012-03-01 16:32:02 +00:00
|
|
|
out = <<-EOS.undent
|
|
|
|
/usr/bin occurs before #{HOMEBREW_PREFIX}/bin
|
2011-08-31 15:38:11 +01:00
|
|
|
This means that system-provided programs will be used instead of those
|
2012-02-20 18:25:13 +00:00
|
|
|
provided by Homebrew. The following tools exist at both paths:
|
2011-08-31 15:38:11 +01:00
|
|
|
|
2012-02-21 15:50:35 +00:00
|
|
|
#{conflicts * "\n "}
|
2012-02-20 18:25:13 +00:00
|
|
|
|
2012-04-03 12:16:40 -03:00
|
|
|
Consider amending your PATH so that #{HOMEBREW_PREFIX}/bin
|
2012-07-24 12:28:02 -07:00
|
|
|
occurs before /usr/bin in your PATH.
|
2011-08-31 15:38:11 +01:00
|
|
|
EOS
|
|
|
|
end
|
2010-03-31 15:55:44 -07:00
|
|
|
end
|
2011-08-31 15:38:11 +01:00
|
|
|
when "#{HOMEBREW_PREFIX}/bin"
|
2012-03-01 16:32:02 +00:00
|
|
|
$seen_prefix_bin = true
|
2011-08-31 15:38:11 +01:00
|
|
|
when "#{HOMEBREW_PREFIX}/sbin"
|
2012-03-01 16:32:02 +00:00
|
|
|
$seen_prefix_sbin = true
|
2010-03-31 15:55:44 -07:00
|
|
|
end
|
|
|
|
end
|
2012-03-01 16:32:02 +00:00
|
|
|
out
|
|
|
|
end
|
2010-04-08 17:50:51 -07:00
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
def check_user_path_2
|
|
|
|
unless $seen_prefix_bin
|
|
|
|
<<-EOS.undent
|
|
|
|
Homebrew's bin was not found in your path.
|
2012-04-03 12:16:40 -03:00
|
|
|
Consider amending your PATH variable so it contains:
|
2010-04-08 17:50:51 -07:00
|
|
|
#{HOMEBREW_PREFIX}/bin
|
2012-03-01 16:32:02 +00:00
|
|
|
EOS
|
2010-04-08 17:50:51 -07:00
|
|
|
end
|
2012-03-01 16:32:02 +00:00
|
|
|
end
|
2010-04-08 17:50:51 -07:00
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
def check_user_path_3
|
2011-06-02 09:27:11 -07:00
|
|
|
# Don't complain about sbin not being in the path if it doesn't exist
|
2011-08-02 14:44:09 +01:00
|
|
|
sbin = (HOMEBREW_PREFIX+'sbin')
|
|
|
|
if sbin.directory? and sbin.children.length > 0
|
2012-03-01 16:32:02 +00:00
|
|
|
unless $seen_prefix_sbin
|
|
|
|
<<-EOS.undent
|
|
|
|
Homebrew's sbin was not found in your path.
|
2012-04-03 12:16:40 -03:00
|
|
|
Consider amending your PATH variable so it contains:
|
2011-06-02 09:27:11 -07:00
|
|
|
#{HOMEBREW_PREFIX}/sbin
|
2012-03-01 16:32:02 +00:00
|
|
|
EOS
|
2011-06-02 09:27:11 -07:00
|
|
|
end
|
2010-03-31 15:55:44 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-10-08 14:00:20 +13:00
|
|
|
def check_user_curlrc
|
2012-11-06 19:00:54 -06:00
|
|
|
if %w[CURL_HOME HOME].any?{|key| ENV[key] and File.exists? "#{ENV[key]}/.curlrc" } then <<-EOS.undent
|
2012-10-08 14:00:20 +13:00
|
|
|
You have a curlrc file
|
|
|
|
If you have trouble downloading packages with Homebrew, then maybe this
|
|
|
|
is the problem? If the following command doesn't work, then try removing
|
|
|
|
your curlrc:
|
|
|
|
curl http://github.com
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-04-20 12:20:57 -07:00
|
|
|
def check_which_pkg_config
|
2012-06-12 00:17:36 -05:00
|
|
|
binary = which 'pkg-config'
|
|
|
|
return if binary.nil?
|
2010-04-03 09:43:17 -07:00
|
|
|
|
2012-06-17 10:59:01 -05:00
|
|
|
mono_config = Pathname.new("/usr/bin/pkg-config")
|
|
|
|
if mono_config.exist? && mono_config.realpath.to_s.include?("Mono.framework") then <<-EOS.undent
|
|
|
|
You have a non-Homebrew 'pkg-config' in your PATH:
|
|
|
|
/usr/bin/pkg-config => #{mono_config.realpath}
|
|
|
|
|
|
|
|
This was most likely created by the Mono installer. `./configure` may
|
|
|
|
have problems finding brew-installed packages using this other pkg-config.
|
|
|
|
EOS
|
|
|
|
elsif binary.to_s != "#{HOMEBREW_PREFIX}/bin/pkg-config" then <<-EOS.undent
|
2012-06-12 00:17:36 -05:00
|
|
|
You have a non-Homebrew 'pkg-config' in your PATH:
|
|
|
|
#{binary}
|
2010-04-03 09:43:17 -07:00
|
|
|
|
2012-06-12 00:17:36 -05:00
|
|
|
`./configure` may have problems finding brew-installed packages using
|
|
|
|
this other pkg-config.
|
2010-04-03 09:43:17 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-05-01 10:50:14 -07:00
|
|
|
def check_for_gettext
|
2012-12-21 18:03:24 -06:00
|
|
|
find_relative_paths("lib/libgettextlib.dylib",
|
|
|
|
"lib/libintl.dylib",
|
|
|
|
"include/libintl.h")
|
2010-05-01 10:50:14 -07:00
|
|
|
|
2012-12-21 18:03:24 -06:00
|
|
|
return if @found.empty?
|
2010-06-24 17:05:57 -07:00
|
|
|
|
2012-12-21 18:03:24 -06:00
|
|
|
# Our gettext formula will be caught by check_linked_keg_only_brews
|
|
|
|
f = Formula.factory("gettext") rescue nil
|
|
|
|
return if f and f.linked_keg.directory? and @found.all? do |path|
|
|
|
|
Pathname.new(path).realpath.to_s.start_with? "#{HOMEBREW_CELLAR}/gettext"
|
2010-08-09 22:15:10 -07:00
|
|
|
end
|
2012-12-21 18:03:24 -06:00
|
|
|
|
|
|
|
s = <<-EOS.undent_________________________________________________________72
|
|
|
|
gettext files detected at a system prefix
|
|
|
|
These files can cause compilation and link failures, especially if they
|
|
|
|
are compiled with improper architectures. Consider removing these files:
|
|
|
|
EOS
|
2012-12-22 12:48:53 -06:00
|
|
|
inject_file_list(@found, s)
|
2010-08-09 22:15:10 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
def check_for_iconv
|
2012-10-03 12:41:20 -07:00
|
|
|
unless find_relative_paths("lib/libiconv.dylib", "include/iconv.h").empty?
|
2012-08-14 11:23:30 -04:00
|
|
|
if (f = Formula.factory("libiconv") rescue nil) and f.linked_keg.directory?
|
|
|
|
if not f.keg_only? then <<-EOS.undent
|
|
|
|
A libiconv formula is installed and linked
|
|
|
|
This will break stuff. For serious. Unlink it.
|
|
|
|
EOS
|
|
|
|
else
|
|
|
|
# NOOP because: check_for_linked_keg_only_brews
|
|
|
|
end
|
|
|
|
else
|
|
|
|
s = <<-EOS.undent_________________________________________________________72
|
|
|
|
libiconv files detected at a system prefix other than /usr
|
|
|
|
Homebrew doesn't provide a libiconv formula, and expects to link against
|
|
|
|
the system version in /usr. libiconv in other prefixes can cause
|
|
|
|
compile or link failure, especially if compiled with improper
|
|
|
|
architectures. OS X itself never installs anything to /usr/local so
|
|
|
|
it was either installed by a user or some other third party software.
|
|
|
|
|
|
|
|
tl;dr: delete these files:
|
|
|
|
EOS
|
2012-12-22 12:48:53 -06:00
|
|
|
inject_file_list(@found, s)
|
2012-08-14 11:23:30 -04:00
|
|
|
end
|
2010-05-01 10:50:14 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-06-10 14:48:34 -07:00
|
|
|
def check_for_config_scripts
|
2012-04-08 15:28:16 -05:00
|
|
|
return unless HOMEBREW_CELLAR.exist?
|
|
|
|
real_cellar = HOMEBREW_CELLAR.realpath
|
2010-06-10 14:48:34 -07:00
|
|
|
|
|
|
|
config_scripts = []
|
|
|
|
|
2012-09-06 10:03:36 -05:00
|
|
|
whitelist = %W[/usr/bin /usr/sbin /usr/X11/bin /usr/X11R6/bin /opt/X11/bin #{HOMEBREW_PREFIX}/bin #{HOMEBREW_PREFIX}/sbin]
|
|
|
|
whitelist.map! { |d| d.downcase }
|
|
|
|
|
2012-12-21 17:16:24 -06:00
|
|
|
paths.each do |p|
|
2012-09-06 10:03:36 -05:00
|
|
|
next if whitelist.include? p.downcase
|
2011-05-21 03:38:34 +02:00
|
|
|
next if p =~ %r[^(#{real_cellar.to_s}|#{HOMEBREW_CELLAR.to_s})] if real_cellar
|
2010-06-10 14:48:34 -07:00
|
|
|
|
|
|
|
configs = Dir["#{p}/*-config"]
|
|
|
|
# puts "#{p}\n #{configs * ' '}" unless configs.empty?
|
2013-02-17 22:54:43 -06:00
|
|
|
config_scripts << [p, configs.map { |c| File.basename(c) }] unless configs.empty?
|
2010-06-10 14:48:34 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
unless config_scripts.empty?
|
2012-03-01 16:32:02 +00:00
|
|
|
s = <<-EOS.undent
|
|
|
|
"config" scripts exist outside your system or Homebrew directories.
|
2011-12-10 17:14:38 -06:00
|
|
|
`./configure` scripts often look for *-config scripts to determine if
|
|
|
|
software packages are installed, and what additional flags to use when
|
|
|
|
compiling and linking.
|
2010-06-10 14:48:34 -07:00
|
|
|
|
2011-12-10 17:14:38 -06:00
|
|
|
Having additional scripts in your path can confuse software installed via
|
|
|
|
Homebrew if the config script overrides a system or Homebrew provided
|
2012-03-01 16:32:02 +00:00
|
|
|
script of the same name. We found the following "config" scripts:
|
2010-06-10 14:48:34 -07:00
|
|
|
|
|
|
|
EOS
|
|
|
|
|
|
|
|
config_scripts.each do |pair|
|
2012-03-01 16:32:02 +00:00
|
|
|
dn = pair[0]
|
|
|
|
pair[1].each do |fn|
|
|
|
|
s << " #{dn}/#{fn}\n"
|
|
|
|
end
|
2010-06-10 14:48:34 -07:00
|
|
|
end
|
2012-03-01 16:32:02 +00:00
|
|
|
s
|
2010-06-10 14:48:34 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-07-23 16:08:05 -07:00
|
|
|
def check_for_DYLD_LIBRARY_PATH
|
2010-06-25 19:22:54 -07:00
|
|
|
if ENV['DYLD_LIBRARY_PATH']
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
2011-09-02 10:59:32 -03:00
|
|
|
Setting DYLD_LIBRARY_PATH can break dynamic linking.
|
2010-06-25 19:22:54 -07:00
|
|
|
You should probably unset it.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-07-23 16:08:05 -07:00
|
|
|
def check_for_DYLD_FALLBACK_LIBRARY_PATH
|
|
|
|
if ENV['DYLD_FALLBACK_LIBRARY_PATH']
|
|
|
|
<<-EOS.undent
|
|
|
|
Setting DYLD_FALLBACK_LIBRARY_PATH can break dynamic linking.
|
|
|
|
You should probably unset it.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-12 21:14:33 -07:00
|
|
|
def check_for_DYLD_INSERT_LIBRARIES
|
|
|
|
if ENV['DYLD_INSERT_LIBRARIES']
|
|
|
|
<<-EOS.undent
|
|
|
|
Setting DYLD_INSERT_LIBRARIES can cause Go builds to fail.
|
|
|
|
Having this set is common if you use this software:
|
|
|
|
http://asepsis.binaryage.com/
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-06-24 17:11:50 -07:00
|
|
|
def check_for_symlinked_cellar
|
2012-06-19 09:24:19 -05:00
|
|
|
return unless HOMEBREW_CELLAR.exist?
|
2010-06-24 17:11:50 -07:00
|
|
|
if HOMEBREW_CELLAR.symlink?
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
2010-06-24 17:11:50 -07:00
|
|
|
Symlinked Cellars can cause problems.
|
|
|
|
Your Homebrew Cellar is a symlink: #{HOMEBREW_CELLAR}
|
|
|
|
which resolves to: #{HOMEBREW_CELLAR.realpath}
|
|
|
|
|
|
|
|
The recommended Homebrew installations are either:
|
2011-12-10 17:14:38 -06:00
|
|
|
(A) Have Cellar be a real directory inside of your HOMEBREW_PREFIX
|
2010-06-24 17:11:50 -07:00
|
|
|
(B) Symlink "bin/brew" into your prefix, but don't symlink "Cellar".
|
|
|
|
|
|
|
|
Older installations of Homebrew may have created a symlinked Cellar, but this can
|
|
|
|
cause problems when two formula install to locations that are mapped on top of each
|
|
|
|
other during the linking step.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-06-28 09:39:14 -07:00
|
|
|
def check_for_multiple_volumes
|
2011-05-21 03:38:34 +02:00
|
|
|
return unless HOMEBREW_CELLAR.exist?
|
2010-06-28 09:39:14 -07:00
|
|
|
volumes = Volumes.new
|
|
|
|
|
|
|
|
# Find the volumes for the TMP folder & HOMEBREW_CELLAR
|
|
|
|
real_cellar = HOMEBREW_CELLAR.realpath
|
2010-08-16 09:32:16 -07:00
|
|
|
|
|
|
|
tmp_prefix = ENV['HOMEBREW_TEMP'] || '/tmp'
|
2011-03-29 12:45:54 -07:00
|
|
|
tmp = Pathname.new `/usr/bin/mktemp -d #{tmp_prefix}/homebrew-brew-doctor-XXXX`.strip
|
2010-06-28 09:39:14 -07:00
|
|
|
real_temp = tmp.realpath.parent
|
|
|
|
|
|
|
|
where_cellar = volumes.which real_cellar
|
|
|
|
where_temp = volumes.which real_temp
|
|
|
|
|
2011-11-20 01:53:52 -08:00
|
|
|
Dir.delete tmp
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
unless where_cellar == where_temp then <<-EOS.undent
|
|
|
|
Your Cellar and TEMP directories are on different volumes.
|
|
|
|
OS X won't move relative symlinks across volumes unless the target file already
|
|
|
|
exists. Brews known to be affected by this are Git and Narwhal.
|
2010-06-28 09:39:14 -07:00
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
You should set the "HOMEBREW_TEMP" environmental variable to a suitable
|
|
|
|
directory on the same volume as your Cellar.
|
2010-06-28 09:39:14 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-12-19 17:16:27 +01:00
|
|
|
def check_filesystem_case_sensitive
|
|
|
|
volumes = Volumes.new
|
|
|
|
tmp_prefix = Pathname.new(ENV['HOMEBREW_TEMP'] || '/tmp')
|
|
|
|
case_sensitive_vols = [HOMEBREW_PREFIX, HOMEBREW_REPOSITORY, HOMEBREW_CELLAR, tmp_prefix].select do |dir|
|
|
|
|
# We select the dir as being case-sensitive if either the UPCASED or the
|
|
|
|
# downcased variant is missing.
|
|
|
|
# Of course, on a case-insensitive fs, both exist because the os reports so.
|
|
|
|
# In the rare situation when the user has indeed a downcased and an upcased
|
|
|
|
# dir (e.g. /TMP and /tmp) this check falsely thinks it is case-insensitive
|
|
|
|
# but we don't care beacuse: 1. there is more than one dir checked, 2. the
|
|
|
|
# check is not vital and 3. we would have to touch files otherwise.
|
|
|
|
upcased = Pathname.new(dir.to_s.upcase)
|
|
|
|
downcased = Pathname.new(dir.to_s.downcase)
|
|
|
|
dir.exist? && !(upcased.exist? && downcased.exist?)
|
|
|
|
end.map { |case_sensitive_dir| volumes.get_mounts(case_sensitive_dir) }.uniq
|
|
|
|
return if case_sensitive_vols.empty?
|
|
|
|
<<-EOS.undent
|
|
|
|
Your file-system on #{case_sensitive_vols} appears to be CaSe SeNsItIvE.
|
|
|
|
Homebrew is less tested with that - don't worry but please report issues.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
2010-07-09 07:13:19 -07:00
|
|
|
def check_for_git
|
2012-05-07 20:32:04 -05:00
|
|
|
unless which "git" then <<-EOS.undent
|
2012-03-01 16:32:02 +00:00
|
|
|
Git could not be found in your PATH.
|
|
|
|
Homebrew uses Git for several internal functions, and some formulae use Git
|
|
|
|
checkouts instead of stable tarballs. You may want to install Git:
|
|
|
|
brew install git
|
2010-07-09 07:13:19 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-05-12 08:47:51 -07:00
|
|
|
def check_git_newline_settings
|
2012-05-07 20:32:04 -05:00
|
|
|
return unless which "git"
|
2011-05-12 08:47:51 -07:00
|
|
|
|
2011-12-16 20:14:19 -06:00
|
|
|
autocrlf = `git config --get core.autocrlf`.chomp
|
2011-05-12 08:47:51 -07:00
|
|
|
|
2013-02-17 16:31:27 +00:00
|
|
|
if autocrlf == 'true' then <<-EOS.undent
|
2011-05-12 08:47:51 -07:00
|
|
|
Suspicious Git newline settings found.
|
|
|
|
|
2013-01-27 19:37:46 +00:00
|
|
|
The detected Git newline settings will cause checkout problems:
|
2011-12-16 20:14:19 -06:00
|
|
|
core.autocrlf = #{autocrlf}
|
2011-05-12 08:47:51 -07:00
|
|
|
|
|
|
|
If you are not routinely dealing with Windows-based projects,
|
2013-01-30 19:54:32 -08:00
|
|
|
consider removing these by running:
|
2013-02-17 16:31:27 +00:00
|
|
|
`git config --global --set core.autocrlf input`
|
2011-05-12 08:47:51 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2013-01-16 15:56:36 +01:00
|
|
|
def check_for_git_origin
|
|
|
|
return unless which "git"
|
2013-01-29 09:33:30 -06:00
|
|
|
# otherwise this will nag users with no repo about their remote
|
|
|
|
return unless (HOMEBREW_REPOSITORY/'.git').exist?
|
2013-01-16 15:56:36 +01:00
|
|
|
|
|
|
|
HOMEBREW_REPOSITORY.cd do
|
|
|
|
if `git config --get remote.origin.url`.chomp.empty? then <<-EOS.undent
|
|
|
|
Missing git origin remote.
|
|
|
|
|
|
|
|
Without a correctly configured origin, Homebrew won't update
|
|
|
|
properly. You can solve this by adding the Homebrew remote:
|
|
|
|
cd #{HOMEBREW_REPOSITORY}
|
2013-01-27 15:35:02 +04:00
|
|
|
git remote add origin https://github.com/mxcl/homebrew.git
|
2013-01-16 15:56:36 +01:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def check_the_git_origin
|
|
|
|
return unless which "git"
|
|
|
|
return if check_for_git_origin
|
|
|
|
|
|
|
|
HOMEBREW_REPOSITORY.cd do
|
|
|
|
origin = `git config --get remote.origin.url`.chomp
|
|
|
|
|
2013-01-17 21:46:02 -06:00
|
|
|
unless origin =~ /mxcl\/homebrew(\.git)?$/ then <<-EOS.undent
|
2013-01-16 15:56:36 +01:00
|
|
|
Suspicious git origin remote found.
|
|
|
|
|
|
|
|
With a non-standard origin, Homebrew won't pull updates from
|
|
|
|
the main repository. The current git origin is:
|
|
|
|
#{origin}
|
|
|
|
|
|
|
|
Unless you have compelling reasons, consider setting the
|
|
|
|
origin remote to point at the main repository, located at:
|
|
|
|
https://github.com/mxcl/homebrew.git
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-08-09 21:33:06 -07:00
|
|
|
def check_for_autoconf
|
2012-07-10 20:25:16 -05:00
|
|
|
return unless MacOS::Xcode.provides_autotools?
|
2012-02-27 00:41:17 +00:00
|
|
|
|
2012-05-13 19:00:10 -05:00
|
|
|
autoconf = which('autoconf')
|
2011-07-10 20:57:00 +02:00
|
|
|
safe_autoconfs = %w[/usr/bin/autoconf /Developer/usr/bin/autoconf]
|
2012-05-13 19:00:10 -05:00
|
|
|
unless autoconf.nil? or safe_autoconfs.include? autoconf.to_s then <<-EOS.undent
|
2012-03-01 16:32:02 +00:00
|
|
|
An "autoconf" in your path blocks the Xcode-provided version at:
|
|
|
|
#{autoconf}
|
2010-08-09 21:33:06 -07:00
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
This custom autoconf may cause some Homebrew formulae to fail to compile.
|
2010-08-09 21:33:06 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-08-09 21:58:47 -07:00
|
|
|
def __check_linked_brew f
|
|
|
|
links_found = []
|
|
|
|
|
2012-12-21 19:33:24 -06:00
|
|
|
f.prefix.find do |src|
|
2010-08-09 21:58:47 -07:00
|
|
|
dst=HOMEBREW_PREFIX+src.relative_path_from(f.prefix)
|
|
|
|
next unless dst.symlink?
|
2010-10-20 20:05:44 -07:00
|
|
|
|
|
|
|
dst_points_to = dst.realpath()
|
|
|
|
next unless dst_points_to.to_s == src.to_s
|
|
|
|
|
|
|
|
if src.directory?
|
|
|
|
Find.prune
|
|
|
|
else
|
|
|
|
links_found << dst
|
|
|
|
end
|
2010-08-09 21:58:47 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
return links_found
|
|
|
|
end
|
|
|
|
|
2012-08-14 11:21:33 -04:00
|
|
|
def check_for_linked_keg_only_brews
|
2010-08-09 21:58:47 -07:00
|
|
|
require 'formula'
|
|
|
|
|
2012-12-08 16:41:31 -06:00
|
|
|
return unless HOMEBREW_CELLAR.exist?
|
|
|
|
|
2010-08-09 21:58:47 -07:00
|
|
|
warnings = Hash.new
|
|
|
|
|
2012-08-21 11:39:45 -04:00
|
|
|
Formula.each do |f|
|
2010-08-09 21:58:47 -07:00
|
|
|
next unless f.keg_only? and f.installed?
|
|
|
|
links = __check_linked_brew f
|
|
|
|
warnings[f.name] = links unless links.empty?
|
|
|
|
end
|
|
|
|
|
|
|
|
unless warnings.empty?
|
2012-03-01 16:32:02 +00:00
|
|
|
s = <<-EOS.undent
|
2010-08-09 21:58:47 -07:00
|
|
|
Some keg-only formula are linked into the Cellar.
|
|
|
|
Linking a keg-only formula, such as gettext, into the cellar with
|
2013-02-12 22:30:36 -08:00
|
|
|
`brew link <formula>` will cause other formulae to detect them during
|
|
|
|
the `./configure` step. This may cause problems when compiling those
|
2010-08-09 21:58:47 -07:00
|
|
|
other formulae.
|
|
|
|
|
|
|
|
Binaries provided by keg-only formulae may override system binaries
|
|
|
|
with other strange results.
|
|
|
|
|
|
|
|
You may wish to `brew unlink` these brews:
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
EOS
|
|
|
|
warnings.keys.each{ |f| s << " #{f}\n" }
|
|
|
|
s
|
2010-08-09 21:58:47 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-03-28 11:57:57 -07:00
|
|
|
def check_for_MACOSX_DEPLOYMENT_TARGET
|
2010-11-05 07:01:00 -07:00
|
|
|
target_var = ENV['MACOSX_DEPLOYMENT_TARGET']
|
2012-03-01 16:32:02 +00:00
|
|
|
if target_var and target_var != MACOS_VERSION.to_s then <<-EOS.undent
|
2011-12-16 20:20:33 -06:00
|
|
|
MACOSX_DEPLOYMENT_TARGET was set to #{target_var}
|
2010-11-05 07:01:00 -07:00
|
|
|
This is used by Fink, but having it set to a value different from the
|
|
|
|
current system version (#{MACOS_VERSION}) can cause problems, compiling
|
|
|
|
Git for instance, and should probably be removed.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-12-31 12:33:21 -08:00
|
|
|
def check_for_other_frameworks
|
|
|
|
# Other frameworks that are known to cause problems when present
|
2012-03-01 16:32:02 +00:00
|
|
|
%w{Mono.framework expat.framework libexpat.framework}.
|
|
|
|
map{ |frmwrk| "/Library/Frameworks/#{frmwrk}" }.
|
|
|
|
select{ |frmwrk| File.exist? frmwrk }.
|
|
|
|
map do |frmwrk| <<-EOS.undent
|
|
|
|
#{frmwrk} detected
|
|
|
|
This can be picked up by CMake's build system and likely cause the build to
|
|
|
|
fail. You may need to move this file out of the way to compile CMake.
|
2011-04-04 08:48:42 -07:00
|
|
|
EOS
|
2012-03-01 16:32:02 +00:00
|
|
|
end.join
|
2010-12-31 12:33:21 -08:00
|
|
|
end
|
|
|
|
|
2011-07-22 10:41:49 -07:00
|
|
|
def check_tmpdir
|
|
|
|
tmpdir = ENV['TMPDIR']
|
2012-03-01 16:32:02 +00:00
|
|
|
"TMPDIR #{tmpdir.inspect} doesn't exist." unless tmpdir.nil? or File.directory? tmpdir
|
2011-07-22 10:41:49 -07:00
|
|
|
end
|
|
|
|
|
2011-08-31 15:36:29 +01:00
|
|
|
def check_missing_deps
|
2012-06-19 10:05:11 -05:00
|
|
|
return unless HOMEBREW_CELLAR.exist?
|
2012-06-11 12:57:51 -07:00
|
|
|
s = Set.new
|
2013-01-23 00:26:28 -06:00
|
|
|
Homebrew.missing_deps(Formula.installed).each do |_, deps|
|
2012-08-14 11:57:10 -05:00
|
|
|
s.merge deps
|
2012-03-02 01:21:55 +00:00
|
|
|
end
|
2012-06-11 12:57:51 -07:00
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
if s.length > 0 then <<-EOS.undent
|
2012-03-02 01:21:55 +00:00
|
|
|
Some installed formula are missing dependencies.
|
|
|
|
You should `brew install` the missing dependencies:
|
|
|
|
|
2012-06-11 12:57:51 -07:00
|
|
|
brew install #{s.to_a.sort * " "}
|
2012-03-02 01:21:55 +00:00
|
|
|
|
|
|
|
Run `brew missing` for more details.
|
2012-03-01 16:32:02 +00:00
|
|
|
EOS
|
2011-08-31 15:36:29 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-09-09 09:24:03 +01:00
|
|
|
def check_git_status
|
2012-05-07 20:32:04 -05:00
|
|
|
return unless which "git"
|
2011-12-28 19:32:40 -06:00
|
|
|
HOMEBREW_REPOSITORY.cd do
|
2012-08-14 11:23:30 -04:00
|
|
|
unless `git status -s -- Library/Homebrew/ 2>/dev/null`.chomp.empty?
|
|
|
|
<<-EOS.undent_________________________________________________________72
|
|
|
|
You have uncommitted modifications to Homebrew
|
|
|
|
If this a surprise to you, then you should stash these modifications.
|
|
|
|
Stashing returns Homebrew to a pristine state but can be undone
|
|
|
|
should you later need to do so for some reason.
|
2012-08-29 09:03:41 -04:00
|
|
|
cd #{HOMEBREW_REPOSITORY}/Library && git stash && git clean -f
|
2012-03-01 16:32:02 +00:00
|
|
|
EOS
|
2011-12-28 19:32:40 -06:00
|
|
|
end
|
2011-09-09 09:24:03 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-10-03 13:55:51 -05:00
|
|
|
def check_for_leopard_ssl
|
2012-08-14 11:37:29 -05:00
|
|
|
if MacOS.version == :leopard and not ENV['GIT_SSL_NO_VERIFY']
|
2012-03-01 16:32:02 +00:00
|
|
|
<<-EOS.undent
|
2011-10-03 13:55:51 -05:00
|
|
|
The version of libcurl provided with Mac OS X Leopard has outdated
|
|
|
|
SSL certificates.
|
|
|
|
|
|
|
|
This can cause problems when running Homebrew commands that use Git to
|
|
|
|
fetch over HTTPS, e.g. `brew update` or installing formulae that perform
|
|
|
|
Git checkouts.
|
|
|
|
|
2011-12-16 20:20:33 -06:00
|
|
|
You can force Git to ignore these errors by setting GIT_SSL_NO_VERIFY.
|
2011-10-03 13:55:51 -05:00
|
|
|
export GIT_SSL_NO_VERIFY=1
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-10-10 18:20:50 -05:00
|
|
|
def check_git_version
|
|
|
|
# see https://github.com/blog/642-smart-http-support
|
2012-05-07 20:32:04 -05:00
|
|
|
return unless which "git"
|
2011-10-10 18:20:50 -05:00
|
|
|
`git --version`.chomp =~ /git version (\d)\.(\d)\.(\d)/
|
|
|
|
|
2012-03-01 16:32:02 +00:00
|
|
|
if $2.to_i < 6 or $2.to_i == 6 and $3.to_i < 6 then <<-EOS.undent
|
|
|
|
An outdated version of Git was detected in your PATH.
|
|
|
|
Git 1.6.6 or newer is required to perform checkouts over HTTP from GitHub.
|
|
|
|
Please upgrade: brew upgrade git
|
2011-10-10 18:20:50 -05:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-12-18 08:36:44 -08:00
|
|
|
def check_for_enthought_python
|
2012-05-07 20:32:04 -05:00
|
|
|
if which "enpkg" then <<-EOS.undent
|
2011-12-18 08:36:44 -08:00
|
|
|
Enthought Python was found in your PATH.
|
|
|
|
This can cause build problems, as this software installs its own
|
2011-12-10 17:14:38 -06:00
|
|
|
copies of iconv and libxml2 into directories that are picked up by
|
2011-12-18 08:36:44 -08:00
|
|
|
other build systems.
|
2012-03-01 16:32:02 +00:00
|
|
|
EOS
|
|
|
|
end
|
2011-12-18 08:36:44 -08:00
|
|
|
end
|
|
|
|
|
2012-03-06 12:19:53 +00:00
|
|
|
def check_for_bad_python_symlink
|
2012-05-07 20:32:04 -05:00
|
|
|
return unless which "python"
|
2013-01-09 17:04:02 -06:00
|
|
|
# Indeed Python -V outputs to stderr (WTF?)
|
|
|
|
`python -V 2>&1` =~ /Python (\d+)\./
|
|
|
|
# This won't be the right warning if we matched nothing at all
|
|
|
|
return if $1.nil?
|
2012-03-06 12:19:53 +00:00
|
|
|
unless $1 == "2" then <<-EOS.undent
|
|
|
|
python is symlinked to python#$1
|
|
|
|
This will confuse build scripts and in general lead to subtle breakage.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-06-04 11:36:11 +02:00
|
|
|
def check_for_pydistutils_cfg_in_home
|
|
|
|
if File.exist? ENV['HOME']+'/.pydistutils.cfg' then <<-EOS.undent
|
|
|
|
A .pydistutils.cfg file was found in $HOME, which may cause Python
|
|
|
|
builds to fail. See:
|
|
|
|
http://bugs.python.org/issue6138
|
|
|
|
http://bugs.python.org/issue4655
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-06 18:09:09 +00:00
|
|
|
def check_for_outdated_homebrew
|
2012-06-19 10:03:11 -05:00
|
|
|
return unless which 'git'
|
2012-03-10 10:08:16 -08:00
|
|
|
HOMEBREW_REPOSITORY.cd do
|
2012-06-03 10:24:17 -05:00
|
|
|
if File.directory? ".git"
|
|
|
|
local = `git rev-parse -q --verify refs/remotes/origin/master`.chomp
|
2012-07-22 12:26:56 -05:00
|
|
|
remote = /^([a-f0-9]{40})/.match(`git ls-remote origin refs/heads/master 2>/dev/null`)
|
|
|
|
if remote.nil? || local == remote[0]
|
|
|
|
return
|
|
|
|
end
|
2012-06-03 10:24:17 -05:00
|
|
|
end
|
|
|
|
|
2012-03-06 18:09:09 +00:00
|
|
|
timestamp = if File.directory? ".git"
|
|
|
|
`git log -1 --format="%ct" HEAD`.to_i
|
|
|
|
else
|
2012-03-10 10:08:16 -08:00
|
|
|
(HOMEBREW_REPOSITORY/"Library").mtime.to_i
|
2012-03-06 18:09:09 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
if Time.now.to_i - timestamp > 60 * 60 * 24 then <<-EOS.undent
|
|
|
|
Your Homebrew is outdated
|
|
|
|
You haven't updated for at least 24 hours, this is a long time in brewland!
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-09 11:36:34 +00:00
|
|
|
def check_for_unlinked_but_not_keg_only
|
2012-04-08 15:28:16 -05:00
|
|
|
return unless HOMEBREW_CELLAR.exist?
|
2012-03-09 11:36:34 +00:00
|
|
|
unlinked = HOMEBREW_CELLAR.children.reject do |rack|
|
2012-03-18 00:15:48 +00:00
|
|
|
if not rack.directory?
|
|
|
|
true
|
|
|
|
elsif not (HOMEBREW_REPOSITORY/"Library/LinkedKegs"/rack.basename).directory?
|
2012-03-09 11:36:34 +00:00
|
|
|
Formula.factory(rack.basename).keg_only? rescue nil
|
|
|
|
else
|
|
|
|
true
|
|
|
|
end
|
|
|
|
end.map{ |pn| pn.basename }
|
|
|
|
|
2012-08-05 10:45:53 -04:00
|
|
|
# NOTE very old kegs will be linked without the LinkedKegs symlink
|
|
|
|
# this will trigger this warning but it's wrong, we could detect that though
|
|
|
|
# but I don't feel like writing the code.
|
|
|
|
|
2012-03-09 11:36:34 +00:00
|
|
|
if not unlinked.empty? then <<-EOS.undent
|
|
|
|
You have unlinked kegs in your Cellar
|
|
|
|
Leaving kegs unlinked can lead to build-trouble and cause brews that depend on
|
2012-08-05 10:45:53 -04:00
|
|
|
those kegs to fail to run properly once built. Run `brew link` on these:
|
2012-03-09 11:36:34 +00:00
|
|
|
|
|
|
|
#{unlinked * "\n "}
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-03-17 11:56:32 -07:00
|
|
|
def check_os_version
|
|
|
|
if MACOS_FULL_VERSION =~ /^10\.6(\.|$)/
|
|
|
|
unless (MACOS_FULL_VERSION == "10.6.8")
|
|
|
|
return <<-EOS.undent
|
|
|
|
Please update Snow Leopard.
|
|
|
|
10.6.8 is the supported version of Snow Leopard.
|
|
|
|
You are still running #{MACOS_FULL_VERSION}.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
elsif MACOS_FULL_VERSION =~ /^10\.5(\.|$)/
|
|
|
|
unless (MACOS_FULL_VERSION == "10.5.8")
|
|
|
|
return <<-EOS.undent
|
|
|
|
Please update Leopard.
|
|
|
|
10.5.8 is the supported version of Leopard.
|
|
|
|
You are still running #{MACOS_FULL_VERSION}.
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2012-08-31 10:20:20 -04:00
|
|
|
|
|
|
|
def check_xcode_license_approved
|
2012-09-24 08:40:19 -04:00
|
|
|
return if MacOS::Xcode.bad_xcode_select_path?
|
2012-08-31 10:20:20 -04:00
|
|
|
# If the user installs Xcode-only, they have to approve the
|
|
|
|
# license or no "xc*" tool will work.
|
|
|
|
<<-EOS.undent if `/usr/bin/xcrun clang 2>&1` =~ /license/ and not $?.success?
|
|
|
|
You have not agreed to the Xcode license.
|
|
|
|
Builds will fail! Agree to the license by opening Xcode.app or running:
|
|
|
|
xcodebuild -license
|
|
|
|
EOS
|
|
|
|
end
|
2012-03-17 11:56:32 -07:00
|
|
|
|
2012-11-11 11:54:03 -08:00
|
|
|
def check_for_latest_xquartz
|
|
|
|
quartz = MacOS::XQuartz.version
|
|
|
|
return unless quartz
|
2012-11-12 19:42:26 -06:00
|
|
|
return if MacOS::XQuartz.provided_by_apple?
|
2012-11-11 11:54:03 -08:00
|
|
|
|
|
|
|
quartz = Version.new(quartz)
|
|
|
|
latest = Version.new(MacOS::XQuartz.latest_version)
|
|
|
|
|
|
|
|
return if quartz >= latest
|
|
|
|
|
|
|
|
<<-EOS.undent
|
|
|
|
Your XQuartz (#{quartz}) is outdated
|
|
|
|
Please install XQuartz #{latest}.
|
|
|
|
EOS
|
|
|
|
end
|
2012-03-01 16:32:02 +00:00
|
|
|
end # end class Checks
|
|
|
|
|
2010-09-11 20:22:54 +01:00
|
|
|
module Homebrew extend self
|
2010-11-09 13:00:33 +00:00
|
|
|
def doctor
|
2012-03-01 16:32:02 +00:00
|
|
|
checks = Checks.new
|
|
|
|
|
2012-11-13 16:49:43 -06:00
|
|
|
if ARGV.include? '--list-checks'
|
|
|
|
checks.methods.select { |m| m =~ /^check_/ }.sort.each { |m| puts m }
|
|
|
|
exit
|
|
|
|
end
|
|
|
|
|
2012-08-14 11:21:33 -04:00
|
|
|
inject_dump_stats(checks) if ARGV.switch? 'D'
|
|
|
|
|
|
|
|
methods = if ARGV.named.empty?
|
|
|
|
# put slowest methods last
|
|
|
|
checks.methods.sort << "check_for_linked_keg_only_brews" << "check_for_outdated_homebrew"
|
|
|
|
else
|
|
|
|
ARGV.named
|
2012-12-21 15:13:36 -06:00
|
|
|
end.select{ |method| method =~ /^check_/ }.reverse.uniq.reverse
|
2012-08-14 11:21:33 -04:00
|
|
|
|
|
|
|
methods.each do |method|
|
2012-03-01 16:32:02 +00:00
|
|
|
out = checks.send(method)
|
|
|
|
unless out.nil? or out.empty?
|
|
|
|
lines = out.to_s.split('\n')
|
2012-07-25 22:54:44 +01:00
|
|
|
opoo lines.shift
|
|
|
|
Homebrew.failed = true
|
2012-03-01 16:32:02 +00:00
|
|
|
puts lines
|
|
|
|
end
|
2011-05-21 03:40:48 +02:00
|
|
|
end
|
2010-11-09 13:00:33 +00:00
|
|
|
|
2012-03-15 10:57:34 +13:00
|
|
|
puts "Your system is raring to brew." unless Homebrew.failed?
|
2010-03-31 14:55:41 -07:00
|
|
|
end
|
2012-08-14 11:21:33 -04:00
|
|
|
|
|
|
|
def inject_dump_stats checks
|
|
|
|
class << checks
|
|
|
|
alias_method :oldsend, :send
|
|
|
|
def send method
|
|
|
|
time = Time.now
|
|
|
|
oldsend(method)
|
|
|
|
ensure
|
|
|
|
$times[method] = Time.now - time
|
|
|
|
end
|
|
|
|
end
|
|
|
|
$times = {}
|
|
|
|
at_exit {
|
|
|
|
puts $times.sort_by{|k, v| v }.map{|k, v| "#{k}: #{v}"}
|
|
|
|
}
|
|
|
|
end
|
2010-03-31 14:55:41 -07:00
|
|
|
end
|