From 178dc49350029685eeee7b86704455ebc9d99760 Mon Sep 17 00:00:00 2001 From: Max Howell Date: Thu, 17 Sep 2009 21:10:39 +0100 Subject: Solving the GNU GetText issues GNU GetText breaks eg. Ruby 1.9 builds, and some other formula I have been building too. But it is required by eg. glib. So to solve this we are going to by default not symlink gettext into the Homebrew prefix. Formula that depend on GetText will have the gettext paths added to the brewing environment automatically. Neat. --- Library/Formula/gettext.rb | 10 +++++----- Library/Formula/glib.rb | 3 ++- Library/Homebrew/brewkit.rb | 8 ++++++++ Library/Homebrew/formula.rb | 5 ++++- Library/Homebrew/install.rb | 34 +++++++++++++++++++++++++++------- 5 files changed, 46 insertions(+), 14 deletions(-) (limited to 'Library') diff --git a/Library/Formula/gettext.rb b/Library/Formula/gettext.rb index 9f5a9bfe1..c52e99d74 100644 --- a/Library/Formula/gettext.rb +++ b/Library/Formula/gettext.rb @@ -4,11 +4,15 @@ class Gettext 'http://bar.com/patch2', # :p2 => ['http://moo.com/patch5', 'http://moo.com/patch6'] # } - # The final option is to return DATA, then put a diff after __END__ and you + # The final option is to return DATA, then put a diff after __END__. You # can still return a Hash with DATA as the value for a patch level key. def patches; end # reimplement and specify dependencies def deps; end # sometimes the clean process breaks things, return true to skip anything def skip_clean? path; false end + # rarely, you don't want your library symlinked into the main prefix + # see gettext.rb for an example + def keg_only?; false end # yields self with current working directory set to the uncompressed tarball def brew diff --git a/Library/Homebrew/install.rb b/Library/Homebrew/install.rb index 3f887e99a..575fbe8f3 100755 --- a/Library/Homebrew/install.rb +++ b/Library/Homebrew/install.rb @@ -6,6 +6,21 @@ require 'brew.h' show_summary_heading = false +def text_for_keg_only_formula f + <<-EOS +#{f.name} is keg-only. This means it is not symlinked into Homebrew's +prefix. The formula provides the following rationale: + +#{f.keg_only?} + +Generally there are no consequences of this for you, however if you build your +own software and it requires this formula, you may want to run this command to +link it into the Homebrew prefix: + + brew link #{f.name} + EOS +end + def install f build_time = nil @@ -71,14 +86,19 @@ def install f end end - begin - Keg.new(f.prefix).link - rescue Exception - onoe "The linking step did not complete successfully" - puts "The package built, but is not symlinked into #{HOMEBREW_PREFIX}" - puts "You can try again using `brew link #{f.name}'" - ohai e, e.inspect if ARGV.debug? + if f.keg_only? + ohai 'Caveats', text_for_keg_only_formula(f) show_summary_heading = true + else + begin + Keg.new(f.prefix).link + rescue Exception + onoe "The linking step did not complete successfully" + puts "The package built, but is not symlinked into #{HOMEBREW_PREFIX}" + puts "You can try again using `brew link #{f.name}'" + ohai e, e.inspect if ARGV.debug? + show_summary_heading = true + end end ohai "Summary" if ARGV.verbose? or show_summary_heading -- cgit v1.2.3