* lib/resolv-replace.rb (BasicSocket#send): don't replace because
it has no hostname argument. (IPSocket.getaddress): raise SocketError instead of Resolv::ResolvError for errors. (TCPSocket#initialize, UDPSocket#bind, UDPSocket#connect) (SOCKSSocket#initialize): use IPSocket.getaddress instead of Resolv.getaddress. (UDPSocket#send): recognize 3 arguments form. try all addresses on 4 arguments form. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5605 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
0967d72815
commit
c9c51009cf
13
ChangeLog
13
ChangeLog
@ -1,4 +1,17 @@
|
|||||||
|
Mon Feb 2 00:01:19 2004 Tanaka Akira <akr@m17n.org>
|
||||||
|
|
||||||
|
* lib/resolv-replace.rb (BasicSocket#send): don't replace because
|
||||||
|
it has no hostname argument.
|
||||||
|
(IPSocket.getaddress): raise SocketError instead of
|
||||||
|
Resolv::ResolvError for errors.
|
||||||
|
(TCPSocket#initialize, UDPSocket#bind, UDPSocket#connect)
|
||||||
|
(SOCKSSocket#initialize): use IPSocket.getaddress instead of
|
||||||
|
Resolv.getaddress.
|
||||||
|
(UDPSocket#send): recognize 3 arguments form. try all addresses on
|
||||||
|
4 arguments form.
|
||||||
|
|
||||||
Sun Feb 1 23:00:00 2004 Shigeo Kobayashi <shigek@ruby-lang.org>
|
Sun Feb 1 23:00:00 2004 Shigeo Kobayashi <shigek@ruby-lang.org>
|
||||||
|
|
||||||
* ext/bigdecimal.c: Bug in BigDecimal("1e#{n}").add BigDecimal('.5'),n)
|
* ext/bigdecimal.c: Bug in BigDecimal("1e#{n}").add BigDecimal('.5'),n)
|
||||||
reported and fixed by Javier Goizueta.
|
reported and fixed by Javier Goizueta.
|
||||||
|
|
||||||
|
@ -1,50 +1,62 @@
|
|||||||
require 'socket'
|
require 'socket'
|
||||||
require 'resolv'
|
require 'resolv'
|
||||||
|
|
||||||
class BasicSocket
|
|
||||||
alias original_resolv_send send
|
|
||||||
def send(mesg, flags, *rest)
|
|
||||||
rest[0] = Resolv.getaddress(rest[0]).to_s unless rest.empty?
|
|
||||||
original_resolv_send(mesg, flags, *rest)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
class << IPSocket
|
class << IPSocket
|
||||||
alias original_resolv_getaddress getaddress
|
alias original_resolv_getaddress getaddress
|
||||||
def getaddress(host)
|
def getaddress(host)
|
||||||
return Resolv.getaddress(host).to_s
|
begin
|
||||||
|
return Resolv.getaddress(host).to_s
|
||||||
|
rescue Resolv::ResolvError
|
||||||
|
raise SocketError, "Name or service not known: #{host}"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class TCPSocket
|
class TCPSocket
|
||||||
alias original_resolv_initialize initialize
|
alias original_resolv_initialize initialize
|
||||||
def initialize(host, serv, *rest)
|
def initialize(host, serv, *rest)
|
||||||
rest[0] = Resolv.getaddress(rest[0]).to_s unless rest.empty?
|
rest[0] = IPSocket.getaddress(rest[0]) unless rest.empty?
|
||||||
original_resolv_initialize(Resolv.getaddress(host).to_s, serv, *rest)
|
original_resolv_initialize(IPSocket.getaddress(host), serv, *rest)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class UDPSocket
|
class UDPSocket
|
||||||
alias original_resolv_bind bind
|
alias original_resolv_bind bind
|
||||||
def bind(host, port)
|
def bind(host, port)
|
||||||
original_resolv_bind(Resolv.getaddress(host).to_s, port)
|
original_resolv_bind(IPSocket.getaddress(host), port)
|
||||||
end
|
end
|
||||||
|
|
||||||
alias original_resolv_connect connect
|
alias original_resolv_connect connect
|
||||||
def connect(host, port)
|
def connect(host, port)
|
||||||
original_resolv_connect(Resolv.getaddress(host).to_s, port)
|
original_resolv_connect(IPSocket.getaddress(host), port)
|
||||||
end
|
end
|
||||||
|
|
||||||
alias original_resolv_send send
|
alias original_resolv_send send
|
||||||
def send(mesg, flags, *rest)
|
def send(mesg, flags, *rest)
|
||||||
rest[0] = Resolv.getaddress(rest[0]).to_s unless rest.empty?
|
if rest.length == 2
|
||||||
original_resolv_send(mesg, flags, *rest)
|
host, port = rest
|
||||||
|
begin
|
||||||
|
addrs = Resolv.getaddresses(host)
|
||||||
|
rescue Resolv::ResolvError
|
||||||
|
raise SocketError, "Name or service not known: #{host}"
|
||||||
|
end
|
||||||
|
err = nil
|
||||||
|
addrs[0...-1].each {|addr|
|
||||||
|
begin
|
||||||
|
return original_resolv_send(mesg, flags, addr, port)
|
||||||
|
rescue SystemCallError
|
||||||
|
end
|
||||||
|
}
|
||||||
|
original_resolv_send(mesg, flags, addrs[-1], port)
|
||||||
|
else
|
||||||
|
original_resolv_send(mesg, flags, *rest)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
class SOCKSSocket
|
class SOCKSSocket
|
||||||
alias original_resolv_initialize initialize
|
alias original_resolv_initialize initialize
|
||||||
def initialize(host, serv)
|
def initialize(host, serv)
|
||||||
original_resolv_initialize(Resolv.getaddress(host).to_s, port)
|
original_resolv_initialize(IPSocket.getaddress(host), port)
|
||||||
end
|
end
|
||||||
end if defined? SOCKSSocket
|
end if defined? SOCKSSocket
|
||||||
|
Loading…
x
Reference in New Issue
Block a user