diff options
Diffstat (limited to 'jni/ruby/lib/rdoc/stats')
-rw-r--r-- | jni/ruby/lib/rdoc/stats/normal.rb | 59 | ||||
-rw-r--r-- | jni/ruby/lib/rdoc/stats/quiet.rb | 59 | ||||
-rw-r--r-- | jni/ruby/lib/rdoc/stats/verbose.rb | 45 |
3 files changed, 163 insertions, 0 deletions
diff --git a/jni/ruby/lib/rdoc/stats/normal.rb b/jni/ruby/lib/rdoc/stats/normal.rb new file mode 100644 index 0000000..ef366a5 --- /dev/null +++ b/jni/ruby/lib/rdoc/stats/normal.rb @@ -0,0 +1,59 @@ +begin + require 'io/console/size' +rescue LoadError +end + +## +# 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..." + @last_width = 0 + 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 = if defined?(IO) && IO.respond_to?(:console_size) + IO.console_size[1].to_i.nonzero? || 80 + else + 80 + end + 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? + # Clean the line with whitespaces so that leftover output from the + # previous line doesn't show up. + $stdout.print("\r" << (" " * @last_width) << ("\b" * @last_width) << "\r") if @last_width && @last_width > 0 + @last_width = line.size + $stdout.print("#{line}\r") + else + $stdout.puts(line) + end + $stdout.flush + end + + def done_adding # :nodoc: + puts + end + +end + diff --git a/jni/ruby/lib/rdoc/stats/quiet.rb b/jni/ruby/lib/rdoc/stats/quiet.rb new file mode 100644 index 0000000..eed27b2 --- /dev/null +++ b/jni/ruby/lib/rdoc/stats/quiet.rb @@ -0,0 +1,59 @@ +## +# Stats printer that prints nothing + +class RDoc::Stats::Quiet + + ## + # Creates a new Quiet that will print nothing + + def initialize num_files + @num_files = num_files + end + + ## + # Prints a message at the beginning of parsing + + def begin_adding(*) end + + ## + # Prints when an alias is added + + def print_alias(*) end + + ## + # Prints when an attribute is added + + def print_attribute(*) end + + ## + # Prints when a class is added + + def print_class(*) end + + ## + # Prints when a constant is added + + def print_constant(*) end + + ## + # Prints when a file is added + + def print_file(*) end + + ## + # Prints when a method is added + + def print_method(*) end + + ## + # Prints when a module is added + + def print_module(*) end + + ## + # Prints when RDoc is done + + def done_adding(*) end + +end + diff --git a/jni/ruby/lib/rdoc/stats/verbose.rb b/jni/ruby/lib/rdoc/stats/verbose.rb new file mode 100644 index 0000000..430809a --- /dev/null +++ b/jni/ruby/lib/rdoc/stats/verbose.rb @@ -0,0 +1,45 @@ +## +# Stats printer that prints everything documented, including the documented +# status + +class RDoc::Stats::Verbose < RDoc::Stats::Normal + + ## + # Returns a marker for RDoc::CodeObject +co+ being undocumented + + def nodoc co + " (undocumented)" unless co.documented? + end + + def print_alias as # :nodoc: + puts " alias #{as.new_name} #{as.old_name}#{nodoc as}" + end + + def print_attribute attribute # :nodoc: + puts " #{attribute.definition} #{attribute.name}#{nodoc attribute}" + end + + def print_class(klass) # :nodoc: + puts " class #{klass.full_name}#{nodoc klass}" + end + + def print_constant(constant) # :nodoc: + puts " #{constant.name}#{nodoc constant}" + end + + def print_file(files_so_far, file) # :nodoc: + super + puts + end + + def print_method(method) # :nodoc: + puts " #{method.singleton ? '::' : '#'}#{method.name}#{nodoc method}" + end + + def print_module(mod) # :nodoc: + puts " module #{mod.full_name}#{nodoc mod}" + end + +end + + |