diff options
| author | Markus Reiter | 2017-04-25 12:50:23 +0200 |
|---|---|---|
| committer | GitHub | 2017-04-25 12:50:23 +0200 |
| commit | 24a339ee239a4e13e5162085780687fcd2b7bc9f (patch) | |
| tree | 4a53d351a1135b10032b73c129c29c68c2a3a3f6 /Library/Homebrew/cmd | |
| parent | a38133e5a116ac3e08a856e38ce76dc5453a963f (diff) | |
| parent | 133e5ddf6ad1b7c931f4686922ba4d61ea450f3a (diff) | |
| download | brew-24a339ee239a4e13e5162085780687fcd2b7bc9f.tar.bz2 | |
Merge pull request #2541 from reitermarkus/cask-search
Add remote search to `brew cask search`.
Diffstat (limited to 'Library/Homebrew/cmd')
| -rw-r--r-- | Library/Homebrew/cmd/search.rb | 26 |
1 files changed, 10 insertions, 16 deletions
diff --git a/Library/Homebrew/cmd/search.rb b/Library/Homebrew/cmd/search.rb index 110e1559e..f71a14ba1 100644 --- a/Library/Homebrew/cmd/search.rb +++ b/Library/Homebrew/cmd/search.rb @@ -59,7 +59,7 @@ module Homebrew local_results = search_formulae(regex) puts Formatter.columns(local_results) unless local_results.empty? tap_results = search_taps(query) - puts Formatter.columns(tap_results) if tap_results && !tap_results.empty? + puts Formatter.columns(tap_results) unless tap_results.empty? if $stdout.tty? count = local_results.length + tap_results.length @@ -101,21 +101,15 @@ module Homebrew end def search_taps(query) - valid_dirnames = ["Formula", "HomebrewFormula", "Casks", ".", ""].freeze - q = "user:Homebrew%20user:caskroom%20filename:#{query}" - GitHub.open "https://api.github.com/search/code?q=#{q}" do |json| - json["items"].map do |object| - dirname, filename = File.split(object["path"]) - next unless valid_dirnames.include?(dirname) - user = object["repository"]["owner"]["login"] - user = user.downcase if user == "Homebrew" - repo = object["repository"]["name"].sub(/^homebrew-/, "") - tap = Tap.fetch user, repo - next if tap.installed? - basename = File.basename(filename, ".rb") - "#{user}/#{repo}/#{basename}" - end.compact - end + valid_dirnames = ["Formula", "HomebrewFormula", "Casks", "."].freeze + matches = GitHub.search_code("user:Homebrew", "user:caskroom", "filename:#{query}", "extension:rb") + [*matches].map do |match| + dirname, filename = File.split(match["path"]) + next unless valid_dirnames.include?(dirname) + tap = Tap.fetch(match["repository"]["full_name"]) + next if tap.installed? + "#{tap.name}/#{File.basename(filename, ".rb")}" + end.compact end def search_formulae(regex) |
