Class: Homebrew::Bundle::Extension Abstract Private
- Inherits:
-
PackageType
- Object
- PackageType
- Homebrew::Bundle::Extension
- Extended by:
- T::Helpers
- Defined in:
- bundle/extensions/extension.rb
Overview
This class is part of a private API. This class may only be used in the Homebrew/brew repository. Third parties should avoid using this class if possible, as it may be removed or changed without warning.
It cannot be directly instantiated. Subclasses must implement the abstract methods below.
Direct Known Subclasses
Cargo, Flatpak, Go, Krew, MacAppStore, Npm, Uv, VscodeExtension
Class Method Summary collapse
- .add_supported? ⇒ Boolean private
- .banner_name ⇒ String private
- .check(entries, exit_on_first_error: false, no_upgrade: false, verbose: false) ⇒ Array<Object> private
- .check_label ⇒ String private
- .cleanup!(items) ⇒ void private
- .cleanup_heading ⇒ String? private
- .cleanup_items(entries) ⇒ Array<String> private
- .cleanup_supported? ⇒ Boolean private
- .dump ⇒ String private
- .dump_disable_description ⇒ String private
- .dump_disable_env ⇒ Symbol private
- .dump_disable_predicate_method ⇒ Symbol private
- .dump_disable_supported? ⇒ Boolean private
- .dump_entry(package) ⇒ String private
- .dump_name(package) ⇒ String private
- .dump_output(describe: false, no_restart: false) ⇒ String private
- .dump_supported? ⇒ Boolean private
- .dump_with(_package) ⇒ Array<String>? private
- .entry(name, options = {}) ⇒ Dsl::Entry private
- .fetchable_name(name, options = {}, no_upgrade: false) ⇒ String? private
- .flag ⇒ String private
- .inherited(subclass) ⇒ void private
- .install!(name, with: nil, preinstall: true, no_upgrade: false, verbose: false, force: false, **_options) ⇒ Boolean private
- .install_package!(name, with: nil, verbose: false) ⇒ Boolean private
- .install_supported? ⇒ Boolean private
- .install_verb(_name = "", _options = {}) ⇒ String private
- .installed_packages ⇒ Array<T.untyped> abstract private
- .legacy_check_step ⇒ Symbol private
- .package_description ⇒ String private
- .package_installed?(name, with: nil) ⇒ Boolean private
- .package_manager_env(executable) ⇒ Hash{String => String} private
- .package_manager_executable ⇒ Pathname? private
- .package_manager_executable! ⇒ Pathname private
- .package_manager_installed? ⇒ Boolean private
- .package_manager_name ⇒ String private
- .package_record(name, with: nil) ⇒ Object private
- .packages ⇒ Array<T.untyped> abstract private
- .predicate_method ⇒ Symbol private
- .preinstall!(name, with: nil, no_upgrade: false, verbose: false, **_options) ⇒ Boolean private
- .quote(value) ⇒ String private
- .remove_supported? ⇒ Boolean private
- .reset! ⇒ void abstract private
- .switch_description ⇒ String private
- .type ⇒ Symbol private
- .uninstall_package!(name, executable: Pathname.new("")) ⇒ void private
- .with_package_manager_env(&_blk) ⇒ T.type_parameter(:U) private
Instance Method Summary collapse
- #failure_reason(package, no_upgrade:) ⇒ String private
- #installed_and_up_to_date?(package, no_upgrade: false) ⇒ Boolean private
Methods inherited from PackageType
#checkable_entries, #exit_early_check, #find_actionable, #format_checkable, #full_check
Class Method Details
.add_supported? ⇒ Boolean
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.
128 129 130 |
# File 'bundle/extensions/extension.rb', line 128 def self.add_supported? true end |
.banner_name ⇒ 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.
32 33 34 |
# File 'bundle/extensions/extension.rb', line 32 def self. T.cast(const_get(:BANNER_NAME), String) end |
.check(entries, exit_on_first_error: false, no_upgrade: false, verbose: false) ⇒ Array<Object>
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.
227 228 229 |
# File 'bundle/extensions/extension.rb', line 227 def self.check(entries, exit_on_first_error: false, no_upgrade: false, verbose: false) new.find_actionable(entries, exit_on_first_error:, no_upgrade:, verbose:) end |
.check_label ⇒ 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.
27 28 29 |
# File 'bundle/extensions/extension.rb', line 27 def self.check_label T.cast(const_get(:PACKAGE_TYPE_NAME), String) end |
.cleanup!(items) ⇒ void
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.
This method returns an undefined value.
251 252 253 254 255 256 257 258 259 260 261 |
# File 'bundle/extensions/extension.rb', line 251 def self.cleanup!(items) executable = package_manager_executable return if executable.nil? with_env(package_manager_env(executable)) do items.each do |name| uninstall_package!(name, executable:) end end puts "Uninstalled #{items.size} #{}#{"s" if items.size != 1}" end |
.cleanup_heading ⇒ 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.
163 164 165 |
# File 'bundle/extensions/extension.rb', line 163 def self.cleanup_heading nil end |
.cleanup_items(entries) ⇒ Array<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.
232 233 234 235 236 237 238 239 240 241 242 243 |
# File 'bundle/extensions/extension.rb', line 232 def self.cleanup_items(entries) return [].freeze unless package_manager_installed? kept_packages = entries.filter_map do |entry| entry.name if entry.type == type end return [].freeze if kept_packages.empty? installed_names = packages.map { |pkg| dump_name(pkg) } installed_names - kept_packages end |
.cleanup_supported? ⇒ Boolean
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.
168 169 170 |
# File 'bundle/extensions/extension.rb', line 168 def self.cleanup_supported? !cleanup_heading.nil? end |
.dump ⇒ 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.
207 208 209 |
# File 'bundle/extensions/extension.rb', line 207 def self.dump packages.map { |package| dump_entry(package) }.join("\n") end |
.dump_disable_description ⇒ 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.
108 109 110 |
# File 'bundle/extensions/extension.rb', line 108 def self.dump_disable_description "`dump` without #{}." end |
.dump_disable_env ⇒ 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.
113 114 115 |
# File 'bundle/extensions/extension.rb', line 113 def self.dump_disable_env :"bundle_dump_no_#{type}" end |
.dump_disable_predicate_method ⇒ 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.
123 124 125 |
# File 'bundle/extensions/extension.rb', line 123 def self.dump_disable_predicate_method :"no_#{type}?" end |
.dump_disable_supported? ⇒ Boolean
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.
118 119 120 |
# File 'bundle/extensions/extension.rb', line 118 def self.dump_disable_supported? true end |
.dump_entry(package) ⇒ 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.
182 183 184 185 186 187 188 189 |
# File 'bundle/extensions/extension.rb', line 182 def self.dump_entry(package) line = "#{type} #{quote(dump_name(package))}" with = dump_with(package) return line if with.blank? formatted_with = with.map { |requirement| quote(requirement) }.join(", ") "#{line}, with: [#{formatted_with}]" end |
.dump_name(package) ⇒ 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.
197 198 199 |
# File 'bundle/extensions/extension.rb', line 197 def self.dump_name(package) package.to_s end |
.dump_output(describe: false, no_restart: false) ⇒ 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.
212 213 214 215 216 217 |
# File 'bundle/extensions/extension.rb', line 212 def self.dump_output(describe: false, no_restart: false) _ = describe _ = no_restart dump end |
.dump_supported? ⇒ Boolean
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.
103 104 105 |
# File 'bundle/extensions/extension.rb', line 103 def self.dump_supported? true end |
.dump_with(_package) ⇒ Array<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.
202 203 204 |
# File 'bundle/extensions/extension.rb', line 202 def self.dump_with(_package) nil end |
.entry(name, options = {}) ⇒ Dsl::Entry
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.
46 47 48 49 50 |
# File 'bundle/extensions/extension.rb', line 46 def self.entry(name, = {}) raise "unknown options(#{.keys.inspect}) for #{type}" if .present? Dsl::Entry.new(type, name) end |
.fetchable_name(name, options = {}, no_upgrade: false) ⇒ 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.
154 155 156 157 158 159 160 |
# File 'bundle/extensions/extension.rb', line 154 def self.fetchable_name(name, = {}, no_upgrade: false) _ = name _ = _ = no_upgrade nil end |
.flag ⇒ 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.
53 54 55 |
# File 'bundle/extensions/extension.rb', line 53 def self.flag type.to_s.tr("_", "-") end |
.inherited(subclass) ⇒ void
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.
This method returns an undefined value.
16 17 18 19 |
# File 'bundle/extensions/extension.rb', line 16 def self.inherited(subclass) super Homebrew::Bundle.register_extension(T.cast(subclass, T.class_of(Homebrew::Bundle::Extension))) end |
.install!(name, with: nil, preinstall: true, no_upgrade: false, verbose: false, force: false, **_options) ⇒ Boolean
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.
330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 |
# File 'bundle/extensions/extension.rb', line 330 def self.install!(name, with: nil, preinstall: true, no_upgrade: false, verbose: false, force: false, **) _ = no_upgrade _ = force return true unless preinstall puts "Installing #{name} #{package_description}. It is not currently installed." if verbose return false unless install_package!(name, with:, verbose:) package = package_record(name, with:) installed_packages << package unless installed_packages.include?(package) packages << package unless packages.include?(package) true end |
.install_package!(name, with: nil, verbose: false) ⇒ Boolean
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.
363 364 365 366 367 368 369 |
# File 'bundle/extensions/extension.rb', line 363 def self.install_package!(name, with: nil, verbose: false) _ = name _ = with _ = verbose raise NotImplementedError, "#{self} must override `install_package!` or `install!`." end |
.install_supported? ⇒ Boolean
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.
138 139 140 |
# File 'bundle/extensions/extension.rb', line 138 def self.install_supported? true end |
.install_verb(_name = "", _options = {}) ⇒ 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.
143 144 145 |
# File 'bundle/extensions/extension.rb', line 143 def self.install_verb(_name = "", = {}) "Installing" end |
.installed_packages ⇒ Array<T.untyped>
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.
179 |
# File 'bundle/extensions/extension.rb', line 179 def self.installed_packages; end |
.legacy_check_step ⇒ 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.
246 247 248 |
# File 'bundle/extensions/extension.rb', line 246 def self.legacy_check_step :registered_extensions_to_install end |
.package_description ⇒ 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 |
# File 'bundle/extensions/extension.rb', line 98 def self.package_description check_label.downcase end |
.package_installed?(name, with: nil) ⇒ Boolean
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.
276 277 278 |
# File 'bundle/extensions/extension.rb', line 276 def self.package_installed?(name, with: nil) installed_packages.include?(package_record(name, with:)) end |
.package_manager_env(executable) ⇒ Hash{String => 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.
83 84 85 |
# File 'bundle/extensions/extension.rb', line 83 def self.package_manager_env(executable) { "PATH" => "#{executable.dirname}:#{ORIGINAL_PATHS.join(":")}" } end |
.package_manager_executable ⇒ Pathname?
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.
73 74 75 |
# File 'bundle/extensions/extension.rb', line 73 def self.package_manager_executable which(package_manager_name, ORIGINAL_PATHS) end |
.package_manager_executable! ⇒ Pathname
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.
78 79 80 |
# File 'bundle/extensions/extension.rb', line 78 def self.package_manager_executable! package_manager_executable || raise("#{package_manager_name} is not installed") end |
.package_manager_installed? ⇒ Boolean
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.
68 69 70 |
# File 'bundle/extensions/extension.rb', line 68 def self.package_manager_installed? package_manager_executable.present? end |
.package_manager_name ⇒ 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.
63 64 65 |
# File 'bundle/extensions/extension.rb', line 63 def self.package_manager_name flag end |
.package_record(name, with: nil) ⇒ Object
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.
269 270 271 272 273 |
# File 'bundle/extensions/extension.rb', line 269 def self.package_record(name, with: nil) _ = with name end |
.packages ⇒ Array<T.untyped>
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.
176 |
# File 'bundle/extensions/extension.rb', line 176 def self.packages; end |
.predicate_method ⇒ 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.
58 59 60 |
# File 'bundle/extensions/extension.rb', line 58 def self.predicate_method :"#{type}?" end |
.preinstall!(name, with: nil, no_upgrade: false, verbose: false, **_options) ⇒ Boolean
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.
289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 |
# File 'bundle/extensions/extension.rb', line 289 def self.preinstall!(name, with: nil, no_upgrade: false, verbose: false, **) _ = no_upgrade unless package_manager_installed? puts "Installing #{package_manager_name}. It is not currently installed." if verbose Bundle.system(HOMEBREW_BREW_FILE, "install", "--formula", package_manager_name, verbose:) # `formula_versions_from_env` consumes the env vars once at startup, so # keep the cached values across reset when bootstrapping a manager. formula_versions_from_env = T.let( Bundle.formula_versions_from_env_cache, T.nilable(T::Hash[String, String]), ) upgrade_formulae = Bundle.upgrade_formulae Bundle.reset! Bundle.formula_versions_from_env_cache = formula_versions_from_env Bundle.upgrade_formulae = upgrade_formulae.join(",") unless package_manager_installed? raise "Unable to install #{name} #{package_description}. " \ "#{package_manager_name} installation failed." end end if package_installed?(name, with:) puts "Skipping install of #{name} #{package_description}. It is already installed." if verbose return false end true end |
.quote(value) ⇒ 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.
192 193 194 |
# File 'bundle/extensions/extension.rb', line 192 def self.quote(value) value.inspect end |
.remove_supported? ⇒ Boolean
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.
133 134 135 |
# File 'bundle/extensions/extension.rb', line 133 def self.remove_supported? true end |
.reset! ⇒ void
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.
This method returns an undefined value.
173 |
# File 'bundle/extensions/extension.rb', line 173 def self.reset!; end |
.switch_description ⇒ 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.
37 38 39 40 41 42 43 |
# File 'bundle/extensions/extension.rb', line 37 def self.switch_description if cleanup_supported? "`list`, `dump` or `cleanup` #{}." else "`list` or `dump` #{}." end end |
.type ⇒ 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.
22 23 24 |
# File 'bundle/extensions/extension.rb', line 22 def self.type T.cast(const_get(:PACKAGE_TYPE), Symbol) end |
.uninstall_package!(name, executable: Pathname.new("")) ⇒ void
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.
This method returns an undefined value.
264 265 266 |
# File 'bundle/extensions/extension.rb', line 264 def self.uninstall_package!(name, executable: Pathname.new("")) raise NotImplementedError, "#{self} must override `uninstall_package!` or `cleanup!`." end |
.with_package_manager_env(&_blk) ⇒ T.type_parameter(:U)
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.
92 93 94 95 |
# File 'bundle/extensions/extension.rb', line 92 def self.with_package_manager_env(&_blk) executable = package_manager_executable! with_env(package_manager_env(executable)) { yield executable } end |
Instance Method Details
#failure_reason(package, no_upgrade:) ⇒ 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.
347 348 349 |
# File 'bundle/extensions/extension.rb', line 347 def failure_reason(package, no_upgrade:) "#{self.class.check_label} #{self.class.dump_name(package)} needs to be installed." end |
#installed_and_up_to_date?(package, no_upgrade: false) ⇒ Boolean
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.
352 353 354 |
# File 'bundle/extensions/extension.rb', line 352 def installed_and_up_to_date?(package, no_upgrade: false) self.class.package_installed?(self.class.dump_name(package), with: self.class.dump_with(package)) end |