2023-02-14 15:39:32 -08:00
|
|
|
# typed: true
|
2019-04-19 15:38:03 +09:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2015-08-03 13:09:07 +01:00
|
|
|
require "requirement"
|
2013-05-24 08:37:16 -07:00
|
|
|
|
2020-08-19 06:51:15 +02:00
|
|
|
# A requirement on macOS.
|
|
|
|
#
|
|
|
|
# @api private
|
2017-10-06 10:12:09 -07:00
|
|
|
class MacOSRequirement < Requirement
|
2013-05-24 08:37:16 -07:00
|
|
|
fatal true
|
|
|
|
|
2020-03-02 16:29:49 -05:00
|
|
|
attr_reader :comparator, :version
|
|
|
|
|
2022-06-03 19:42:36 +01:00
|
|
|
# TODO: when Yosemite is removed here, keep these around as empty arrays so we
|
|
|
|
# can keep the deprecation/disabling code the same.
|
2023-07-06 16:47:09 +01:00
|
|
|
DISABLED_MACOS_VERSIONS = [
|
2022-06-03 19:42:36 +01:00
|
|
|
:yosemite,
|
|
|
|
].freeze
|
2023-07-06 16:47:09 +01:00
|
|
|
DEPRECATED_MACOS_VERSIONS = [].freeze
|
2022-06-03 19:42:36 +01:00
|
|
|
|
2019-08-15 07:53:28 +02:00
|
|
|
def initialize(tags = [], comparator: ">=")
|
2022-06-03 19:42:36 +01:00
|
|
|
@version = begin
|
|
|
|
if comparator == "==" && tags.first.respond_to?(:map)
|
2023-05-09 02:15:28 +02:00
|
|
|
tags.first.map { |s| MacOSVersion.from_symbol(s) }
|
2022-06-03 19:42:36 +01:00
|
|
|
else
|
2023-05-09 02:15:28 +02:00
|
|
|
MacOSVersion.from_symbol(tags.first) unless tags.empty?
|
2022-06-03 19:42:36 +01:00
|
|
|
end
|
2023-05-09 02:15:28 +02:00
|
|
|
rescue MacOSVersion::Error => e
|
2022-06-03 19:42:36 +01:00
|
|
|
if DISABLED_MACOS_VERSIONS.include?(e.version)
|
2023-07-06 16:47:09 +01:00
|
|
|
# This odisabled should stick around indefinitely.
|
|
|
|
odisabled "`depends_on macos: :#{e.version}`"
|
2022-06-03 19:42:36 +01:00
|
|
|
elsif DEPRECATED_MACOS_VERSIONS.include?(e.version)
|
2023-07-06 16:47:09 +01:00
|
|
|
# This odeprecated should stick around indefinitely.
|
|
|
|
odeprecated "`depends_on macos: :#{e.version}`"
|
2022-06-03 19:42:36 +01:00
|
|
|
else
|
|
|
|
raise
|
|
|
|
end
|
|
|
|
|
|
|
|
# Array of versions: remove the bad ones and try again.
|
|
|
|
if tags.first.respond_to?(:reject)
|
|
|
|
tags = [tags.first.reject { |s| s == e.version }, tags[1..]]
|
|
|
|
retry
|
|
|
|
end
|
|
|
|
|
|
|
|
# Otherwise fallback to the oldest allowed if comparator is >=.
|
2023-05-09 02:15:28 +02:00
|
|
|
MacOSVersion.new(HOMEBREW_MACOS_OLDEST_ALLOWED) if comparator == ">="
|
2019-08-15 10:14:10 +02:00
|
|
|
end
|
|
|
|
|
2019-08-15 07:53:28 +02:00
|
|
|
@comparator = comparator
|
2022-06-03 19:42:36 +01:00
|
|
|
super(tags.drop(1))
|
2013-05-24 08:37:16 -07:00
|
|
|
end
|
|
|
|
|
2019-08-15 07:53:28 +02:00
|
|
|
def version_specified?
|
2023-03-02 23:26:38 -05:00
|
|
|
@version.present?
|
2017-02-25 10:17:25 -08:00
|
|
|
end
|
|
|
|
|
|
|
|
satisfy(build_env: false) do
|
2023-02-14 15:39:32 -08:00
|
|
|
T.bind(self, MacOSRequirement)
|
2023-04-05 23:55:01 +08:00
|
|
|
next Array(@version).any? { |v| OS::Mac.version.compare(@comparator, v) } if OS.mac? && version_specified?
|
2017-02-25 10:17:25 -08:00
|
|
|
next true if OS.mac?
|
|
|
|
next true if @version
|
2018-09-17 02:45:00 +02:00
|
|
|
|
2017-02-25 10:17:25 -08:00
|
|
|
false
|
|
|
|
end
|
2013-05-24 08:37:16 -07:00
|
|
|
|
2019-08-15 10:14:10 +02:00
|
|
|
def message(type: :formula)
|
2020-11-01 12:26:18 -05:00
|
|
|
return "macOS is required for this software." unless version_specified?
|
2019-08-15 07:53:28 +02:00
|
|
|
|
|
|
|
case @comparator
|
|
|
|
when ">="
|
2023-03-02 23:26:38 -05:00
|
|
|
"This software does not run on macOS versions older than #{@version.pretty_name}."
|
2019-08-15 07:53:28 +02:00
|
|
|
when "<="
|
2019-08-15 10:14:10 +02:00
|
|
|
case type
|
|
|
|
when :formula
|
|
|
|
<<~EOS
|
|
|
|
This formula either does not compile or function as expected on macOS
|
|
|
|
versions newer than #{@version.pretty_name} due to an upstream incompatibility.
|
|
|
|
EOS
|
|
|
|
when :cask
|
2019-08-30 14:11:13 -04:00
|
|
|
"This cask does not run on macOS versions newer than #{@version.pretty_name}."
|
2019-08-15 10:14:10 +02:00
|
|
|
end
|
2019-08-15 07:53:28 +02:00
|
|
|
else
|
2019-08-15 10:14:10 +02:00
|
|
|
if @version.respond_to?(:to_ary)
|
2019-08-30 14:11:13 -04:00
|
|
|
*versions, last = @version.map(&:pretty_name)
|
2023-03-02 23:26:38 -05:00
|
|
|
return "This software does not run on macOS versions other than #{versions.join(", ")} and #{last}."
|
2019-08-15 10:14:10 +02:00
|
|
|
end
|
|
|
|
|
2023-03-02 23:26:38 -05:00
|
|
|
"This software does not run on macOS versions other than #{@version.pretty_name}."
|
2019-08-15 07:53:28 +02:00
|
|
|
end
|
2013-05-24 08:37:16 -07:00
|
|
|
end
|
2016-09-18 00:37:02 -04:00
|
|
|
|
2022-11-09 01:19:46 +00:00
|
|
|
def ==(other)
|
|
|
|
super(other) && comparator == other.comparator && version == other.version
|
|
|
|
end
|
|
|
|
alias eql? ==
|
|
|
|
|
|
|
|
def hash
|
|
|
|
[super, comparator, version].hash
|
|
|
|
end
|
|
|
|
|
2020-10-20 12:03:48 +02:00
|
|
|
sig { returns(String) }
|
2020-03-02 16:29:49 -05:00
|
|
|
def inspect
|
2020-11-01 12:22:56 -05:00
|
|
|
"#<#{self.class.name}: version#{@comparator}#{@version.to_s.inspect} #{tags.inspect}>"
|
2020-03-02 16:29:49 -05:00
|
|
|
end
|
|
|
|
|
2020-10-20 12:03:48 +02:00
|
|
|
sig { returns(String) }
|
2016-09-18 00:37:02 -04:00
|
|
|
def display_s
|
2020-11-16 23:22:18 -05:00
|
|
|
if version_specified?
|
|
|
|
if @version.respond_to?(:to_ary)
|
2023-03-02 23:26:38 -05:00
|
|
|
"macOS #{@comparator} #{version.join(" / ")} (or Linux)"
|
2020-11-16 23:22:18 -05:00
|
|
|
else
|
2023-03-02 23:26:38 -05:00
|
|
|
"macOS #{@comparator} #{@version} (or Linux)"
|
2020-11-16 23:22:18 -05:00
|
|
|
end
|
|
|
|
else
|
|
|
|
"macOS"
|
|
|
|
end
|
2016-09-18 00:37:02 -04:00
|
|
|
end
|
2019-08-30 14:11:13 -04:00
|
|
|
|
2023-02-14 15:39:32 -08:00
|
|
|
def to_json(options)
|
2019-08-30 14:11:13 -04:00
|
|
|
comp = @comparator.to_s
|
2023-02-14 15:39:32 -08:00
|
|
|
return { comp => @version.map(&:to_s) }.to_json(options) if @version.is_a?(Array)
|
2019-08-30 14:11:13 -04:00
|
|
|
|
2023-02-14 15:39:32 -08:00
|
|
|
{ comp => [@version.to_s] }.to_json(options)
|
2019-08-30 14:11:13 -04:00
|
|
|
end
|
2013-05-24 08:37:16 -07:00
|
|
|
end
|