2011-05-21 03:40:48 +02:00
|
|
|
require 'stringio'
|
|
|
|
|
2010-06-28 09:39:14 -07:00
|
|
|
class Volumes
|
|
|
|
def initialize
|
|
|
|
@volumes = []
|
2011-04-29 09:15:39 -07:00
|
|
|
raw_mounts=`/sbin/mount`
|
2010-06-28 09:39:14 -07:00
|
|
|
raw_mounts.split("\n").each do |line|
|
|
|
|
case line
|
|
|
|
when /^(.+) on (\S+) \(/
|
|
|
|
@volumes << [$1, $2]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
# Sort volumes by longest path prefix first
|
|
|
|
@volumes.sort! {|a,b| b[1].length <=> a[1].length}
|
|
|
|
end
|
|
|
|
|
|
|
|
def which path
|
|
|
|
@volumes.each_index do |i|
|
|
|
|
vol = @volumes[i]
|
2011-06-13 14:32:50 -07:00
|
|
|
return i if vol[1].start_with? path.to_s
|
2010-06-28 09:39:14 -07:00
|
|
|
end
|
|
|
|
|
|
|
|
return -1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2011-06-07 13:18:00 -07:00
|
|
|
def remove_trailing_slash s
|
|
|
|
(s[s.length-1] == '/') ? s[0,s.length-1] : s
|
|
|
|
end
|
|
|
|
|
|
|
|
|
2011-03-29 12:45:54 -07:00
|
|
|
def path_folders
|
2011-06-07 13:18:00 -07:00
|
|
|
ENV['PATH'].split(':').collect{|p| remove_trailing_slash(File.expand_path(p))}.uniq
|
2011-03-29 12:45:54 -07:00
|
|
|
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
|
2010-09-22 15:24:41 -07:00
|
|
|
if File.exist? "/Applications/start-gpg-agent.app" or
|
|
|
|
File.exist? "/Library/Receipts/libiconv1.pkg"
|
2010-08-18 09:09:38 -07:00
|
|
|
puts <<-EOS.undent
|
|
|
|
If you 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/.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
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?
|
|
|
|
|
|
|
|
puts <<-EOS.undent
|
2011-03-28 11:51:54 -07:00
|
|
|
Unbrewed dylibs were found in /usr/local/lib.
|
2010-06-29 10:10:53 -07:00
|
|
|
|
2011-03-28 11:51:54 -07:00
|
|
|
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
|
|
|
|
puts *bad_dylibs.collect { |f| " #{f}" }
|
|
|
|
puts
|
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 }
|
|
|
|
return if unbrewed_alibs.empty?
|
|
|
|
|
|
|
|
puts <<-EOS.undent
|
|
|
|
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
|
|
|
|
puts *unbrewed_alibs.collect { |f| " #{f}" }
|
|
|
|
puts
|
|
|
|
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.
|
|
|
|
white_list = {
|
|
|
|
"fuse.pc" => "MacFuse",
|
|
|
|
}
|
|
|
|
|
|
|
|
bad_pcs = unbrewed_pcs.reject {|d| white_list.key? File.basename(d) }
|
|
|
|
return if bad_pcs.empty?
|
|
|
|
|
|
|
|
puts <<-EOS.undent
|
|
|
|
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
|
|
|
|
puts *bad_pcs.collect { |f| " #{f}" }
|
|
|
|
puts
|
|
|
|
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?
|
|
|
|
|
|
|
|
puts <<-EOS.undent
|
|
|
|
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
|
|
|
|
puts *bad_las.collect { |f| " #{f}" }
|
|
|
|
puts
|
|
|
|
end
|
|
|
|
|
2010-03-31 14:59:50 -07:00
|
|
|
def check_for_x11
|
2010-06-29 10:21:40 -07:00
|
|
|
unless x11_installed?
|
2010-03-31 15:22:20 -07:00
|
|
|
puts <<-EOS.undent
|
2011-03-28 11:51:54 -07:00
|
|
|
X11 not installed.
|
|
|
|
|
2011-03-14 20:59:21 +00:00
|
|
|
You don't have X11 installed as part of your OS X installation.
|
2010-06-29 10:21:40 -07:00
|
|
|
This isn't required for all formulae, but is expected by some.
|
2010-03-31 15:22:20 -07:00
|
|
|
|
|
|
|
EOS
|
2010-03-31 14:59:50 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-07-25 12:07:41 -07:00
|
|
|
def check_for_nonstandard_x11
|
|
|
|
return unless File.exists? '/usr/X11'
|
|
|
|
x11 = Pathname.new('/usr/X11')
|
|
|
|
if x11.symlink?
|
|
|
|
puts <<-EOS.undent
|
|
|
|
"/usr/X11" was found, but it is a symlink to:
|
|
|
|
#{x11.resolved_path}
|
|
|
|
|
2010-08-07 11:46:20 -07:00
|
|
|
Homebrew's X11 support has only be tested with Apple's X11.
|
|
|
|
In particular, "XQuartz" and "XDarwin" are not known to be compatible.
|
2010-07-25 12:07:41 -07:00
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-03-31 15:00:40 -07:00
|
|
|
def check_for_other_package_managers
|
|
|
|
if macports_or_fink_installed?
|
2010-03-31 15:22:20 -07:00
|
|
|
puts <<-EOS.undent
|
|
|
|
You have Macports or Fink installed. This can cause trouble.
|
|
|
|
You don't have to uninstall them, but you may like to try temporarily
|
|
|
|
moving them away, eg.
|
|
|
|
|
|
|
|
sudo mv /opt/local ~/macports
|
|
|
|
|
|
|
|
EOS
|
2010-03-31 15:00:40 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-03-31 15:06:46 -07:00
|
|
|
def check_gcc_versions
|
|
|
|
gcc_42 = gcc_42_build
|
|
|
|
gcc_40 = gcc_40_build
|
|
|
|
|
2010-05-01 09:02:18 -07:00
|
|
|
if gcc_42 == nil
|
|
|
|
puts <<-EOS.undent
|
2010-08-09 21:06:33 -07:00
|
|
|
We couldn't detect gcc 4.2.x. Some formulae require this compiler.
|
2010-05-01 09:02:18 -07:00
|
|
|
|
|
|
|
EOS
|
|
|
|
elsif gcc_42 < RECOMMENDED_GCC_42
|
2010-03-31 15:22:20 -07:00
|
|
|
puts <<-EOS.undent
|
|
|
|
Your gcc 4.2.x version is older than the recommended version. It may be advisable
|
|
|
|
to upgrade to the latest release of Xcode.
|
|
|
|
|
|
|
|
EOS
|
2010-03-31 15:06:46 -07:00
|
|
|
end
|
|
|
|
|
2011-07-26 16:01:30 -07:00
|
|
|
if MacOS.xcode_version == nil
|
|
|
|
puts <<-EOS.undent
|
|
|
|
We couldn't detect any version of Xcode.
|
|
|
|
If you downloaded Xcode 4.1 from the App Store, you may need to run the installer.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
elsif MacOS.xcode_version < "4.0"
|
2011-07-20 23:26:11 -07:00
|
|
|
if gcc_40 == nil
|
|
|
|
puts <<-EOS.undent
|
|
|
|
We couldn't detect gcc 4.0.x. Some formulae require this compiler.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
elsif gcc_40 < RECOMMENDED_GCC_40
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Your gcc 4.0.x version is older than the recommended version. It may be advisable
|
|
|
|
to upgrade to the latest release of Xcode.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
2010-03-31 15:06:46 -07:00
|
|
|
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?
|
|
|
|
cant_read << d unless d.writable?
|
|
|
|
end
|
|
|
|
|
|
|
|
cant_read.sort!
|
2010-04-12 13:09:51 -07:00
|
|
|
if cant_read.length > 0
|
2010-03-31 15:38:20 -07:00
|
|
|
puts <<-EOS.undent
|
2010-07-30 09:23:29 -07:00
|
|
|
Some folders 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
|
|
|
|
folders, then the install will fail during the link step.
|
|
|
|
You should probably `chown` them:
|
|
|
|
|
|
|
|
EOS
|
|
|
|
puts *cant_read.collect { |f| " #{f}" }
|
|
|
|
puts
|
|
|
|
end
|
2010-07-01 10:16:15 -07:00
|
|
|
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
|
|
|
|
return unless folder.exist?
|
2010-07-01 10:16:15 -07:00
|
|
|
|
2011-03-28 11:48:45 -07:00
|
|
|
unless folder.writable?
|
2010-07-01 10:16:15 -07:00
|
|
|
puts <<-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-03-31 15:38:20 -07:00
|
|
|
|
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',
|
|
|
|
'If a brew tries to write a .pc file to this folder, the install will\n'+
|
|
|
|
'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',
|
|
|
|
'If a brew tries to write a header file to this folder, the install will\n'+
|
|
|
|
'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',
|
|
|
|
'If a brew tries to write a file to this folder, the install will\n'+
|
|
|
|
'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',
|
|
|
|
'If a brew tries to write a file to this folder, the install will\n'+
|
|
|
|
'fail during the link step.'
|
2010-10-20 19:28:46 -07:00
|
|
|
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
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Ruby version #{RUBY_VERSION} is unsupported.
|
|
|
|
Homebrew is developed and tested on Ruby 1.8.x, and may not work correctly
|
|
|
|
on Ruby 1.9.x. Patches are accepted as long as they don't break on 1.8.x.
|
|
|
|
|
|
|
|
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'
|
|
|
|
puts <<-EOS.undent
|
2010-10-02 10:28:43 -07:00
|
|
|
You can install Homebrew anywhere you want, but some brews may only work
|
|
|
|
correctly if you install to /usr/local.
|
2010-03-31 15:20:13 -07:00
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
2010-03-31 15:09:03 -07:00
|
|
|
end
|
|
|
|
|
2010-03-31 15:55:44 -07:00
|
|
|
def check_user_path
|
|
|
|
seen_prefix_bin = false
|
|
|
|
seen_prefix_sbin = false
|
|
|
|
seen_usr_bin = false
|
2010-04-08 17:50:51 -07:00
|
|
|
|
2011-03-29 12:45:54 -07:00
|
|
|
path_folders.each do |p|
|
2010-03-31 15:55:44 -07:00
|
|
|
if p == '/usr/bin'
|
|
|
|
seen_usr_bin = true
|
|
|
|
unless seen_prefix_bin
|
|
|
|
puts <<-EOS.undent
|
|
|
|
/usr/bin is in your PATH before Homebrew's bin. This means that system-
|
|
|
|
provided programs will be used before Homebrew-provided ones. This is an
|
|
|
|
issue if you install, for instance, Python.
|
2010-04-08 17:50:51 -07:00
|
|
|
|
2010-03-31 15:55:44 -07:00
|
|
|
Consider editing your .bashrc to put:
|
|
|
|
#{HOMEBREW_PREFIX}/bin
|
2010-04-08 17:50:51 -07:00
|
|
|
ahead of /usr/bin in your $PATH.
|
2010-03-31 15:55:44 -07:00
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
2010-04-08 17:50:51 -07:00
|
|
|
|
|
|
|
seen_prefix_bin = true if p == "#{HOMEBREW_PREFIX}/bin"
|
2010-03-31 15:55:44 -07:00
|
|
|
seen_prefix_sbin = true if p == "#{HOMEBREW_PREFIX}/sbin"
|
|
|
|
end
|
2010-04-08 17:50:51 -07:00
|
|
|
|
|
|
|
unless seen_prefix_bin
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Homebrew's bin was not found in your path. Some brews depend
|
|
|
|
on other brews that install tools to bin.
|
|
|
|
|
|
|
|
You should edit your .bashrc to add:
|
|
|
|
#{HOMEBREW_PREFIX}/bin
|
|
|
|
to $PATH.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
|
2011-06-02 09:27:11 -07:00
|
|
|
# Don't complain about sbin not being in the path if it doesn't exist
|
2011-07-29 14:54:42 +01:00
|
|
|
if (HOMEBREW_PREFIX+'sbin').children.count > 0
|
2011-06-02 09:27:11 -07:00
|
|
|
unless seen_prefix_sbin
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Some brews install binaries to sbin instead of bin, but Homebrew's
|
|
|
|
sbin was not found in your path.
|
2010-04-08 17:50:51 -07:00
|
|
|
|
2011-06-02 09:27:11 -07:00
|
|
|
Consider editing your .bashrc to add:
|
|
|
|
#{HOMEBREW_PREFIX}/sbin
|
|
|
|
to $PATH.
|
2010-03-31 15:55:44 -07:00
|
|
|
|
2011-06-02 09:27:11 -07:00
|
|
|
EOS
|
|
|
|
end
|
2010-03-31 15:55:44 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-04-20 12:20:57 -07:00
|
|
|
def check_which_pkg_config
|
2010-07-09 07:13:19 -07:00
|
|
|
binary = `/usr/bin/which pkg-config`.chomp
|
2010-04-03 09:43:17 -07:00
|
|
|
return if binary.empty?
|
|
|
|
|
|
|
|
unless binary == "#{HOMEBREW_PREFIX}/bin/pkg-config"
|
|
|
|
puts <<-EOS.undent
|
|
|
|
You have a non-brew 'pkg-config' in your PATH:
|
|
|
|
#{binary}
|
|
|
|
|
|
|
|
`./configure` may have problems finding brew-installed packages using
|
|
|
|
this other pkg-config.
|
2010-04-08 17:50:51 -07:00
|
|
|
|
2010-04-03 09:43:17 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-04-20 12:20:57 -07:00
|
|
|
def check_pkg_config_paths
|
2010-07-09 07:13:19 -07:00
|
|
|
binary = `/usr/bin/which pkg-config`.chomp
|
2010-04-20 12:20:57 -07:00
|
|
|
return if binary.empty?
|
|
|
|
|
|
|
|
# Use the debug output to determine which paths are searched
|
|
|
|
pkg_config_paths = []
|
|
|
|
|
|
|
|
debug_output = `pkg-config --debug 2>&1`
|
|
|
|
debug_output.split("\n").each do |line|
|
|
|
|
line =~ /Scanning directory '(.*)'/
|
|
|
|
pkg_config_paths << $1 if $1
|
|
|
|
end
|
|
|
|
|
|
|
|
# Check that all expected paths are being searched
|
|
|
|
unless pkg_config_paths.include? "/usr/X11/lib/pkgconfig"
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Your pkg-config is not checking "/usr/X11/lib/pkgconfig" for packages.
|
|
|
|
Earlier versions of the pkg-config formula did not add this path
|
|
|
|
to the search path, which means that other formula may not be able
|
|
|
|
to find certain dependencies.
|
|
|
|
|
|
|
|
To resolve this issue, re-brew pkg-config with:
|
|
|
|
brew rm pkg-config && brew install pkg-config
|
2010-06-24 17:05:57 -07:00
|
|
|
|
2010-04-20 12:20:57 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-05-01 10:50:14 -07:00
|
|
|
def check_for_gettext
|
2010-08-09 22:15:10 -07:00
|
|
|
if %w[lib/libgettextlib.dylib
|
|
|
|
lib/libintl.dylib
|
|
|
|
include/libintl.h ].any? { |f| File.exist? "#{HOMEBREW_PREFIX}/#{f}" }
|
2010-05-01 10:50:14 -07:00
|
|
|
puts <<-EOS.undent
|
|
|
|
gettext was detected in your PREFIX.
|
|
|
|
|
|
|
|
The gettext provided by Homebrew is "keg-only", meaning it does not
|
|
|
|
get linked into your PREFIX by default.
|
|
|
|
|
|
|
|
If you `brew link gettext` then a large number of brews that don't
|
|
|
|
otherwise have a `depends_on 'gettext'` will pick up gettext anyway
|
|
|
|
during the `./configure` step.
|
2010-06-24 17:05:57 -07:00
|
|
|
|
2010-08-09 22:15:10 -07:00
|
|
|
If you have a non-Homebrew provided gettext, other problems will happen
|
|
|
|
especially if it wasn't compiled with the proper architectures.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def check_for_iconv
|
|
|
|
if %w[lib/libiconv.dylib
|
|
|
|
include/iconv.h ].any? { |f| File.exist? "#{HOMEBREW_PREFIX}/#{f}" }
|
|
|
|
puts <<-EOS.undent
|
|
|
|
libiconv was detected in your PREFIX.
|
|
|
|
|
|
|
|
Homebrew doesn't provide a libiconv formula, and expects to link against
|
|
|
|
the system version in /usr/lib.
|
|
|
|
|
|
|
|
If you have a non-Homebrew provided libiconv, many formulae will fail
|
|
|
|
to compile or link, especially if it wasn't compiled with the proper
|
|
|
|
architectures.
|
|
|
|
|
2010-05-01 10:50:14 -07:00
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-06-10 14:48:34 -07:00
|
|
|
def check_for_config_scripts
|
2011-05-21 03:38:34 +02:00
|
|
|
real_cellar = HOMEBREW_CELLAR.exist? && HOMEBREW_CELLAR.realpath
|
2010-06-10 14:48:34 -07:00
|
|
|
|
|
|
|
config_scripts = []
|
|
|
|
|
2011-03-29 12:45:54 -07:00
|
|
|
path_folders.each do |p|
|
2010-06-10 14:48:34 -07:00
|
|
|
next if ['/usr/bin', '/usr/sbin', '/usr/X11/bin', "#{HOMEBREW_PREFIX}/bin", "#{HOMEBREW_PREFIX}/sbin"].include? p
|
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?
|
|
|
|
config_scripts << [p, configs.collect {|p| File.basename(p)}] unless configs.empty?
|
|
|
|
end
|
|
|
|
|
|
|
|
unless config_scripts.empty?
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Some "config" scripts were found in your path, but not in system or Homebrew folders.
|
|
|
|
|
|
|
|
`./configure` scripts often look for *-config scripts to determine if software packages
|
|
|
|
are installed, and what additional flags to use when compiling and linking.
|
|
|
|
|
|
|
|
Having additional scripts in your path can confuse software installed via Homebrew if
|
|
|
|
the config script overrides a system or Homebrew provided script of the same name.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
|
|
|
|
config_scripts.each do |pair|
|
|
|
|
puts pair[0]
|
|
|
|
puts " " + pair[1] * " "
|
|
|
|
end
|
2010-06-24 17:05:57 -07:00
|
|
|
puts
|
2010-06-10 14:48:34 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-06-25 19:22:54 -07:00
|
|
|
def check_for_dyld_vars
|
|
|
|
if ENV['DYLD_LIBRARY_PATH']
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Setting DYLD_LIBARY_PATH can break dynamic linking.
|
|
|
|
You should probably unset it.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-06-24 17:11:50 -07:00
|
|
|
def check_for_symlinked_cellar
|
|
|
|
if HOMEBREW_CELLAR.symlink?
|
|
|
|
puts <<-EOS.undent
|
|
|
|
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:
|
|
|
|
(A) Have Cellar be a real folder inside of your HOMEBREW_PREFIX
|
|
|
|
(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
|
|
|
|
|
|
|
|
unless where_cellar == where_temp
|
|
|
|
puts <<-EOS.undent
|
2010-08-16 09:32:16 -07:00
|
|
|
Your Cellar & TEMP folders are on different volumes.
|
|
|
|
|
|
|
|
OS X won't move relative symlinks across volumes unless the target file
|
|
|
|
already exists.
|
2010-06-28 09:39:14 -07:00
|
|
|
|
2010-08-16 09:32:16 -07:00
|
|
|
Brews known to be affected by this are Git and Narwhal.
|
2010-06-28 09:39:14 -07:00
|
|
|
|
2010-05-01 14:06:23 -07:00
|
|
|
You should set the "HOMEBREW_TEMP" environmental variable to a suitable
|
|
|
|
folder on the same volume as your Cellar.
|
2010-06-28 09:39:14 -07:00
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-07-09 07:13:19 -07:00
|
|
|
def check_for_git
|
|
|
|
git = `/usr/bin/which git`.chomp
|
|
|
|
if git.empty?
|
|
|
|
puts <<-EOS.undent
|
|
|
|
"Git" was not found in your path.
|
|
|
|
|
|
|
|
Homebrew uses Git for several internal functions, and some formulae
|
2010-10-20 19:29:02 -07:00
|
|
|
use Git checkouts instead of stable tarballs.
|
2010-07-09 07:13:19 -07:00
|
|
|
|
2011-05-12 08:47:51 -07:00
|
|
|
You may want to install git:
|
2010-07-09 07:13:19 -07:00
|
|
|
brew install git
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2011-05-12 08:47:51 -07:00
|
|
|
def check_git_newline_settings
|
|
|
|
git = `/usr/bin/which git`.chomp
|
|
|
|
return if git.empty?
|
|
|
|
|
|
|
|
autocrlf=`git config --get core.autocrlf`
|
|
|
|
safecrlf=`git config --get core.safecrlf`
|
|
|
|
|
|
|
|
if autocrlf=='input' and safecrlf=='true'
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Suspicious Git newline settings found.
|
|
|
|
|
|
|
|
The detected Git newline settings can cause checkout problems:
|
|
|
|
core.autocrlf=#{autocrlf}
|
|
|
|
core.safecrlf=#{safecrlf}
|
|
|
|
|
|
|
|
If you are not routinely dealing with Windows-based projects,
|
|
|
|
consider removing these settings.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-08-09 21:33:06 -07:00
|
|
|
def check_for_autoconf
|
2011-07-10 20:57:00 +02:00
|
|
|
autoconf = `/usr/bin/which autoconf`.chomp
|
|
|
|
safe_autoconfs = %w[/usr/bin/autoconf /Developer/usr/bin/autoconf]
|
|
|
|
unless autoconf.empty? or safe_autoconfs.include? autoconf
|
2010-08-09 21:33:06 -07:00
|
|
|
puts <<-EOS.undent
|
2011-05-26 22:19:15 -07:00
|
|
|
An "autoconf" in your path blocking the Xcode-provided version at:
|
2011-07-10 20:57:00 +02:00
|
|
|
#{autoconf}
|
2010-08-09 21:33:06 -07:00
|
|
|
|
2011-05-26 22:19:15 -07: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 = []
|
|
|
|
|
|
|
|
Pathname.new(f.prefix).find do |src|
|
|
|
|
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
|
|
|
|
|
|
|
|
def check_for_linked_kegonly_brews
|
|
|
|
require 'formula'
|
|
|
|
|
|
|
|
warnings = Hash.new
|
|
|
|
|
|
|
|
Formula.all.each do |f|
|
|
|
|
next unless f.keg_only? and f.installed?
|
|
|
|
links = __check_linked_brew f
|
|
|
|
warnings[f.name] = links unless links.empty?
|
|
|
|
end
|
|
|
|
|
|
|
|
unless warnings.empty?
|
|
|
|
puts <<-EOS.undent
|
|
|
|
Some keg-only formula are linked into the Cellar.
|
|
|
|
|
|
|
|
Linking a keg-only formula, such as gettext, into the cellar with
|
|
|
|
`brew link f` will cause other formulae to detect them during the
|
|
|
|
`./configure` step. This may cause problems when compiling those
|
|
|
|
other formulae.
|
|
|
|
|
|
|
|
Binaries provided by keg-only formulae may override system binaries
|
|
|
|
with other strange results.
|
|
|
|
|
|
|
|
You may wish to `brew unlink` these brews:
|
|
|
|
EOS
|
|
|
|
|
|
|
|
puts *warnings.keys.collect { |f| " #{f}" }
|
|
|
|
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']
|
2011-03-28 11:57:57 -07:00
|
|
|
return if target_var.to_s.empty?
|
2010-11-05 07:01:00 -07:00
|
|
|
|
|
|
|
unless target_var == MACOS_VERSION.to_s
|
|
|
|
puts <<-EOS.undent
|
|
|
|
$MACOSX_DEPLOYMENT_TARGET was set to #{target_var}
|
|
|
|
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
|
|
|
|
|
2011-03-28 11:57:57 -07:00
|
|
|
def check_for_CLICOLOR_FORCE
|
2011-04-01 13:42:12 -07:00
|
|
|
target_var = ENV['CLICOLOR_FORCE'].to_s
|
|
|
|
unless target_var.empty?
|
2011-03-28 11:57:57 -07:00
|
|
|
puts <<-EOS.undent
|
2011-04-04 09:21:44 -07:00
|
|
|
$CLICOLOR_FORCE was set to \"#{target_var}\".
|
|
|
|
Having $CLICOLOR_FORCE set can cause git builds to fail.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def check_for_GREP_OPTIONS
|
|
|
|
target_var = ENV['GREP_OPTIONS'].to_s
|
2011-07-25 17:26:31 -05:00
|
|
|
unless target_var.empty? or target_var == '--color=auto'
|
2011-04-04 09:21:44 -07:00
|
|
|
puts <<-EOS.undent
|
|
|
|
$GREP_OPTIONS was set to \"#{target_var}\".
|
2011-07-25 17:26:31 -05:00
|
|
|
Having $GREP_OPTIONS set this way can cause CMake builds to fail.
|
2011-03-28 11:57:57 -07:00
|
|
|
|
|
|
|
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
|
2011-04-04 08:48:42 -07:00
|
|
|
["/Library/Frameworks/expat.framework", "/Library/Frameworks/libexpat.framework"].each do |f|
|
|
|
|
if File.exist? f
|
|
|
|
puts <<-EOS.undent
|
|
|
|
#{f} detected
|
2010-12-31 12:33:21 -08:00
|
|
|
|
2011-07-22 12:14:03 -05:00
|
|
|
This will be picked up by Cmake's build system and likely cause the
|
2011-04-04 08:48:42 -07:00
|
|
|
build to fail, trying to link to a 32-bit version of expat.
|
|
|
|
You may need to move this file out of the way to compile Cmake.
|
2010-12-31 12:33:21 -08:00
|
|
|
|
2011-04-04 08:48:42 -07:00
|
|
|
EOS
|
|
|
|
end
|
2010-12-31 12:33:21 -08:00
|
|
|
end
|
2011-05-12 07:24:10 -07:00
|
|
|
|
|
|
|
if File.exist? "/Library/Frameworks/Mono.framework"
|
|
|
|
puts <<-EOS.undent
|
|
|
|
/Library/Frameworks/Mono.framework detected
|
|
|
|
|
2011-07-22 12:14:03 -05:00
|
|
|
This can be picked up by Cmake's build system and likely cause the
|
2011-05-12 07:24:10 -07:00
|
|
|
build to fail, finding improper header files for libpng for instance.
|
|
|
|
|
|
|
|
EOS
|
|
|
|
end
|
2010-12-31 12:33:21 -08:00
|
|
|
end
|
|
|
|
|
2011-07-22 10:41:49 -07:00
|
|
|
def check_tmpdir
|
|
|
|
tmpdir = ENV['TMPDIR']
|
|
|
|
if !File.directory?(tmpdir)
|
|
|
|
puts "$TMPDIR #{tmpdir.inspect} doesn't exist."
|
|
|
|
puts
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-09-11 20:22:54 +01:00
|
|
|
module Homebrew extend self
|
2010-11-09 13:00:33 +00:00
|
|
|
def doctor
|
2011-05-21 03:40:48 +02:00
|
|
|
old_stdout = $stdout
|
|
|
|
$stdout = output = StringIO.new
|
2010-11-09 13:00:33 +00:00
|
|
|
|
2011-05-21 03:40:48 +02:00
|
|
|
begin
|
2010-11-09 13:00:33 +00:00
|
|
|
check_usr_bin_ruby
|
|
|
|
check_homebrew_prefix
|
|
|
|
check_for_macgpg2
|
|
|
|
check_for_stray_dylibs
|
2011-05-05 09:40:03 -07:00
|
|
|
check_for_stray_static_libs
|
2011-05-09 17:23:35 -07:00
|
|
|
check_for_stray_pcs
|
2011-05-12 08:10:47 -07:00
|
|
|
check_for_stray_las
|
2010-11-09 13:00:33 +00:00
|
|
|
check_gcc_versions
|
|
|
|
check_for_other_package_managers
|
|
|
|
check_for_x11
|
|
|
|
check_for_nonstandard_x11
|
|
|
|
check_access_include
|
|
|
|
check_access_etc
|
2011-03-28 11:48:45 -07:00
|
|
|
check_access_share
|
|
|
|
check_access_share_locale
|
|
|
|
check_access_share_man
|
2010-11-09 13:00:33 +00:00
|
|
|
check_user_path
|
|
|
|
check_which_pkg_config
|
|
|
|
check_pkg_config_paths
|
|
|
|
check_access_pkgconfig
|
|
|
|
check_for_gettext
|
|
|
|
check_for_config_scripts
|
|
|
|
check_for_dyld_vars
|
2011-03-28 11:57:57 -07:00
|
|
|
check_for_MACOSX_DEPLOYMENT_TARGET
|
|
|
|
check_for_CLICOLOR_FORCE
|
2011-04-04 09:21:44 -07:00
|
|
|
check_for_GREP_OPTIONS
|
2010-11-09 13:00:33 +00:00
|
|
|
check_for_symlinked_cellar
|
|
|
|
check_for_multiple_volumes
|
|
|
|
check_for_git
|
2011-05-12 08:47:51 -07:00
|
|
|
check_git_newline_settings
|
2010-11-09 13:00:33 +00:00
|
|
|
check_for_autoconf
|
|
|
|
check_for_linked_kegonly_brews
|
2010-12-31 12:33:21 -08:00
|
|
|
check_for_other_frameworks
|
2011-07-22 10:41:49 -07:00
|
|
|
check_tmpdir
|
2011-05-21 03:40:48 +02:00
|
|
|
ensure
|
|
|
|
$stdout = old_stdout
|
|
|
|
end
|
2010-11-09 13:00:33 +00:00
|
|
|
|
2011-05-21 03:40:48 +02:00
|
|
|
unless (warnings = output.string).chomp.empty?
|
|
|
|
puts warnings
|
2011-05-21 03:41:45 +02:00
|
|
|
exit 1
|
2010-03-31 14:55:41 -07:00
|
|
|
else
|
2011-05-21 03:40:48 +02:00
|
|
|
puts "Your OS X is ripe for brewing."
|
|
|
|
puts "Any troubles you may be experiencing are likely purely psychosomatic."
|
2010-03-31 14:55:41 -07:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|