# typed: false # frozen_string_literal: true require "formula_installer" require "development_tools" require "messages" require "install" require "reinstall" require "cli/parser" require "cleanup" require "cask/cmd" require "cask/utils" require "cask/macos" require "upgrade" require "bottle_api" module Homebrew extend T::Sig module_function sig { returns(CLI::Parser) } def reinstall_args Homebrew::CLI::Parser.new do description <<~EOS Uninstall and then reinstall a or using the same options it was originally installed with, plus any appended options specific to a . Unless `HOMEBREW_NO_INSTALL_CLEANUP` is set, `brew cleanup` will then be run for the reinstalled formulae or, every 30 days, for all formulae. EOS switch "-d", "--debug", description: "If brewing fails, open an interactive debugging session with access to IRB " \ "or a shell inside the temporary build directory." switch "-f", "--force", description: "Install without checking for previously installed keg-only or " \ "non-migrated versions." switch "-v", "--verbose", description: "Print the verification and postinstall steps." [ [:switch, "--formula", "--formulae", { description: "Treat all named arguments as formulae." }], [:switch, "-s", "--build-from-source", { description: "Compile from source even if a bottle is available.", }], [:switch, "-i", "--interactive", { description: "Download and patch , then open a shell. This allows the user to " \ "run `./configure --help` and otherwise determine how to turn the software " \ "package into a Homebrew package.", }], [:switch, "--force-bottle", { description: "Install from a bottle if it exists for the current or newest version of " \ "macOS, even if it would not normally be used for installation.", }], [:switch, "--keep-tmp", { description: "Retain the temporary files created during installation.", }], [:switch, "--display-times", { env: :display_install_times, description: "Print install times for each formula at the end of the run.", }], [:switch, "-g", "--git", { description: "Create a Git repository, useful for creating patches to the software.", }], ].each do |options| send(*options) conflicts "--cask", options[-2] end formula_options [ [:switch, "--cask", "--casks", { description: "Treat all named arguments as casks." }], *Cask::Cmd::AbstractCommand::OPTIONS, *Cask::Cmd::Install::OPTIONS, ].each do |options| send(*options) conflicts "--formula", options[-2] end cask_options conflicts "--build-from-source", "--force-bottle" named_args [:formula, :cask], min: 1 end end def reinstall args = reinstall_args.parse if ENV["HOMEBREW_JSON_CORE"].present? args.named.each do |name| formula = Formulary.factory(name) next unless formula.any_version_installed? next if formula.tap.present? && !formula.core_formula? next unless BottleAPI.bottle_available?(name) BottleAPI.fetch_bottles(name) rescue FormulaUnavailableError next end end formulae, casks = args.named.to_formulae_and_casks(method: :resolve) .partition { |o| o.is_a?(Formula) } if args.build_from_source? && !DevelopmentTools.installed? raise BuildFlagsError.new(["--build-from-source"], bottled: formulae.all?(&:bottled?)) end Install.perform_preinstall_checks formulae.each do |formula| if formula.pinned? onoe "#{formula.full_name} is pinned. You must unpin it to reinstall." next end Migrator.migrate_if_needed(formula, force: args.force?) reinstall_formula( formula, flags: args.flags_only, installed_on_request: args.named.present?, force_bottle: args.force_bottle?, build_from_source_formulae: args.build_from_source_formulae, interactive: args.interactive?, keep_tmp: args.keep_tmp?, force: args.force?, debug: args.debug?, quiet: args.quiet?, verbose: args.verbose?, git: args.git?, ) Cleanup.install_formula_clean!(formula) end Upgrade.check_installed_dependents( formulae, flags: args.flags_only, installed_on_request: args.named.present?, force_bottle: args.force_bottle?, build_from_source_formulae: args.build_from_source_formulae, interactive: args.interactive?, keep_tmp: args.keep_tmp?, force: args.force?, debug: args.debug?, quiet: args.quiet?, verbose: args.verbose?, ) if casks.any? Cask::Cmd::Reinstall.reinstall_casks( *casks, binaries: args.binaries?, verbose: args.verbose?, force: args.force?, require_sha: args.require_sha?, skip_cask_deps: args.skip_cask_deps?, quarantine: args.quarantine?, ) end Homebrew.messages.display_messages(display_times: args.display_times?) end end