mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
This is analogous to functionality found in IO#read_nonblock and
IO#wait_nonblock. Raising exceptions for common failures on
non-blocking servers is expensive and makes $DEBUG too noisy.
Benchmark results:
user system total real
default 2.790000 0.870000 3.660000 ( 3.671597)
exception: false 1.120000 0.800000 1.920000 ( 1.922032)
exception: false (cached arg) 0.820000 0.770000 1.590000 ( 1.589267)
--------------------- benchmark script ------------------------
require 'socket'
require 'benchmark'
require 'tmpdir'
nr = 1000000
Dir.mktmpdir('nb_bench') do |path|
sock_path = "#{path}/test.sock"
s = UNIXServer.new(sock_path)
Benchmark.bmbm do |x|
x.report("default") do
nr.times do
begin
s.accept_nonblock
rescue IO::WaitReadable
end
end
end
x.report("exception: false") do
nr.times do
begin
s.accept_nonblock(exception: false)
rescue IO::WaitReadable
abort "should not raise"
end
end
end
x.report("exception: false (cached arg)") do
arg = { exception: false }
nr.times do
begin
s.accept_nonblock(arg)
rescue IO::WaitReadable
abort "should not raise"
end
end
end
end
end
* ext/socket/init.c (rsock_s_accept_nonblock):
support exception: false
[ruby-core:66385] [Feature #10532]
* ext/socket/init.c (rsock_init_socket_init): define new symbols
* ext/socket/rubysocket.h: adjust prototype
* ext/socket/socket.c (sock_accept_nonblock): support exception: false
* ext/openssl/ossl_ssl.c (ossl_ssl_accept_nonblock): ditto
* ext/socket/socket.c (Init_socket): adjust accept_nonblock definition
* ext/openssl/ossl_ssl.c (Init_ossl_ssl): ditto
* ext/socket/tcpserver.c (rsock_init_tcpserver): ditto
* ext/socket/unixserver.c (rsock_init_unixserver): ditto
* ext/socket/tcpserver.c (tcp_accept_nonblock): adjust
rsock_s_accept_nonblock call
* ext/socket/unixserver.c (unix_accept_nonblock): ditto
* ext/openssl/ossl_ssl.c (ossl_start_ssl): support no_exception
* ext/openssl/ossl_ssl.c (ossl_ssl_connect): adjust ossl_start_ssl call
* ext/openssl/ossl_ssl.c (ossl_ssl_connect_nonblock): ditto
* ext/openssl/ossl_ssl.c (ossl_ssl_accept): ditto
* test/socket/test_nonblock.rb (test_accept_nonblock): test for
"exception :false"
* test/socket/test_tcp.rb (test_accept_nonblock): new test
* test/socket/test_unix.rb (test_accept_nonblock): ditto
* test/openssl/test_pair.rb (test_accept_nonblock_no_exception): ditto
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@49948 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
68 lines
1.9 KiB
Text
68 lines
1.9 KiB
Text
# -*- rdoc -*-
|
|
|
|
= NEWS for Ruby 2.3.0
|
|
|
|
This document is a list of user visible feature changes made between
|
|
releases except for bug fixes.
|
|
|
|
Note that each entry is kept so brief that no reason behind or
|
|
reference information is supplied with. For a full list of changes
|
|
with all sufficient information, see the ChangeLog file.
|
|
|
|
== Changes since the 2.2.0 release
|
|
|
|
=== Language changes
|
|
|
|
=== Core classes updates (outstanding ones only)
|
|
|
|
=== Core classes compatibility issues (excluding feature bug fixes)
|
|
|
|
* Array
|
|
* Array#select!, Array#keep_if, Array#reject!, and Array#delete_if
|
|
no longer changes the receiver array instantly every time the
|
|
block is called. [Feature #10714]
|
|
|
|
* Array#flatten and Array#flatten! no longer try to call #to_ary
|
|
method on elements beyond the given level. [Bug #10748]
|
|
|
|
* IO
|
|
* IO#close doesn't raise when the IO object is closed. [Feature #10718]
|
|
|
|
=== Stdlib updates (outstanding ones only)
|
|
|
|
* Socket
|
|
* Socket#accept_nonblock supports `exception :false` to return symbols
|
|
Ditto for TCPServer#accept_nonblock, UNIXServer#accept_nonblock
|
|
|
|
* OpenSSL
|
|
* OpenSSL::SSL::SSLSocket#accept_nonblock supports `exception: false`
|
|
to return symbols
|
|
|
|
=== Stdlib compatibility issues (excluding feature bug fixes)
|
|
|
|
* lib/webrick/utils.rb
|
|
* removed unused argument. https://github.com/ruby/ruby/pull/356
|
|
|
|
* lib/drb/drb.rb
|
|
* removed unused argument. https://github.com/ruby/ruby/pull/515
|
|
|
|
* lib/base64.rb
|
|
* Base64.urlsafe_encode64: added a "padding" option to suppress
|
|
the padding character ("=").
|
|
* Base64.urlsafe_decode64: now it accepts not only correctly-padded
|
|
input but also unpadded input.
|
|
|
|
* lib/matrix.rb
|
|
* Add Vector#round. https://github.com/ruby/ruby/pull/802
|
|
|
|
* ext/coverage/coverage.c
|
|
* Coverage.peek_result: new method to allow coverage to be captured without
|
|
stopping the coverage tool.
|
|
|
|
=== Built-in global variables compatibility issues
|
|
|
|
=== C API updates
|
|
|
|
=== Build system updates
|
|
|
|
=== Implementation changes
|