Class: Async::IO::TCPSocket
- Inherits:
-
IPSocket
- Object
- Wrapper
- Generic
- BasicSocket
- IPSocket
- Async::IO::TCPSocket
- Includes:
- Peer
- Defined in:
- lib/async/io/tcp_socket.rb
Overview
Asynchronous TCP socket wrapper.
Direct Known Subclasses
Constant Summary
Constants inherited from Generic
Instance Attribute Summary collapse
-
#buffer ⇒ Object
readonly
Returns the value of attribute buffer.
Instance Method Summary collapse
-
#initialize(remote_host, remote_port = nil, local_host = nil, local_port = nil) ⇒ TCPSocket
constructor
A new instance of TCPSocket.
Methods included from Peer
Methods inherited from BasicSocket
Methods inherited from Generic
#connected?, #nonblock, #nonblock?, #read, #wait, wrap, wrap_blocking_method, wraps, #write
Constructor Details
#initialize(remote_host, remote_port = nil, local_host = nil, local_port = nil) ⇒ TCPSocket
Returns a new instance of TCPSocket.
31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 |
# File 'lib/async/io/tcp_socket.rb', line 31 def initialize(remote_host, remote_port = nil, local_host = nil, local_port = nil) if remote_host.is_a? ::TCPSocket super(remote_host) else remote_address = Addrinfo.tcp(remote_host, remote_port) local_address = Addrinfo.tcp(local_host, local_port) if local_host # We do this unusual dance to avoid leaking an "open" socket instance. socket = Socket.connect(remote_address, local_address) fd = socket.fcntl(Fcntl::F_DUPFD) socket.close super(::TCPSocket.for_fd(fd)) # The equivalent blocking operation. Unfortunately there is no trivial way to make this non-blocking. # super(::TCPSocket.new(remote_host, remote_port, local_host, local_port)) end @buffer = Stream.new(self) end |
Instance Attribute Details
#buffer ⇒ Object (readonly)
Returns the value of attribute buffer.
58 59 60 |
# File 'lib/async/io/tcp_socket.rb', line 58 def buffer @buffer end |