Module: DeprecateDisable
- Defined in:
- deprecate_disable.rb
Overview
This module is part of an internal API. This module may only be used internally in repositories owned by Homebrew, except in casks or formulae. Third parties should avoid using this module if possible, as it may be removed or changed without warning.
Helper module for handling disable!
and deprecate!
.
Constant Summary collapse
- FORMULA_DEPRECATE_DISABLE_REASONS =
This constant is part of an internal API. This constant may only be used internally in repositories owned by Homebrew, except in casks or formulae. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.
T.let({ does_not_build: "does not build", no_license: "has no license", repo_archived: "has an archived upstream repository", repo_removed: "has a removed upstream repository", unmaintained: "is not maintained upstream", unsupported: "is not supported upstream", deprecated_upstream: "is deprecated upstream", versioned_formula: "is a versioned formula", checksum_mismatch: "was built with an initially released source file that had " \ "a different checksum than the current one. " \ "Upstream's repository might have been compromised. " \ "We can re-package this once upstream has confirmed that they retagged their release", }.freeze, T::Hash[Symbol, String])
- CASK_DEPRECATE_DISABLE_REASONS =
This constant is part of an internal API. This constant may only be used internally in repositories owned by Homebrew, except in casks or formulae. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.
T.let({ discontinued: "is discontinued upstream", moved_to_mas: "is now exclusively distributed on the Mac App Store", no_longer_available: "is no longer available upstream", no_longer_meets_criteria: "no longer meets the criteria for acceptable casks", unmaintained: "is not maintained upstream", unsigned: "is unsigned or does not meet signature requirements", }.freeze, T::Hash[Symbol, String])
- REMOVE_DISABLED_TIME_WINDOW =
This constant is part of a private API. This constant may only be used in the Homebrew/brew repository. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.
One year when << or >> to Date.today.
12
- REMOVE_DISABLED_BEFORE =
This constant is part of an internal API. This constant may only be used internally in repositories owned by Homebrew, except in casks or formulae. Third parties should avoid using this constant if possible, as it may be removed or changed without warning.
T.let((Date.today << REMOVE_DISABLED_TIME_WINDOW).freeze, Date)
Class Method Summary collapse
- .message(formula_or_cask) ⇒ String? private
- .to_reason_string_or_symbol(string, type:) ⇒ String, ... private
- .type(formula_or_cask) ⇒ Symbol? private
Class Method Details
.message(formula_or_cask) ⇒ String?
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 |
# File 'deprecate_disable.rb', line 45 def (formula_or_cask) return if type(formula_or_cask).blank? reason = if formula_or_cask.deprecated? formula_or_cask.deprecation_reason elsif formula_or_cask.disabled? formula_or_cask.disable_reason end reason = if formula_or_cask.is_a?(Formula) && FORMULA_DEPRECATE_DISABLE_REASONS.key?(reason) FORMULA_DEPRECATE_DISABLE_REASONS[reason] elsif formula_or_cask.is_a?(Cask::Cask) && CASK_DEPRECATE_DISABLE_REASONS.key?(reason) CASK_DEPRECATE_DISABLE_REASONS[reason] else reason end = if reason.present? "#{type(formula_or_cask)} because it #{reason}!" else "#{type(formula_or_cask)}!" end disable_date = formula_or_cask.disable_date if !disable_date && formula_or_cask.deprecation_date disable_date = formula_or_cask.deprecation_date >> REMOVE_DISABLED_TIME_WINDOW end if disable_date += if disable_date < Date.today " It was disabled on #{disable_date}." else " It will be disabled on #{disable_date}." end end replacement = if formula_or_cask.deprecated? formula_or_cask.deprecation_replacement elsif formula_or_cask.disabled? formula_or_cask.disable_replacement end if replacement.present? << "\n" << <<~EOS Replacement: brew install #{replacement} EOS end end |
.to_reason_string_or_symbol(string, type:) ⇒ String, ...
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
98 99 100 101 102 103 104 105 106 107 |
# File 'deprecate_disable.rb', line 98 def to_reason_string_or_symbol(string, type:) return if string.nil? if (type == :formula && FORMULA_DEPRECATE_DISABLE_REASONS.key?(string.to_sym)) || (type == :cask && CASK_DEPRECATE_DISABLE_REASONS.key?(string.to_sym)) return string.to_sym end string end |
.type(formula_or_cask) ⇒ Symbol?
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
38 39 40 41 42 |
# File 'deprecate_disable.rb', line 38 def type(formula_or_cask) return :deprecated if formula_or_cask.deprecated? :disabled if formula_or_cask.disabled? end |