diff options
Diffstat (limited to 'Library/Homebrew/build_options.rb')
| -rw-r--r-- | Library/Homebrew/build_options.rb | 39 |
1 files changed, 36 insertions, 3 deletions
diff --git a/Library/Homebrew/build_options.rb b/Library/Homebrew/build_options.rb index 05f8507de..2e8f741d4 100644 --- a/Library/Homebrew/build_options.rb +++ b/Library/Homebrew/build_options.rb @@ -1,13 +1,28 @@ class BuildOptions + # @private def initialize(args, options) @args = args @options = options end + # True if a {Formula} is being built with a specific option + # (which isn't named `with-*` or `without-*`). + # @deprecated def include?(name) @args.include?("--#{name}") end + # True if a {Formula} is being built with a specific option. + # <pre>args << "--i-want-spam" if build.with? "spam" + # + # args << "--qt-gui" if build.with? "qt" # "--with-qt" ==> build.with? "qt" + # + # # If a formula presents a user with a choice, but the choice must be fulfilled: + # if build.with? "example2" + # args << "--with-example2" + # else + # args << "--with-example1" + # end</pre> def with?(val) name = val.respond_to?(:option_name) ? val.option_name : val @@ -20,47 +35,65 @@ class BuildOptions end end + # True if a {Formula} is being built without a specific option. + # <pre>args << "--no-spam-plz" if build.without? "spam" def without?(name) !with? name end + # True if a {Formula} is being built as a bottle (i.e. binary package). def bottle? include? "build-bottle" end + # True if a {Formula} is being built with {Formula.head} instead of {Formula.stable}. + # <pre>args << "--some-new-stuff" if build.head?</pre> + # <pre># If there are multiple conditional arguments use a block instead of lines. + # if build.head? + # args << "--i-want-pizza" + # args << "--and-a-cold-beer" if build.with? "cold-beer" + # end</pre> def head? include? "HEAD" end + # True if a {Formula} is being built with {Formula.devel} instead of {Formula.stable}. + # <pre>args << "--some-beta" if build.devel?</pre> def devel? include? "devel" end + # True if a {Formula} is being built with {Formula.stable} instead of {Formula.devel} or {Formula.head}. This is the default. + # <pre>args << "--some-beta" if build.devel?</pre> def stable? !(head? || devel?) end - # True if the user requested a universal build. + # True if a {Formula} is being built universally. + # e.g. on newer Intel Macs this means a combined x86_64/x86 binary/library. + # <pre>args << "--universal-binary" if build.universal?</pre> def universal? include?("universal") && option_defined?("universal") end - # True if the user requested to enable C++11 mode. + # True if a {Formula} is being built in C++11 mode. def cxx11? include?("c++11") && option_defined?("c++11") end - # Request a 32-bit only build. + # True if a {Formula} is being built in 32-bit/x86 mode. # This is needed for some use-cases though we prefer to build Universal # when a 32-bit version is needed. def build_32_bit? include?("32-bit") && option_defined?("32-bit") end + # @private def used_options @options & @args end + # @private def unused_options @options - @args end |
