| 
									
										
										
										
											2017-03-18 17:02:08 +02:00
										 |  |  | require "formulary" | 
					
						
							|  |  |  | require "tap" | 
					
						
							|  |  |  | require "utils" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | module Homebrew | 
					
						
							|  |  |  |   module MissingFormula | 
					
						
							|  |  |  |     class << self | 
					
						
							| 
									
										
										
										
											2017-03-22 21:56:15 +00:00
										 |  |  |       def reason(name, silent: false) | 
					
						
							|  |  |  |         blacklisted_reason(name) || tap_migration_reason(name) || | 
					
						
							|  |  |  |           deleted_reason(name, silent: silent) | 
					
						
							| 
									
										
										
										
											2017-03-18 17:02:08 +02:00
										 |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def blacklisted_reason(name) | 
					
						
							|  |  |  |         case name.downcase | 
					
						
							|  |  |  |         when "gem", /^rubygems?$/ then <<-EOS.undent
 | 
					
						
							|  |  |  |           Homebrew provides gem via: `brew install ruby`. | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "tex", "tex-live", "texlive", "latex" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Installing TeX from source is weird and gross, requires a lot of patches, | 
					
						
							|  |  |  |           and only builds 32-bit (and thus can't use Homebrew dependencies) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           We recommend using a MacTeX distribution: https://www.tug.org/mactex/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           You can install it with Homebrew-Cask: | 
					
						
							|  |  |  |             brew cask install mactex | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "pip" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Homebrew provides pip via: `brew install python`. However you will then | 
					
						
							|  |  |  |           have two Pythons installed on your Mac, so alternatively you can install | 
					
						
							|  |  |  |           pip via the instructions at: | 
					
						
							|  |  |  |             #{Formatter.url("https://pip.readthedocs.io/en/stable/installing/")} | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "pil" then <<-EOS.undent
 | 
					
						
							| 
									
										
										
										
											2017-04-01 03:32:25 -07:00
										 |  |  |           Instead of PIL, consider `pip install pillow` or `brew install Homebrew/science/pillow`. | 
					
						
							| 
									
										
										
										
											2017-03-18 17:02:08 +02:00
										 |  |  |           EOS | 
					
						
							|  |  |  |         when "macruby" then <<-EOS.undent
 | 
					
						
							|  |  |  |           MacRuby is not packaged and is on an indefinite development hiatus. | 
					
						
							|  |  |  |           You can read more about it at: | 
					
						
							|  |  |  |             #{Formatter.url("https://github.com/MacRuby/MacRuby")} | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when /(lib)?lzma/ | 
					
						
							|  |  |  |           "lzma is now part of the xz formula." | 
					
						
							|  |  |  |         when "gtest", "googletest", "google-test" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Installing gtest system-wide is not recommended; it should be vendored | 
					
						
							|  |  |  |           in your projects that use it. | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "gmock", "googlemock", "google-mock" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Installing gmock system-wide is not recommended; it should be vendored | 
					
						
							|  |  |  |           in your projects that use it. | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "sshpass" then <<-EOS.undent
 | 
					
						
							|  |  |  |           We won't add sshpass because it makes it too easy for novice SSH users to | 
					
						
							|  |  |  |           ruin SSH's security. | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "gsutil" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Install gsutil with `pip install gsutil` | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "clojure" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Clojure isn't really a program but a library managed as part of a | 
					
						
							|  |  |  |           project and Leiningen is the user interface to that library. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           To install Clojure you should install Leiningen: | 
					
						
							|  |  |  |             brew install leiningen | 
					
						
							|  |  |  |           and then follow the tutorial: | 
					
						
							|  |  |  |             #{Formatter.url("https://github.com/technomancy/leiningen/blob/stable/doc/TUTORIAL.md")} | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "gfortran" then <<-EOS.undent
 | 
					
						
							|  |  |  |           GNU Fortran is now provided as part of GCC, and can be installed with: | 
					
						
							|  |  |  |             brew install gcc | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "play" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Play 2.3 replaces the play command with activator: | 
					
						
							|  |  |  |             brew install typesafe-activator | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           You can read more about this change at: | 
					
						
							|  |  |  |             #{Formatter.url("https://www.playframework.com/documentation/2.3.x/Migration23")} | 
					
						
							|  |  |  |             #{Formatter.url("https://www.playframework.com/documentation/2.3.x/Highlights23")} | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "haskell-platform" then <<-EOS.undent
 | 
					
						
							|  |  |  |           We no longer package haskell-platform. Consider installing ghc | 
					
						
							|  |  |  |           and cabal-install instead: | 
					
						
							|  |  |  |             brew install ghc cabal-install | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           You can install with Homebrew-Cask: | 
					
						
							|  |  |  |             brew cask install haskell-platform | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "mysqldump-secure" then <<-EOS.undent
 | 
					
						
							|  |  |  |           The creator of mysqldump-secure tried to game our popularity metrics. | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         when "ngrok" then <<-EOS.undent
 | 
					
						
							|  |  |  |           Upstream sunsetted 1.x in March 2016 and 2.x is not open-source. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           If you wish to use the 2.x release you can install with Homebrew-Cask: | 
					
						
							|  |  |  |             brew cask install ngrok | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |       alias generic_blacklisted_reason blacklisted_reason | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 20:37:12 +01:00
										 |  |  |       def tap_migration_reason(name) | 
					
						
							|  |  |  |         message = nil | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Tap.each do |old_tap| | 
					
						
							| 
									
										
										
										
											2017-03-30 19:18:40 +01:00
										 |  |  |           new_tap = old_tap.tap_migrations[name] | 
					
						
							|  |  |  |           next unless new_tap | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           new_tap_user, new_tap_repo, = new_tap.split("/") | 
					
						
							|  |  |  |           new_tap_name = "#{new_tap_user}/#{new_tap_repo}" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 20:37:12 +01:00
										 |  |  |           message = <<-EOS.undent
 | 
					
						
							| 
									
										
										
										
											2017-03-30 19:18:40 +01:00
										 |  |  |             It was migrated from #{old_tap} to #{new_tap}. | 
					
						
							| 
									
										
										
										
											2017-03-20 20:37:12 +01:00
										 |  |  |             You can access it again by running: | 
					
						
							|  |  |  |               brew tap #{new_tap_name} | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |           break | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         message | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-22 21:56:15 +00:00
										 |  |  |       def deleted_reason(name, silent: false) | 
					
						
							| 
									
										
										
										
											2017-03-20 20:37:12 +01:00
										 |  |  |         path = Formulary.path name | 
					
						
							|  |  |  |         return if File.exist? path | 
					
						
							|  |  |  |         tap = Tap.from_path(path) | 
					
						
							| 
									
										
										
										
											2017-04-10 16:22:50 -04:00
										 |  |  |         return if tap.nil? || !File.exist?(tap.path) | 
					
						
							| 
									
										
										
										
											2017-03-20 20:37:12 +01:00
										 |  |  |         relative_path = path.relative_path_from tap.path | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         tap.path.cd do | 
					
						
							| 
									
										
										
										
											2017-03-22 21:56:15 +00:00
										 |  |  |           ohai "Searching for a previously deleted formula..." unless silent | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           # We know this may return incomplete results for shallow clones but | 
					
						
							|  |  |  |           # we don't want to nag everyone with a shallow clone to unshallow it. | 
					
						
							|  |  |  |           log_command = "git log --name-only --max-count=1 --format=%H\\\\n%h\\\\n%B -- #{relative_path}" | 
					
						
							|  |  |  |           hash, short_hash, *commit_message, relative_path = | 
					
						
							|  |  |  |             Utils.popen_read(log_command).gsub("\\n", "\n").lines.map(&:chomp) | 
					
						
							| 
									
										
										
										
											2017-03-22 00:28:01 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-20 20:37:12 +01:00
										 |  |  |           if hash.to_s.empty? || short_hash.to_s.empty? || | 
					
						
							|  |  |  |              relative_path.to_s.empty? | 
					
						
							| 
									
										
										
										
											2017-03-22 21:56:15 +00:00
										 |  |  |             ofail "No previously deleted formula found." unless silent | 
					
						
							| 
									
										
										
										
											2017-03-20 20:37:12 +01:00
										 |  |  |             return | 
					
						
							|  |  |  |           end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           commit_message = commit_message.reject(&:empty?).join("\n  ") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           commit_message.sub!(/ \(#(\d+)\)$/, " (#{tap.issues_url}/\\1)") | 
					
						
							|  |  |  |           commit_message.gsub!(/(Closes|Fixes) #(\d+)/, "\\1 #{tap.issues_url}/\\2") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <<-EOS.undent
 | 
					
						
							|  |  |  |             #{name} was deleted from #{tap.name} in commit #{short_hash}: | 
					
						
							|  |  |  |               #{commit_message} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             To show the formula before removal run: | 
					
						
							|  |  |  |               git -C "$(brew --repo #{tap})" show #{short_hash}^:#{relative_path} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             If you still use this formula consider creating your own tap: | 
					
						
							|  |  |  |               http://docs.brew.sh/How-to-Create-and-Maintain-a-Tap.html | 
					
						
							|  |  |  |           EOS | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-18 17:02:08 +02:00
										 |  |  |       require "extend/os/missing_formula" | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |