| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  | # typed: strict | 
					
						
							| 
									
										
										
										
											2019-04-19 15:38:03 +09:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-05 17:17:03 -05:00
										 |  |  | # A {Messages} object collects messages that may need to be displayed together | 
					
						
							| 
									
										
										
										
											2018-10-18 21:42:43 -04:00
										 |  |  | # at the end of a multi-step `brew` command run. | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  | class Messages | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |   sig { returns(T::Array[T::Hash[Symbol, Symbol]]) } | 
					
						
							|  |  |  |   attr_reader :caveats | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sig { returns(Integer) } | 
					
						
							|  |  |  |   attr_reader :package_count | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   sig { returns(T::Array[T::Hash[String, Float]]) } | 
					
						
							|  |  |  |   attr_reader :install_times | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-20 12:03:48 +02:00
										 |  |  |   sig { void } | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  |   def initialize | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |     @caveats = T.let([], T::Array[T::Hash[Symbol, Symbol]]) | 
					
						
							| 
									
										
										
										
											2025-06-06 17:09:28 +01:00
										 |  |  |     @completions_and_elisp = T.let(Set.new, T::Set[String]) | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |     @package_count = T.let(0, Integer) | 
					
						
							|  |  |  |     @install_times = T.let([], T::Array[T::Hash[String, Float]]) | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |   sig { params(package: String, caveats: T.any(String, Caveats)).void } | 
					
						
							| 
									
										
										
										
											2021-06-08 23:43:14 +01:00
										 |  |  |   def record_caveats(package, caveats) | 
					
						
							| 
									
										
										
										
											2024-03-07 16:20:20 +00:00
										 |  |  |     @caveats.push(package:, caveats:) | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-06 17:09:28 +01:00
										 |  |  |   sig { params(completions_and_elisp: T::Array[String]).void } | 
					
						
							|  |  |  |   def record_completions_and_elisp(completions_and_elisp) | 
					
						
							|  |  |  |     @completions_and_elisp.merge(completions_and_elisp) | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |   sig { params(package: String, elapsed_time: Float).void } | 
					
						
							| 
									
										
										
										
											2021-09-02 08:42:48 -07:00
										 |  |  |   def package_installed(package, elapsed_time) | 
					
						
							|  |  |  |     @package_count += 1
 | 
					
						
							| 
									
										
										
										
											2024-03-07 16:20:20 +00:00
										 |  |  |     @install_times.push(package:, time: elapsed_time) | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |   sig { params(force_caveats: T::Boolean, display_times: T::Boolean).void } | 
					
						
							| 
									
										
										
										
											2021-01-11 11:43:11 -08:00
										 |  |  |   def display_messages(force_caveats: false, display_times: false) | 
					
						
							|  |  |  |     display_caveats(force: force_caveats) | 
					
						
							| 
									
										
										
										
											2020-07-25 21:33:48 +02:00
										 |  |  |     display_install_times if display_times | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  |   end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |   sig { params(force: T::Boolean).void } | 
					
						
							| 
									
										
										
										
											2021-01-11 11:43:11 -08:00
										 |  |  |   def display_caveats(force: false) | 
					
						
							| 
									
										
										
										
											2021-09-02 08:42:48 -07:00
										 |  |  |     return if @package_count.zero? | 
					
						
							| 
									
										
										
										
											2025-06-06 17:09:28 +01:00
										 |  |  |     return if @caveats.empty? && @completions_and_elisp.empty? | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     oh1 "Caveats" unless @completions_and_elisp.empty? | 
					
						
							|  |  |  |     @completions_and_elisp.each { |c| puts c } | 
					
						
							| 
									
										
										
										
											2021-09-02 08:42:48 -07:00
										 |  |  |     return if @package_count == 1 && !force | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-06-06 17:09:28 +01:00
										 |  |  |     oh1 "Caveats" if @completions_and_elisp.empty? | 
					
						
							|  |  |  |     @caveats.each { |c| ohai c[:package], c[:caveats] } | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  |   end | 
					
						
							| 
									
										
										
										
											2018-06-20 00:54:14 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-05-13 08:48:41 -04:00
										 |  |  |   sig { void } | 
					
						
							| 
									
										
										
										
											2018-06-20 00:54:14 -04:00
										 |  |  |   def display_install_times | 
					
						
							|  |  |  |     return if install_times.empty? | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-20 00:54:14 -04:00
										 |  |  |     oh1 "Installation times" | 
					
						
							|  |  |  |     install_times.each do |t| | 
					
						
							| 
									
										
										
										
											2021-09-02 08:42:48 -07:00
										 |  |  |       puts format("%<package>-20s %<time>10.3f s", t) | 
					
						
							| 
									
										
										
										
											2018-06-20 00:54:14 -04:00
										 |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							| 
									
										
										
										
											2018-06-20 02:10:54 -04:00
										 |  |  | end |