summaryrefslogtreecommitdiff
path: root/jni/ruby/lib/rdoc/stats
diff options
context:
space:
mode:
authorJari Vetoniemi <jari.vetoniemi@indooratlas.com>2020-03-16 18:49:26 +0900
committerJari Vetoniemi <jari.vetoniemi@indooratlas.com>2020-03-30 00:39:06 +0900
commitfcbf63e62c627deae76c1b8cb8c0876c536ed811 (patch)
tree64cb17de3f41a2b6fef2368028fbd00349946994 /jni/ruby/lib/rdoc/stats
Fresh start
Diffstat (limited to 'jni/ruby/lib/rdoc/stats')
-rw-r--r--jni/ruby/lib/rdoc/stats/normal.rb59
-rw-r--r--jni/ruby/lib/rdoc/stats/quiet.rb59
-rw-r--r--jni/ruby/lib/rdoc/stats/verbose.rb45
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
+
+