summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authoraamine <aamine@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-08-18 14:44:41 +0000
committeraamine <aamine@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-08-18 14:44:41 +0000
commit157832d922a914ff1b995f4b105503bd32fb17d2 (patch)
tree07e886ccd61e2771da631666cefcbf30f6397ac7 /lib
parentff9782cfc9d1bb9342331096720386a7c881daed (diff)
* lib/net/protocol.rb (rbuf_fill): OpenSSL::SSLSocket has its own buffer, select(2) might not work. [ruby-dev:24072]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@6786 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib')
-rw-r--r--lib/net/protocol.rb11
1 files changed, 5 insertions, 6 deletions
diff --git a/lib/net/protocol.rb b/lib/net/protocol.rb
index 316f5e51a2..ac6bce1058 100644
--- a/lib/net/protocol.rb
+++ b/lib/net/protocol.rb
@@ -2,8 +2,8 @@
# = net/protocol.rb
#
#--
-# Copyright (c) 1999-2003 Yukihiro Matsumoto
-# Copyright (c) 1999-2003 Minero Aoki
+# Copyright (c) 1999-2004 Yukihiro Matsumoto
+# Copyright (c) 1999-2004 Minero Aoki
#
# written and maintained by Minero Aoki <aamine@loveruby.net>
#
@@ -193,10 +193,9 @@ module Net # :nodoc:
private
def rbuf_fill
- until IO.select([@socket], nil, nil, @read_timeout)
- raise TimeoutError, "socket read timeout (#{@read_timeout} sec)"
- end
- @rbuf << @socket.sysread(1024)
+ timeout(@read_timeout) {
+ @rbuf << @socket.sysread(1024)
+ }
end
def rbuf_moveto( dest, len )