diff options
author | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-06-26 20:44:14 +0000 |
---|---|---|
committer | drbrain <drbrain@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2006-06-26 20:44:14 +0000 |
commit | 4e23c46ff4c2b6fb8c16a50b7123acb753f7b7d6 (patch) | |
tree | 03e7986b60a2ef8aca427d12f0288e8b09339f55 /lib/rdoc/ri/ri_display.rb | |
parent | 74831046c7240243c57efec65c11e2e71a9287f4 (diff) |
Merge from HEAD.
Add --system, --site, --home, --gems to ri.
Allow --doc-dir to be specified multiple times.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@10405 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/rdoc/ri/ri_display.rb')
-rw-r--r-- | lib/rdoc/ri/ri_display.rb | 50 |
1 files changed, 16 insertions, 34 deletions
diff --git a/lib/rdoc/ri/ri_display.rb b/lib/rdoc/ri/ri_display.rb index 076df46b17..67962fc2c1 100644 --- a/lib/rdoc/ri/ri_display.rb +++ b/lib/rdoc/ri/ri_display.rb @@ -194,12 +194,15 @@ class DefaultDisplay ###################################################################### def page - setup_pager + return yield unless pager = setup_pager begin + save_stdout = STDOUT.clone + STDOUT.reopen(pager) yield - page_output ensure - STDOUT.reopen(@save_stdout) if @save_stdout + STDOUT.reopen(save_stdout) + save_stdout.close + pager.close end end @@ -207,31 +210,11 @@ class DefaultDisplay def setup_pager unless @options.use_stdout - require 'tempfile' - - @save_stdout = STDOUT.clone - STDOUT.reopen(Tempfile.new("ri_")) - end - end - - ###################################################################### - - def page_output - unless @options.use_stdout - path = STDOUT.path - STDOUT.reopen(@save_stdout) - @save_stdout = nil - paged = false - for pager in [ ENV['PAGER'], "less", "more <", 'pager' ].compact.uniq - if system("#{pager} #{path}") - paged = true - break - end - end - if !paged - @options.use_stdout = true - puts File.read(path) + for pager in [ ENV['PAGER'], "less", "more", 'pager' ].compact.uniq + return IO.popen(pager, "w") rescue nil end + @options.use_stdout = true + nil end end @@ -255,12 +238,6 @@ class DefaultDisplay end ###################################################################### - def warn_no_database - puts "Before using ri, you need to generate documentation" - puts "using 'rdoc' with the --ri option" - end - ###################################################################### - def display_flow(flow) if !flow || flow.empty? @formatter.wrap("(no description...)") @@ -269,5 +246,10 @@ class DefaultDisplay end end - + ###################################################################### + + def warn_no_database + puts "Before using ri, you need to generate documentation" + puts "using 'rdoc' with the --ri option" + end end # class RiDisplay |