2010-12-19 22:22:49 -05:00
|
|
|
##
|
|
|
|
# Stats printer that prints just the files being documented with a progress
|
|
|
|
# bar
|
|
|
|
|
|
|
|
class RDoc::Stats::Normal < RDoc::Stats::Quiet
|
|
|
|
|
|
|
|
def begin_adding # :nodoc:
|
2011-05-12 19:41:35 -04:00
|
|
|
puts "Parsing sources..." if $stdout.tty?
|
2010-12-19 22:22:49 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
##
|
|
|
|
# Prints a file with a progress bar
|
|
|
|
|
|
|
|
def print_file files_so_far, filename
|
2011-05-12 19:41:35 -04:00
|
|
|
return unless $stdout.tty?
|
|
|
|
|
2010-12-19 22:22:49 -05:00
|
|
|
progress_bar = sprintf("%3d%% [%2d/%2d] ",
|
|
|
|
100 * files_so_far / @num_files,
|
|
|
|
files_so_far,
|
|
|
|
@num_files)
|
|
|
|
|
2011-05-12 19:41:35 -04:00
|
|
|
# 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] = "..."
|
2010-12-19 22:22:49 -05:00
|
|
|
end
|
|
|
|
|
2011-05-12 19:41:35 -04:00
|
|
|
# Pad the line with whitespaces so that leftover output from the
|
|
|
|
# previous line doesn't show up.
|
|
|
|
line = "#{progress_bar}#{filename}"
|
|
|
|
padding = terminal_width - line.size
|
|
|
|
line << (" " * padding) if padding > 0
|
|
|
|
|
|
|
|
$stdout.print("#{line}\r")
|
2010-12-19 22:22:49 -05:00
|
|
|
$stdout.flush
|
|
|
|
end
|
|
|
|
|
|
|
|
def done_adding # :nodoc:
|
2011-05-12 19:41:35 -04:00
|
|
|
puts if $stdout.tty?
|
2010-12-19 22:22:49 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|