Class: Async::IO::TCPSocket

Inherits:
IPSocket show all
Includes:
Peer
Defined in:
lib/async/io/tcp_socket.rb

Overview

Asynchronous TCP socket wrapper.

Direct Known Subclasses

TCPServer

Constant Summary

Constants inherited from Generic

Generic::WRAPPERS

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods included from Peer

#connected?

Methods inherited from BasicSocket

#type

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

#bufferObject (readonly)

Returns the value of attribute buffer.



58
59
60
# File 'lib/async/io/tcp_socket.rb', line 58

def buffer
  @buffer
end