Merge pull request #10501 from MikeMcQuaid/update-stderr
cmd/update-report: output to stderr when not a TTY.
This commit is contained in:
		
						commit
						e98a913783
					
				| @ -15,9 +15,25 @@ module Homebrew | |||||||
| 
 | 
 | ||||||
|   module_function |   module_function | ||||||
| 
 | 
 | ||||||
|  |   def ohai_stdout_or_stderr(message) | ||||||
|  |     if $stdout.tty? | ||||||
|  |       ohai(message) | ||||||
|  |     else | ||||||
|  |       $stderr.puts(ohai_title(message)) | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|  |   def puts_stdout_or_stderr(message) | ||||||
|  |     if $stdout.tty? | ||||||
|  |       puts(message) | ||||||
|  |     else | ||||||
|  |       $stderr.puts(message) | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|   def update_preinstall_header(args:) |   def update_preinstall_header(args:) | ||||||
|     @update_preinstall_header ||= begin |     @update_preinstall_header ||= begin | ||||||
|       ohai "Auto-updated Homebrew!" if args.preinstall? |       ohai_stdout_or_stderr "Auto-updated Homebrew!" if args.preinstall? | ||||||
|       true |       true | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| @ -50,8 +66,8 @@ module Homebrew | |||||||
|       print "\a" |       print "\a" | ||||||
| 
 | 
 | ||||||
|       # Use an extra newline and bold to avoid this being missed. |       # Use an extra newline and bold to avoid this being missed. | ||||||
|       ohai "Homebrew has enabled anonymous aggregate formula and cask analytics." |       ohai_stdout_or_stderr "Homebrew has enabled anonymous aggregate formula and cask analytics." | ||||||
|       puts <<~EOS |       puts_stdout_or_stderr <<~EOS | ||||||
|         #{Tty.bold}Read the analytics documentation (and how to opt-out) here: |         #{Tty.bold}Read the analytics documentation (and how to opt-out) here: | ||||||
|           #{Formatter.url("https://docs.brew.sh/Analytics")}#{Tty.reset} |           #{Formatter.url("https://docs.brew.sh/Analytics")}#{Tty.reset} | ||||||
|         No analytics have been recorded yet (nor will be during this `brew` run). |         No analytics have been recorded yet (nor will be during this `brew` run). | ||||||
| @ -63,8 +79,8 @@ module Homebrew | |||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     if Settings.read("donationmessage") != "true" && !args.quiet? |     if Settings.read("donationmessage") != "true" && !args.quiet? | ||||||
|       ohai "Homebrew is run entirely by unpaid volunteers. Please consider donating:" |       ohai_stdout_or_stderr "Homebrew is run entirely by unpaid volunteers. Please consider donating:" | ||||||
|       puts "  #{Formatter.url("https://github.com/Homebrew/brew#donations")}\n" |       puts_stdout_or_stderr "  #{Formatter.url("https://github.com/Homebrew/brew#donations")}\n" | ||||||
| 
 | 
 | ||||||
|       # Consider the message possibly missed if not a TTY. |       # Consider the message possibly missed if not a TTY. | ||||||
|       Settings.write "donationmessage", true if $stdout.tty? |       Settings.write "donationmessage", true if $stdout.tty? | ||||||
| @ -81,7 +97,8 @@ module Homebrew | |||||||
| 
 | 
 | ||||||
|     if initial_revision != current_revision |     if initial_revision != current_revision | ||||||
|       update_preinstall_header args: args |       update_preinstall_header args: args | ||||||
|       puts "Updated Homebrew from #{shorten_revision(initial_revision)} to #{shorten_revision(current_revision)}." |       puts_stdout_or_stderr \ | ||||||
|  |         "Updated Homebrew from #{shorten_revision(initial_revision)} to #{shorten_revision(current_revision)}." | ||||||
|       updated = true |       updated = true | ||||||
| 
 | 
 | ||||||
|       old_tag = Settings.read "latesttag" |       old_tag = Settings.read "latesttag" | ||||||
| @ -119,13 +136,14 @@ module Homebrew | |||||||
| 
 | 
 | ||||||
