| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  | # typed: strict | 
					
						
							| 
									
										
										
										
											2019-04-19 15:38:03 +09:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-08-20 19:20:19 +01:00
										 |  |  | require "utils/output" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  | module Utils | 
					
						
							| 
									
										
										
										
											2020-08-19 08:18:57 +02:00
										 |  |  |   # Helper functions for creating symlinks. | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |   module Link | 
					
						
							| 
									
										
										
										
											2025-08-20 19:20:19 +01:00
										 |  |  |     extend Utils::Output::Mixin | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  |     sig { params(src_dir: Pathname, dst_dir: Pathname, command: String, link_dir: T::Boolean).void } | 
					
						
							| 
									
										
										
										
											2023-04-17 10:37:59 -07:00
										 |  |  |     def self.link_src_dst_dirs(src_dir, dst_dir, command, link_dir: false) | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       return unless src_dir.exist? | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       conflicts = [] | 
					
						
							|  |  |  |       src_paths = link_dir ? [src_dir] : src_dir.find | 
					
						
							|  |  |  |       src_paths.each do |src| | 
					
						
							|  |  |  |         next if src.directory? && !link_dir | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |         dst = dst_dir/src.relative_path_from(src_dir) | 
					
						
							|  |  |  |         if dst.symlink? | 
					
						
							|  |  |  |           next if src == dst.resolved_path | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |           dst.unlink | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |         if dst.exist? | 
					
						
							|  |  |  |           conflicts << dst | 
					
						
							|  |  |  |           next | 
					
						
							|  |  |  |         end | 
					
						
							|  |  |  |         dst_dir.parent.mkpath | 
					
						
							|  |  |  |         dst.make_relative_symlink(src) | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       return if conflicts.empty? | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-15 02:28:32 +02:00
										 |  |  |       onoe <<~EOS | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |         Could not link: | 
					
						
							|  |  |  |         #{conflicts.join("\n")} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-24 21:25:12 -05:00
										 |  |  |         Please delete these paths and run: | 
					
						
							|  |  |  |           #{command} | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       EOS | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     private_class_method :link_src_dst_dirs | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  |     sig { params(src_dir: Pathname, dst_dir: Pathname, unlink_dir: T::Boolean).void } | 
					
						
							| 
									
										
										
										
											2023-04-17 10:37:59 -07:00
										 |  |  |     def self.unlink_src_dst_dirs(src_dir, dst_dir, unlink_dir: false) | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       return unless src_dir.exist? | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       src_paths = unlink_dir ? [src_dir] : src_dir.find | 
					
						
							|  |  |  |       src_paths.each do |src| | 
					
						
							|  |  |  |         next if src.directory? && !unlink_dir | 
					
						
							| 
									
										
										
										
											2018-09-17 02:45:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |         dst = dst_dir/src.relative_path_from(src_dir) | 
					
						
							|  |  |  |         dst.delete if dst.symlink? && src == dst.resolved_path | 
					
						
							|  |  |  |         dst.parent.rmdir_if_possible | 
					
						
							|  |  |  |       end | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |     private_class_method :unlink_src_dst_dirs | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  |     sig { params(path: Pathname, command: String).void } | 
					
						
							| 
									
										
										
										
											2023-04-17 10:37:59 -07:00
										 |  |  |     def self.link_manpages(path, command) | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       link_src_dst_dirs(path/"manpages", HOMEBREW_PREFIX/"share/man/man1", command) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  |     sig { params(path: Pathname).void } | 
					
						
							| 
									
										
										
										
											2023-04-17 10:37:59 -07:00
										 |  |  |     def self.unlink_manpages(path) | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       unlink_src_dst_dirs(path/"manpages", HOMEBREW_PREFIX/"share/man/man1") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  |     sig { params(path: Pathname, command: String).void } | 
					
						
							| 
									
										
										
										
											2023-04-17 10:37:59 -07:00
										 |  |  |     def self.link_completions(path, command) | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       link_src_dst_dirs(path/"completions/bash", HOMEBREW_PREFIX/"etc/bash_completion.d", command) | 
					
						
							|  |  |  |       link_src_dst_dirs(path/"completions/zsh", HOMEBREW_PREFIX/"share/zsh/site-functions", command) | 
					
						
							|  |  |  |       link_src_dst_dirs(path/"completions/fish", HOMEBREW_PREFIX/"share/fish/vendor_completions.d", command) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  |     sig { params(path: Pathname).void } | 
					
						
							| 
									
										
										
										
											2023-04-17 10:37:59 -07:00
										 |  |  |     def self.unlink_completions(path) | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       unlink_src_dst_dirs(path/"completions/bash", HOMEBREW_PREFIX/"etc/bash_completion.d") | 
					
						
							|  |  |  |       unlink_src_dst_dirs(path/"completions/zsh", HOMEBREW_PREFIX/"share/zsh/site-functions") | 
					
						
							|  |  |  |       unlink_src_dst_dirs(path/"completions/fish", HOMEBREW_PREFIX/"share/fish/vendor_completions.d") | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-10 00:23:29 +01:00
										 |  |  |     sig { params(path: Pathname, command: String).void } | 
					
						
							| 
									
										
										
										
											2023-04-17 10:37:59 -07:00
										 |  |  |     def self.link_docs(path, command) | 
					
						
							| 
									
										
										
										
											2016-09-30 18:22:53 -05:00
										 |  |  |       link_src_dst_dirs(path/"docs", HOMEBREW_PREFIX/"share/doc/homebrew", command, link_dir: true) | 
					
						
							|  |  |  |     end | 
					
						
							|  |  |  |   end | 
					
						
							|  |  |  | end |