Class: Gem::StreamUI::VerboseDownloadReporter
Relationships & Source Files | |
Inherits: | Object |
Defined in: | lib/rubygems/user_interaction.rb |
Overview
A progress reporter that prints out messages about the current progress.
Class Method Summary
-
.new(out_stream, *args) ⇒ VerboseDownloadReporter
constructor
Creates a new verbose download reporter that will display on
out_stream
.
Instance Attribute Summary
-
#file_name
readonly
The current file name being displayed.
-
#progress
readonly
The current progress (0 to 100).
-
#total_bytes
readonly
The total bytes in the file.
Instance Method Summary
-
#done
Indicates the download is complete.
-
#fetch(file_name, total_bytes)
Tells the download reporter that the #file_name is being fetched and contains #total_bytes.
-
#update(bytes)
Updates the verbose download reporter for the given number of
bytes
.
Constructor Details
.new(out_stream, *args) ⇒ VerboseDownloadReporter
Creates a new verbose download reporter that will display on out_stream
. The other arguments are ignored.
# File 'lib/rubygems/user_interaction.rb', line 602
def initialize(out_stream, *args) @out = out_stream @progress = 0 end
Instance Attribute Details
#file_name (readonly)
The current file name being displayed
# File 'lib/rubygems/user_interaction.rb', line 586
attr_reader :file_name
#progress (readonly)
The current progress (0 to 100)
# File 'lib/rubygems/user_interaction.rb', line 596
attr_reader :progress
#total_bytes (readonly)
The total bytes in the file
# File 'lib/rubygems/user_interaction.rb', line 591
attr_reader :total_bytes
Instance Method Details
#done
Indicates the download is complete.
# File 'lib/rubygems/user_interaction.rb', line 638
def done @progress = 100 if @units == '%' update_display(true, true) end
#fetch(file_name, total_bytes)
Tells the download reporter that the #file_name is being fetched and contains #total_bytes.
# File 'lib/rubygems/user_interaction.rb', line 611
def fetch(file_name, total_bytes) @file_name = file_name @total_bytes = total_bytes.to_i @units = @total_bytes.zero? ? 'B' : '%' update_display(false) end
#update(bytes)
Updates the verbose download reporter for the given number of bytes
.
# File 'lib/rubygems/user_interaction.rb', line 622
def update(bytes) new_progress = if @units == 'B' then bytes else ((bytes.to_f * 100) / total_bytes.to_f).ceil end return if new_progress == @progress @progress = new_progress update_display end