2016-04-08 16:28:43 +02:00
|
|
|
#: * `tap`:
|
|
|
|
#: List all installed taps.
|
|
|
|
#:
|
2018-04-12 16:14:02 -07:00
|
|
|
#: * `tap` [`--full`] [`--force-auto-update`] <user>`/`<repo> [<URL>]:
|
2016-04-08 16:28:43 +02:00
|
|
|
#: Tap a formula repository.
|
|
|
|
#:
|
|
|
|
#: With <URL> unspecified, taps a formula repository from GitHub using HTTPS.
|
|
|
|
#: Since so many taps are hosted on GitHub, this command is a shortcut for
|
2018-10-06 00:31:10 -04:00
|
|
|
#: `brew tap` <user>`/`<repo> `https://github.com/`<user>`/homebrew-`<repo>.
|
2016-04-08 16:28:43 +02:00
|
|
|
#:
|
|
|
|
#: With <URL> specified, taps a formula repository from anywhere, using
|
|
|
|
#: any transport protocol that `git` handles. The one-argument form of `tap`
|
|
|
|
#: simplifies but also limits. This two-argument command makes no
|
|
|
|
#: assumptions, so taps can be cloned from places other than GitHub and
|
|
|
|
#: using protocols other than HTTPS, e.g., SSH, GIT, HTTP, FTP(S), RSYNC.
|
|
|
|
#:
|
|
|
|
#: By default, the repository is cloned as a shallow copy (`--depth=1`), but
|
|
|
|
#: if `--full` is passed, a full clone will be used. To convert a shallow copy
|
|
|
|
#: to a full copy, you can retap passing `--full` without first untapping.
|
|
|
|
#:
|
2018-04-12 16:14:02 -07:00
|
|
|
#: By default, only taps hosted on GitHub are auto-updated (for performance
|
|
|
|
#: reasons). If `--force-auto-update` is passed, this tap will be auto-updated
|
|
|
|
#: even if it is not hosted on GitHub.
|
|
|
|
#:
|
2016-04-08 16:28:43 +02:00
|
|
|
#: `tap` is re-runnable and exits successfully if there's nothing to do.
|
|
|
|
#: However, retapping with a different <URL> will cause an exception, so first
|
|
|
|
#: `untap` if you need to modify the <URL>.
|
|
|
|
#:
|
|
|
|
#: * `tap` `--repair`:
|
|
|
|
#: Migrate tapped formulae from symlink-based to directory-based structure.
|
|
|
|
#:
|
|
|
|
#: * `tap` `--list-pinned`:
|
|
|
|
#: List all pinned taps.
|
|
|
|
|
2014-06-18 22:41:47 -05:00
|
|
|
module Homebrew
|
2016-09-26 01:44:51 +02:00
|
|
|
module_function
|
|
|
|
|
2012-03-02 20:28:54 +00:00
|
|
|
def tap
|
2015-12-26 13:01:52 +08:00
|
|
|
if ARGV.include? "--repair"
|
2016-09-30 18:22:53 -05:00
|
|
|
Tap.each(&:link_completions_and_manpages)
|
2015-12-26 13:01:52 +08:00
|
|
|
elsif ARGV.include? "--list-official"
|
2018-07-09 15:29:40 +01:00
|
|
|
odisabled("brew tap --list-official")
|
2015-12-26 13:01:52 +08:00
|
|
|
elsif ARGV.include? "--list-pinned"
|
2015-08-21 12:33:33 +08:00
|
|
|
puts Tap.select(&:pinned?).map(&:name)
|
2015-12-26 13:01:52 +08:00
|
|
|
elsif ARGV.named.empty?
|
|
|
|
puts Tap.names
|
2012-03-02 20:28:54 +00:00
|
|
|
else
|
2015-12-26 13:01:52 +08:00
|
|
|
tap = Tap.fetch(ARGV.named[0])
|
2015-11-10 18:33:57 +08:00
|
|
|
begin
|
2016-09-17 15:32:44 +01:00
|
|
|
tap.install clone_target: ARGV.named[1],
|
2018-04-12 16:14:02 -07:00
|
|
|
force_auto_update: force_auto_update?,
|
2016-09-17 15:32:44 +01:00
|
|
|
full_clone: full_clone?,
|
|
|
|
quiet: ARGV.quieter?
|
2016-04-04 03:18:55 -07:00
|
|
|
rescue TapRemoteMismatchError => e
|
|
|
|
odie e
|
2017-10-07 00:31:28 +02:00
|
|
|
rescue TapAlreadyTappedError, TapAlreadyUnshallowError # rubocop:disable Lint/HandleExceptions
|
2015-11-10 09:12:25 +00:00
|
|
|
end
|
2012-03-02 20:28:54 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-05-30 17:01:36 +01:00
|
|
|
def full_clone?
|
|
|
|
ARGV.include?("--full") || ARGV.homebrew_developer?
|
|
|
|
end
|
2018-04-12 16:14:02 -07:00
|
|
|
|
|
|
|
def force_auto_update?
|
|
|
|
# if no relevant flag is present, return nil, meaning "no change"
|
|
|
|
true if ARGV.include?("--force-auto-update")
|
|
|
|
end
|
2012-03-16 12:49:09 +00:00
|
|
|
end
|