mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
3f1f9e9a0a
http://c64b.rubyci.org/~chkbuild/ruby-trunk/log/20140520T030303Z.fail.html.gz git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@46027 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
49 lines
1.3 KiB
Ruby
49 lines
1.3 KiB
Ruby
##
|
|
# Stats printer that prints just the files being documented with a progress
|
|
# bar
|
|
|
|
class RDoc::Stats::Normal < RDoc::Stats::Quiet
|
|
|
|
def begin_adding # :nodoc:
|
|
puts "Parsing sources..."
|
|
end
|
|
|
|
##
|
|
# Prints a file with a progress bar
|
|
|
|
def print_file files_so_far, filename
|
|
progress_bar = sprintf("%3d%% [%2d/%2d] ",
|
|
100 * files_so_far / @num_files,
|
|
files_so_far,
|
|
@num_files)
|
|
|
|
# Print a progress bar, but make sure it fits on a single line. Filename
|
|
# will be truncated if necessary.
|
|
terminal_width = (ENV['COLUMNS'] || 80).to_i
|
|
max_filename_size = terminal_width - progress_bar.size
|
|
|
|
if filename.size > max_filename_size then
|
|
# Turn "some_long_filename.rb" to "...ong_filename.rb"
|
|
filename = filename[(filename.size - max_filename_size) .. -1]
|
|
filename[0..2] = "..."
|
|
end
|
|
|
|
line = "#{progress_bar}#{filename}"
|
|
if $stdout.tty?
|
|
# Pad the line with whitespaces so that leftover output from the
|
|
# previous line doesn't show up.
|
|
padding = terminal_width - line.size
|
|
line << (" " * padding) if padding > 0
|
|
$stdout.print("#{line}\r")
|
|
else
|
|
$stdout.puts(line)
|
|
end
|
|
$stdout.flush
|
|
end
|
|
|
|
def done_adding # :nodoc:
|
|
puts
|
|
end
|
|
|
|
end
|
|
|