From 5dfa7cacd162be3164d259dcf6f2d4e035724fb5 Mon Sep 17 00:00:00 2001 From: nobu Date: Wed, 3 Mar 2004 16:17:32 +0000 Subject: * lib/rdoc/ri/ri_display.rb (DefaultDisplay::page): wait until the pager terminates. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5881 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- lib/rdoc/ri/ri_display.rb | 25 +++++++------------------ 1 file changed, 7 insertions(+), 18 deletions(-) (limited to 'lib/rdoc/ri/ri_display.rb') diff --git a/lib/rdoc/ri/ri_display.rb b/lib/rdoc/ri/ri_display.rb index d07f595531..1e371350dc 100644 --- a/lib/rdoc/ri/ri_display.rb +++ b/lib/rdoc/ri/ri_display.rb @@ -183,11 +183,15 @@ class DefaultDisplay ###################################################################### def page - pager = setup_pager + return yield unless pager = setup_pager begin + save_stdout = STDOUT.clone + STDOUT.reopen(pager) yield ensure - page_output(pager) + STDOUT.reopen(save_stdout) + save_stdout.close + pager.close end end @@ -196,28 +200,13 @@ class DefaultDisplay def setup_pager unless @options.use_stdout for pager in [ ENV['PAGER'], "less", "more", 'pager' ].compact.uniq - begin - pager = IO.popen(pager, "w") - rescue - else - @save_stdout = STDOUT.clone - STDOUT.reopen(pager) - return pager - end + return IO.popen(pager, "w") rescue nil end @options.use_stdout = true nil end end - ###################################################################### - - def page_output(pager) - STDOUT.reopen(@save_stdout) if @save_stdout - @save_stdout = nil - pager.close if pager - end - ###################################################################### def display_params(method) -- cgit v1.2.3