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>
|
Thu Jul 14 18:27:16 2005 Hirokazu Yamamoto <ocean@m2.ccsnet.ne.jp>
|
||||||
|
|
||||||
* win32/win32.c (rb_w32_strerror): should return correct message
|
* win32/win32.c (rb_w32_strerror): should return correct message
|
||||||
|
|
|
@ -306,7 +306,12 @@ module WEBrick
|
||||||
def read_chunked(socket, block)
|
def read_chunked(socket, block)
|
||||||
chunk_size, = read_chunk_size(socket)
|
chunk_size, = read_chunk_size(socket)
|
||||||
while chunk_size > 0
|
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
|
if data.nil? || data.size != chunk_size
|
||||||
raise BadRequest, "bad chunk data size."
|
raise BadRequest, "bad chunk data size."
|
||||||
end
|
end
|
||||||
|
|
|
@ -146,6 +146,7 @@ module WEBrick
|
||||||
begin
|
begin
|
||||||
sock = svr.accept
|
sock = svr.accept
|
||||||
sock.sync = true
|
sock.sync = true
|
||||||
|
Utils::set_non_blocking(sock)
|
||||||
Utils::set_close_on_exec(sock)
|
Utils::set_close_on_exec(sock)
|
||||||
rescue Errno::ECONNRESET, Errno::ECONNABORTED, Errno::EPROTO => ex
|
rescue Errno::ECONNRESET, Errno::ECONNABORTED, Errno::EPROTO => ex
|
||||||
# TCP connection was established but RST segment was sent
|
# TCP connection was established but RST segment was sent
|
||||||
|
|
|
@ -18,6 +18,14 @@ end
|
||||||
|
|
||||||
module WEBrick
|
module WEBrick
|
||||||
module Utils
|
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)
|
def set_close_on_exec(io)
|
||||||
if defined?(Fcntl::FD_CLOEXEC)
|
if defined?(Fcntl::FD_CLOEXEC)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue