diff options
author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-03-03 16:17:32 +0000 |
---|---|---|
committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-03-03 16:17:32 +0000 |
commit | 5dfa7cacd162be3164d259dcf6f2d4e035724fb5 (patch) | |
tree | f91084ce2d7e0fcf489cbae5199a8b32fe8d11bf | |
parent | 57cbecdb4f62df817c4d4fb694837b32b0f3b604 (diff) |
* 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
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | lib/rdoc/ri/ri_display.rb | 25 |
2 files changed, 10 insertions, 21 deletions
@@ -1,7 +1,7 @@ -Wed Mar 3 18:58:20 2004 Nobuyoshi Nakada <[email protected]> +Thu Mar 4 01:17:28 2004 Nobuyoshi Nakada <[email protected]> - * lib/rdoc/ri/ri_display.rb (DefaultDisplay::setup_pager): ensure - pager closes and stdout is restored. + * lib/rdoc/ri/ri_display.rb (DefaultDisplay::page): wait until the + pager terminates. Wed Mar 3 13:10:56 2004 Yukihiro Matsumoto <[email protected]> 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,14 +200,7 @@ 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 @@ -211,14 +208,6 @@ class DefaultDisplay end ###################################################################### - - def page_output(pager) - STDOUT.reopen(@save_stdout) if @save_stdout - @save_stdout = nil - pager.close if pager - end - - ###################################################################### def display_params(method) |