Merge pull request #9422 from dawidd6/untap-force
untap: add --force switch
This commit is contained in:
commit
37fe150284
@ -2,6 +2,7 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
require "cli/parser"
|
require "cli/parser"
|
||||||
|
require "formula"
|
||||||
|
|
||||||
module Homebrew
|
module Homebrew
|
||||||
extend T::Sig
|
extend T::Sig
|
||||||
@ -16,6 +17,8 @@ module Homebrew
|
|||||||
|
|
||||||
Remove a tapped formula repository.
|
Remove a tapped formula repository.
|
||||||
EOS
|
EOS
|
||||||
|
switch "-f", "--force",
|
||||||
|
description: "Untap even if formulae or casks from this tap are currently installed."
|
||||||
|
|
||||||
min_named 1
|
min_named 1
|
||||||
end
|
end
|
||||||
@ -28,6 +31,23 @@ module Homebrew
|
|||||||
tap = Tap.fetch(tapname)
|
tap = Tap.fetch(tapname)
|
||||||
odie "Untapping #{tap} is not allowed" if tap.core_tap?
|
odie "Untapping #{tap} is not allowed" if tap.core_tap?
|
||||||
|
|
||||||
|
installed_tap_formulae = Formula.installed.select { |formula| formula.tap == tap }
|
||||||
|
installed_tap_casks = Cask::Caskroom.casks.select { |cask| cask.tap == tap }
|
||||||
|
|
||||||
|
if installed_tap_formulae.length.positive? || installed_tap_casks.length.positive?
|
||||||
|
if args.force?
|
||||||
|
opoo <<~EOS
|
||||||
|
Untapping #{tap} even though it contains the following installed formulae or casks:
|
||||||
|
#{(installed_tap_formulae + installed_tap_casks.map(&:token)).join("\n")}
|
||||||
|
EOS
|
||||||
|
else
|
||||||
|
odie <<~EOS
|
||||||
|
Refusing to untap #{tap} because it contains the following installed formulae or casks:
|
||||||
|
#{(installed_tap_formulae + installed_tap_casks.map(&:token)).join("\n")}
|
||||||
|
EOS
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
tap.uninstall
|
tap.uninstall
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -572,6 +572,9 @@ See also `pin`.
|
|||||||
|
|
||||||
Remove a tapped formula repository.
|
Remove a tapped formula repository.
|
||||||
|
|
||||||
|
* `-f`, `--force`:
|
||||||
|
Untap even if formulae or casks from this tap are currently installed.
|
||||||
|
|
||||||
### `update` [*`options`*]
|
### `update` [*`options`*]
|
||||||
|
|
||||||
Fetch the newest version of Homebrew and all formulae from GitHub using `git`(1) and perform any necessary migrations.
|
Fetch the newest version of Homebrew and all formulae from GitHub using `git`(1) and perform any necessary migrations.
|
||||||
|
|||||||
@ -770,6 +770,10 @@ Unpin \fIformula\fR, allowing them to be upgraded by \fBbrew upgrade\fR \fIformu
|
|||||||
.SS "\fBuntap\fR \fItap\fR"
|
.SS "\fBuntap\fR \fItap\fR"
|
||||||
Remove a tapped formula repository\.
|
Remove a tapped formula repository\.
|
||||||
.
|
.
|
||||||
|
.TP
|
||||||
|
\fB\-f\fR, \fB\-\-force\fR
|
||||||
|
Untap even if formulae or casks from this tap are currently installed\.
|
||||||
|
.
|
||||||
.SS "\fBupdate\fR [\fIoptions\fR]"
|
.SS "\fBupdate\fR [\fIoptions\fR]"
|
||||||
Fetch the newest version of Homebrew and all formulae from GitHub using \fBgit\fR(1) and perform any necessary migrations\.
|
Fetch the newest version of Homebrew and all formulae from GitHub using \fBgit\fR(1) and perform any necessary migrations\.
|
||||||
.
|
.
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user