Class: EventMachine::EvmaUDPSocket

Inherits:
DatagramObject show all
Defined in:
lib/em/pure_ruby.rb

Instance Attribute Summary

Attributes inherited from Selectable

#io, #is_server, #uuid

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from DatagramObject

#get_outbound_data_size, #initialize, #select_for_reading?, #select_for_writing?, #send_datagram

Methods inherited from Selectable

#close_scheduled?, #get_peername, #get_sockname, #heartbeat, #initialize, #schedule_close, #select_for_reading?, #select_for_writing?, #set_inactivity_timeout

Constructor Details

This class inherits a constructor from EventMachine::DatagramObject

Class Method Details

.create(host, port) ⇒ Object



1218
1219
1220
1221
1222
# File 'lib/em/pure_ruby.rb', line 1218

def create host, port
  sd = Socket.new( Socket::AF_INET, Socket::SOCK_DGRAM, 0 )
  sd.bind Socket::pack_sockaddr_in( port, host )
  EvmaUDPSocket.new sd
end

Instance Method Details

#eventable_readObject

Proper nonblocking I/O was added to Ruby 1.8.4 in May 2006. If we have it, then we can read multiple times safely to improve performance.



1252
1253
1254
1255
1256
1257
1258
1259
1260
1261
1262
1263
1264
1265
1266
1267
1268
1269
# File 'lib/em/pure_ruby.rb', line 1252

def eventable_read
  begin
    if io.respond_to?(:recvfrom_nonblock)
      40.times {
        data,@return_address = io.recvfrom_nonblock(16384)
        EventMachine::event_callback uuid, ConnectionData, data
        @return_address = nil
      }
    else
      raise "unimplemented datagram-read operation on this Ruby"
    end
  rescue Errno::EAGAIN
    # no-op
  rescue Errno::ECONNRESET, EOFError
    @close_scheduled = true
    EventMachine::event_callback uuid, ConnectionUnbound, nil
  end
end

#eventable_writeObject

#eventable_write This really belongs in DatagramObject, but there is some UDP-specific stuff.



1227
1228
1229
1230
1231
1232
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
# File 'lib/em/pure_ruby.rb', line 1227

def eventable_write
  40.times {
    break if @outbound_q.empty?
    begin
      data,target = @outbound_q.first

      # This damn better be nonblocking.
      io.send data.to_s, 0, target

      @outbound_q.shift
    rescue Errno::EAGAIN
      # It's not been observed in testing that we ever get here.
      # True to the definition, packets will be accepted and quietly dropped
      # if the system is under pressure.
      break
    rescue EOFError, Errno::ECONNRESET
      @close_scheduled = true
      @outbound_q.clear
    end
  }
end

#send_data(data) ⇒ Object



1271
1272
1273
# File 'lib/em/pure_ruby.rb', line 1271

def send_data data
  send_datagram data, @return_address
end