|     unless updated_taps.empty? |     unless updated_taps.empty? | ||||||
|       update_preinstall_header args: args |       update_preinstall_header args: args | ||||||
|       puts "Updated #{updated_taps.count} #{"tap".pluralize(updated_taps.count)} (#{updated_taps.to_sentence})." |       puts_stdout_or_stderr \ | ||||||
|  |         "Updated #{updated_taps.count} #{"tap".pluralize(updated_taps.count)} (#{updated_taps.to_sentence})." | ||||||
|       updated = true |       updated = true | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     if updated |     if updated | ||||||
|       if hub.empty? |       if hub.empty? | ||||||
|         puts "No changes to formulae." unless args.quiet? |         puts_stdout_or_stderr "No changes to formulae." unless args.quiet? | ||||||
|       else |       else | ||||||
|         hub.dump(updated_formula_report: !args.preinstall?) |         hub.dump(updated_formula_report: !args.preinstall?) | ||||||
|         hub.reporters.each(&:migrate_tap_migration) |         hub.reporters.each(&:migrate_tap_migration) | ||||||
| @ -137,7 +155,7 @@ module Homebrew | |||||||
|       end |       end | ||||||
|       puts if args.preinstall? |       puts if args.preinstall? | ||||||
|     elsif !args.preinstall? && !ENV["HOMEBREW_UPDATE_FAILED"] |     elsif !args.preinstall? && !ENV["HOMEBREW_UPDATE_FAILED"] | ||||||
|       puts "Already up-to-date." unless args.quiet? |       puts_stdout_or_stderr "Already up-to-date." unless args.quiet? | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     Commands.rebuild_commands_completion_list |     Commands.rebuild_commands_completion_list | ||||||
| @ -148,8 +166,8 @@ module Homebrew | |||||||
|     if failed_fetch_dirs.present? |     if failed_fetch_dirs.present? | ||||||
|       failed_fetch_taps = failed_fetch_dirs.map { |dir| Tap.from_path(dir) } |       failed_fetch_taps = failed_fetch_dirs.map { |dir| Tap.from_path(dir) } | ||||||
| 
 | 
 | ||||||
|       puts Formatter.headline "Some taps failed to update!", color: :red |       ofail <<~EOS | ||||||
|       puts <<~EOS |         Some taps failed to update! | ||||||
|         The following taps can not read their remote branches: |         The following taps can not read their remote branches: | ||||||
|           #{failed_fetch_taps.join("\n  ")} |           #{failed_fetch_taps.join("\n  ")} | ||||||
|         This is happening because the remote branch was renamed or deleted. |         This is happening because the remote branch was renamed or deleted. | ||||||
| @ -159,14 +177,14 @@ module Homebrew | |||||||
| 
 | 
 | ||||||
|     return if new_repository_version.blank? |     return if new_repository_version.blank? | ||||||
| 
 | 
 | ||||||
|     ohai "Homebrew was updated to version #{new_repository_version}" |     ohai_stdout_or_stderr "Homebrew was updated to version #{new_repository_version}" | ||||||
|     if new_repository_version.split(".").last == "0" |     if new_repository_version.split(".").last == "0" | ||||||
|       puts <<~EOS |       puts_stdout_or_stderr <<~EOS | ||||||
|         More detailed release notes are available on the Homebrew Blog: |         More detailed release notes are available on the Homebrew Blog: | ||||||
|           #{Formatter.url("https://brew.sh/blog/#{new_repository_version}")} |           #{Formatter.url("https://brew.sh/blog/#{new_repository_version}")} | ||||||
|       EOS |       EOS | ||||||
|     else |     else | ||||||
|       puts <<~EOS |       puts_stdout_or_stderr <<~EOS | ||||||
|         The changelog can be found at: |         The changelog can be found at: | ||||||
|           #{Formatter.url("https://github.com/Homebrew/brew/releases/tag/#{new_repository_version}")} |           #{Formatter.url("https://github.com/Homebrew/brew/releases/tag/#{new_repository_version}")} | ||||||
|       EOS |       EOS | ||||||
| @ -355,13 +373,13 @@ class Reporter | |||||||
| 
 | 
 | ||||||
|         new_tap = Tap.fetch(new_tap_name) |         new_tap = Tap.fetch(new_tap_name) | ||||||
|         new_tap.install unless new_tap.installed? |         new_tap.install unless new_tap.installed? | ||||||
|         ohai "#{name} has been moved to Homebrew.", <<~EOS |         ohai_stdout_or_stderr "#{name} has been moved to Homebrew.", <<~EOS | ||||||
|           To uninstall the cask, run: |           To uninstall the cask, run: | ||||||
|             brew uninstall --cask --force #{name} |             brew uninstall --cask --force #{name} | ||||||
|         EOS |         EOS | ||||||
|         next if (HOMEBREW_CELLAR/new_name.split("/").last).directory? |         next if (HOMEBREW_CELLAR/new_name.split("/").last).directory? | ||||||
| 
 | 
 | ||||||
