| 
									
										
										
										
											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 | 
					
						
							| 
									
										
										
										
											2011-11-26 12:01:52 -06:00
										 |  |  |   gcc_42 = MacOS.gcc_42_build_version | 
					
						
							|  |  |  |   gcc_40 = MacOS.gcc_40_build_version | 
					
						
							| 
									
										
										
										
											2010-03-31 15:06:46 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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. | 
					
						
							| 
									
										
										
										
											2011-11-29 14:30:09 -08:00
										 |  |  |       NOTE: Versions of XCode newer than 4.2 don't include gcc 4.2.x. | 
					
						
							| 
									
										
										
										
											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. | 
					
						
							| 
									
										
										
										
											2011-11-11 20:12:41 -06:00
										 |  |  |         If you downloaded Xcode from the App Store, you may need to run the installer. | 
					
						
							| 
									
										
										
										
											2011-07-26 16:01:30 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       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 | 
					
						
							| 
									
										
										
										
											2011-09-07 12:18:05 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |   unless File.exist? '/usr/bin/cc' | 
					
						
							|  |  |  |     puts <<-EOS.undent
 | 
					
						
							|  |  |  |       You have no /usr/bin/cc. This will cause numerous build issues. Please | 
					
						
							|  |  |  |       reinstall Xcode. | 
					
						
							|  |  |  |     EOS | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2010-03-31 15:06:46 -07:00
										 |  |  | 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
 | 
					
						
							| 
									
										
										
										
											2011-07-29 14:33:59 +01:00
										 |  |  |       You can install Homebrew anywhere you want, but some brews may only build | 
					
						
							| 
									
										
										
										
											2010-10-02 10:28:43 -07:00
										 |  |  |       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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-01 09:39:17 -07:00
										 |  |  | def check_xcode_prefix | 
					
						
							|  |  |  |   prefix = MacOS.xcode_prefix | 
					
						
							|  |  |  |   return if prefix.nil? | 
					
						
							|  |  |  |   if prefix.to_s.match(' ') | 
					
						
							|  |  |  |     puts <<-EOS.undent
 | 
					
						
							|  |  |  |       Xcode is installed to a folder with a space in the name. | 
					
						
							|  |  |  |       This may cause some formulae, such as libiconv, to fail to build. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EOS | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 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-08-31 15:38:11 +01:00
										 |  |  |   path_folders.each do |p| case p | 
					
						
							|  |  |  |     when '/usr/bin' | 
					
						
							| 
									
										
										
										
											2010-03-31 15:55:44 -07:00
										 |  |  |       seen_usr_bin = true | 
					
						
							|  |  |  |       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 | 
					
						
							|  |  |  |         if Dir["#{HOMEBREW_PREFIX}/bin/*"].any? {|fn| File.exist? "/usr/bin/#{File.basename fn}"} | 
					
						
							|  |  |  |           ohai "/usr/bin occurs before #{HOMEBREW_PREFIX}/bin" | 
					
						
							|  |  |  |           puts <<-EOS.undent
 | 
					
						
							|  |  |  |             This means that system-provided programs will be used instead of those | 
					
						
							|  |  |  |             provided by Homebrew. This is an issue if you eg. brew installed Python. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             Consider editing your .bashrc to put: | 
					
						
							|  |  |  |               #{HOMEBREW_PREFIX}/bin | 
					
						
							| 
									
										
										
										
											2011-12-16 20:20:33 -06:00
										 |  |  |             ahead of /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" | 
					
						
							|  |  |  |       seen_prefix_bin = true | 
					
						
							|  |  |  |     when "#{HOMEBREW_PREFIX}/sbin" | 
					
						
							|  |  |  |       seen_prefix_sbin = true | 
					
						
							| 
									
										
										
										
											2010-03-31 15:55:44 -07:00
										 |  |  |     end | 
					
						
							|  |  |  |   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 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:20:33 -06:00
										 |  |  |       to the PATH variable. | 
					
						
							| 
									
										
										
										
											2010-04-08 17:50:51 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       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-08-02 14:44:09 +01:00
										 |  |  |   sbin = (HOMEBREW_PREFIX+'sbin') | 
					
						
							|  |  |  |   if sbin.directory? and sbin.children.length > 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 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:20:33 -06:00
										 |  |  |         to the PATH variable. | 
					
						
							| 
									
										
										
										
											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| | 
					
						
							| 
									
										
										
										
											2011-11-29 14:40:40 -08:00
										 |  |  |     next if ['/usr/bin', '/usr/sbin', '/usr/X11/bin', '/usr/X11R6/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
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-20 01:53:52 -08:00
										 |  |  |   Dir.delete tmp | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-28 09:39:14 -07:00
										 |  |  |   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 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:14:19 -06:00
										 |  |  |   unless system "/usr/bin/which -s git" | 
					
						
							| 
									
										
										
										
											2010-07-09 07:13:19 -07:00
										 |  |  |     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 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:14:19 -06:00
										 |  |  |   return unless system "/usr/bin/which -s git" | 
					
						
							| 
									
										
										
										
											2011-05-12 08:47:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:14:19 -06:00
										 |  |  |   autocrlf = `git config --get core.autocrlf`.chomp | 
					
						
							|  |  |  |   safecrlf = `git config --get core.safecrlf`.chomp | 
					
						
							| 
									
										
										
										
											2011-05-12 08:47:51 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:14:19 -06:00
										 |  |  |   if autocrlf == 'input' and safecrlf == 'true' | 
					
						
							| 
									
										
										
										
											2011-05-12 08:47:51 -07:00
										 |  |  |     puts <<-EOS.undent
 | 
					
						
							|  |  |  |     Suspicious Git newline settings found. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     The detected Git newline settings can cause checkout problems: | 
					
						
							| 
									
										
										
										
											2011-12-16 20:14:19 -06:00
										 |  |  |       core.autocrlf = #{autocrlf} | 
					
						
							|  |  |  |       core.safecrlf = #{safecrlf} | 
					
						
							| 
									
										
										
										
											2011-05-12 08:47:51 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     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}" } | 
					
						
							| 
									
										
										
										
											2011-09-16 10:05:11 -07:00
										 |  |  |     puts | 
					
						
							| 
									
										
										
										
											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'] | 
					
						
							| 
									
										
										
										
											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
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-03-28 11:57:57 -07:00
										 |  |  | def check_for_CLICOLOR_FORCE | 
					
						
							| 
									
										
										
										
											2011-10-18 20:10:57 -05:00
										 |  |  |   if ENV['CLICOLOR_FORCE'] | 
					
						
							| 
									
										
										
										
											2011-03-28 11:57:57 -07:00
										 |  |  |     puts <<-EOS.undent
 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:20:33 -06:00
										 |  |  |     Having CLICOLOR_FORCE set can cause some builds to fail. | 
					
						
							| 
									
										
										
										
											2011-10-18 20:10:57 -05:00
										 |  |  |     You may want to unset it. | 
					
						
							| 
									
										
										
										
											2011-04-04 09:21:44 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     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
 | 
					
						
							| 
									
										
										
										
											2011-12-16 20:20:33 -06:00
										 |  |  |     GREP_OPTIONS was set to \"#{target_var}\".
 | 
					
						
							|  |  |  |     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'] | 
					
						
							| 
									
										
										
										
											2011-08-07 10:01:00 -07:00
										 |  |  |   return if tmpdir.nil? | 
					
						
							| 
									
										
										
										
											2011-07-22 10:41:49 -07:00
										 |  |  |   if !File.directory?(tmpdir) | 
					
						
							| 
									
										
										
										
											2011-12-16 20:20:33 -06:00
										 |  |  |     puts "TMPDIR #{tmpdir.inspect} doesn't exist." | 
					
						
							| 
									
										
										
										
											2011-07-22 10:41:49 -07:00
										 |  |  |     puts | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-31 15:36:29 +01:00
										 |  |  | def check_missing_deps | 
					
						
							|  |  |  |   s = `brew missing`.strip | 
					
						
							|  |  |  |   if s.length > 0
 | 
					
						
							|  |  |  |     ohai "You should brew install these missing dependencies:" | 
					
						
							|  |  |  |     puts s | 
					
						
							| 
									
										
										
										
											2011-09-16 10:05:11 -07:00
										 |  |  |     puts | 
					
						
							| 
									
										
										
										
											2011-08-31 15:36:29 +01:00
										 |  |  |   end | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-09 09:24:03 +01:00
										 |  |  | def check_git_status | 
					
						
							| 
									
										
										
										
											2011-12-28 19:32:40 -06:00
										 |  |  |   HOMEBREW_REPOSITORY.cd do | 
					
						
							|  |  |  |     cmd = `git status -s Library/Homebrew/`.chomp | 
					
						
							|  |  |  |     if system "/usr/bin/which -s git" and File.directory? '.git' and not cmd.empty? | 
					
						
							|  |  |  |       ohai "You have uncommitted modifications to Homebrew's core." | 
					
						
							| 
									
										
										
										
											2012-01-24 19:35:41 +00:00
										 |  |  |       puts "Unless you know what you are doing, you should run:" | 
					
						
							| 
									
										
										
										
											2012-01-24 19:59:24 -06:00
										 |  |  |       puts "cd "+HOMEBREW_REPOSITORY+" && git reset --hard" | 
					
						
							| 
									
										
										
										
											2011-12-28 19:32:40 -06:00
										 |  |  |       puts | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2011-09-09 09:24:03 +01:00
										 |  |  |   end | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-03 13:55:51 -05:00
										 |  |  | def check_for_leopard_ssl | 
					
						
							|  |  |  |   if MacOS.leopard? and not ENV['GIT_SSL_NO_VERIFY'] | 
					
						
							|  |  |  |     puts <<-EOS.undent
 | 
					
						
							|  |  |  |       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 | 
					
						
							|  |  |  |   return unless system "/usr/bin/which -s git" | 
					
						
							|  |  |  |   `git --version`.chomp =~ /git version (\d)\.(\d)\.(\d)/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if $2.to_i > 6
 | 
					
						
							|  |  |  |     return | 
					
						
							|  |  |  |   elsif $2.to_i == 6 and $3.to_i == 6
 | 
					
						
							|  |  |  |     return | 
					
						
							|  |  |  |   else | 
					
						
							|  |  |  |     puts <<-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. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       You may want to upgrade: | 
					
						
							|  |  |  |         brew upgrade git | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     EOS | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-18 08:36:44 -08:00
										 |  |  | def check_for_enthought_python | 
					
						
							|  |  |  |   return unless system "/usr/bin/which -s enpkg" | 
					
						
							|  |  |  |   puts <<-EOS.undent
 | 
					
						
							|  |  |  |     Enthought Python was found in your PATH. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     This can cause build problems, as this software installs its own | 
					
						
							|  |  |  |     copies of iconv and libxml2 into folders that are picked up by | 
					
						
							|  |  |  |     other build systems. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   EOS | 
					
						
							|  |  |  | 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 | 
					
						
							| 
									
										
										
										
											2011-09-01 09:39:17 -07:00
										 |  |  |       check_xcode_prefix | 
					
						
							| 
									
										
										
										
											2010-11-09 13:00:33 +00:00
										 |  |  |       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-08-31 15:36:29 +01:00
										 |  |  |       check_missing_deps | 
					
						
							| 
									
										
										
										
											2011-09-09 09:24:03 +01:00
										 |  |  |       check_git_status | 
					
						
							| 
									
										
										
										
											2011-10-03 13:55:51 -05:00
										 |  |  |       check_for_leopard_ssl | 
					
						
							| 
									
										
										
										
											2011-10-10 18:20:50 -05:00
										 |  |  |       check_git_version | 
					
						
							| 
									
										
										
										
											2011-12-18 08:36:44 -08:00
										 |  |  |       check_for_enthought_python | 
					
						
							| 
									
										
										
										
											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-08-31 15:38:21 +01:00
										 |  |  |       puts "Your system is raring to brew." | 
					
						
							| 
									
										
										
										
											2010-03-31 14:55:41 -07:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |