aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Homebrew/build_options.rb
diff options
context:
space:
mode:
Diffstat (limited to 'Library/Homebrew/build_options.rb')
-rw-r--r--Library/Homebrew/build_options.rb39
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