|         ohai "Installing #{new_name}..." |         ohai_stdout_or_stderr "Installing #{new_name}..." | ||||||
|         system HOMEBREW_BREW_FILE, "install", new_full_name |         system HOMEBREW_BREW_FILE, "install", new_full_name | ||||||
|         begin |         begin | ||||||
|           unless Formulary.factory(new_full_name).keg_only? |           unless Formulary.factory(new_full_name).keg_only? | ||||||
| @ -382,12 +400,12 @@ class Reporter | |||||||
|       # For formulae migrated to cask: Auto-install cask or provide install instructions. |       # For formulae migrated to cask: Auto-install cask or provide install instructions. | ||||||
|       if new_tap_name.start_with?("homebrew/cask") |       if new_tap_name.start_with?("homebrew/cask") | ||||||
|         if new_tap.installed? && (HOMEBREW_PREFIX/"Caskroom").directory? |         if new_tap.installed? && (HOMEBREW_PREFIX/"Caskroom").directory? | ||||||
|           ohai "#{name} has been moved to Homebrew Cask." |           ohai_stdout_or_stderr "#{name} has been moved to Homebrew Cask." | ||||||
|           ohai "brew unlink #{name}" |           ohai_stdout_or_stderr "brew unlink #{name}" | ||||||
|           system HOMEBREW_BREW_FILE, "unlink", name |           system HOMEBREW_BREW_FILE, "unlink", name | ||||||
|           ohai "brew cleanup" |           ohai_stdout_or_stderr "brew cleanup" | ||||||
|           system HOMEBREW_BREW_FILE, "cleanup" |           system HOMEBREW_BREW_FILE, "cleanup" | ||||||
|           ohai "brew install --cask #{new_name}" |           ohai_stdout_or_stderr "brew install --cask #{new_name}" | ||||||
|           system HOMEBREW_BREW_FILE, "install", "--cask", new_name |           system HOMEBREW_BREW_FILE, "install", "--cask", new_name | ||||||
|           ohai <<~EOS |           ohai <<~EOS | ||||||
|             #{name} has been moved to Homebrew Cask. |             #{name} has been moved to Homebrew Cask. | ||||||
| @ -396,7 +414,7 @@ class Reporter | |||||||
|               brew uninstall --force #{name} |               brew uninstall --force #{name} | ||||||
|           EOS |           EOS | ||||||
|         else |         else | ||||||
|           ohai "#{name} has been moved to Homebrew Cask.", <<~EOS |           ohai_stdout_or_stderr "#{name} has been moved to Homebrew Cask.", <<~EOS | ||||||
|             To uninstall the formula and install the cask, run: |             To uninstall the formula and install the cask, run: | ||||||
|               brew uninstall --force #{name} |               brew uninstall --force #{name} | ||||||
|               brew tap #{new_tap_name} |               brew tap #{new_tap_name} | ||||||
| @ -483,7 +501,10 @@ class ReporterHub | |||||||
|       dump_formula_report :M, "Updated Formulae" |       dump_formula_report :M, "Updated Formulae" | ||||||
|     else |     else | ||||||
|       updated = select_formula(:M).count |       updated = select_formula(:M).count | ||||||
|       ohai "Updated Formulae", "Updated #{updated} #{"formula".pluralize(updated)}." if updated.positive? |       if updated.positive? | ||||||
|  |         ohai_stdout_or_stderr "Updated Formulae", | ||||||
|  |                               "Updated #{updated} #{"formula".pluralize(updated)}." | ||||||
|  |       end | ||||||
|     end |     end | ||||||
|     dump_formula_report :R, "Renamed Formulae" |     dump_formula_report :R, "Renamed Formulae" | ||||||
|     dump_formula_report :D, "Deleted Formulae" |     dump_formula_report :D, "Deleted Formulae" | ||||||
| @ -492,7 +513,10 @@ class ReporterHub | |||||||
|       dump_formula_report :MC, "Updated Casks" |       dump_formula_report :MC, "Updated Casks" | ||||||
|     else |     else | ||||||
|       updated = select_formula(:MC).count |       updated = select_formula(:MC).count | ||||||
|       ohai "Updated Casks", "Updated #{updated} #{"cask".pluralize(updated)}." if updated.positive? |       if updated.positive? | ||||||
|  |         ohai_stdout_or_stderr "Updated Casks", | ||||||
|  |                               "Updated #{updated} #{"cask".pluralize(updated)}." | ||||||
|  |       end | ||||||
|     end |     end | ||||||
|     dump_formula_report :DC, "Deleted Casks" |     dump_formula_report :DC, "Deleted Casks" | ||||||
|   end |   end | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Mike McQuaid
						Mike McQuaid