mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/webrick/server.rb (WEBrick::GenericServer#accept_client):
sockets should be non-blocking mode. [ruby-dev:26405] * lib/webrick/utils.rb (WEBrick::Utils.set_non_blocking): new method. * lib/webrick/httprequest.rb (WEBrick::HTTPRequest#read_chunked): should call sock.read repeatedly until the preferred size data is obtained. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@8769 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
f07aefe54f
commit
c7070bdc48
4 changed files with 26 additions and 1 deletions
11
ChangeLog
11
ChangeLog
|
@ -1,3 +1,14 @@
|
|||
Fri Jul 15 07:58:56 2005 GOTOU Yuuzou <gotoyuzo@notwork.org>
|
||||
|
||||
* lib/webrick/server.rb (WEBrick::GenericServer#accept_client):
|
||||
sockets should be non-blocking mode. [ruby-dev:26405]
|
||||
|
||||
* lib/webrick/utils.rb (WEBrick::Utils.set_non_blocking): new method.
|
||||
|
||||
* lib/webrick/httprequest.rb (WEBrick::HTTPRequest#read_chunked):
|
||||
should call sock.read repeatedly until the preferred size data
|
||||
is obtained.
|
||||
|
||||
Thu Jul 14 18:27:16 2005 Hirokazu Yamamoto <ocean@m2.ccsnet.ne.jp>
|
||||
|
||||
* win32/win32.c (rb_w32_strerror): should return correct message
|
||||
|
|
|
@ -306,7 +306,12 @@ module WEBrick
|
|||
def read_chunked(socket, block)
|
||||
chunk_size, = read_chunk_size(socket)
|
||||
while chunk_size > 0
|
||||
data = read_data(socket, chunk_size) # read chunk-data
|
||||
data = ""
|
||||
while data.size < chunk_size
|
||||
tmp = read_data(socket, chunk_size-data.size) # read chunk-data
|
||||
break unless tmp
|
||||
data << tmp
|
||||
end
|
||||
if data.nil? || data.size != chunk_size
|
||||
raise BadRequest, "bad chunk data size."
|
||||
end
|
||||
|
|
|
@ -146,6 +146,7 @@ module WEBrick
|
|||
begin
|
||||
sock = svr.accept
|
||||
sock.sync = true
|
||||
Utils::set_non_blocking(sock)
|
||||
Utils::set_close_on_exec(sock)
|
||||
rescue Errno::ECONNRESET, Errno::ECONNABORTED, Errno::EPROTO => ex
|
||||
# TCP connection was established but RST segment was sent
|
||||
|
|
|
@ -18,6 +18,14 @@ end
|
|||
|
||||
module WEBrick
|
||||
module Utils
|
||||
def set_non_blocking(io)
|
||||
flag = File::NONBLOCK
|
||||
if defined?(Fcntl::F_GETFL)
|
||||
flag |= io.fcntl(Fcntl::F_GETFL)
|
||||
end
|
||||
io.fcntl(Fcntl::F_SETFL, flag)
|
||||
end
|
||||
module_function :set_non_blocking
|
||||
|
||||
def set_close_on_exec(io)
|
||||
if defined?(Fcntl::FD_CLOEXEC)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue