Class: ZMQMachine::Socket::Pair
- Inherits:
-
Object
- Object
- ZMQMachine::Socket::Pair
- Includes:
- Base
- Defined in:
- lib/zm/sockets/pair.rb
Instance Attribute Summary
Attributes included from Base
#kind, #poll_options, #raw_socket
Instance Method Summary collapse
-
#initialize(context, handler) ⇒ Pair
constructor
A new instance of Pair.
-
#on_attach(handler) ⇒ Object
Attach a handler to the PAIR socket.
Methods included from Base
#attach, #bind, #connect, create, #identity, #identity=, #inspect, #resume_read, #resume_write, #send_message, #send_message_string, #send_messages
Constructor Details
#initialize(context, handler) ⇒ Pair
Returns a new instance of Pair.
44 45 46 47 48 49 |
# File 'lib/zm/sockets/pair.rb', line 44 def initialize context, handler @poll_options = ZMQ::POLLIN @kind = :pair super end |
Instance Method Details
#on_attach(handler) ⇒ Object
Attach a handler to the PAIR socket.
A PAIR socket may send and receive messages without restriction to order or quantity of send/recv operations.
This socket expects its handler
to implement the #on_readable and #on_writable methods. The #on_readable method will be called whenever a message may be dequeued without blocking. The #on_writable method will be called whenever a message may be enqueued without blocking.
For error handling purposes, the handler must also implement #on_readable_error and #on_writable_error.
67 68 69 70 71 72 73 |
# File 'lib/zm/sockets/pair.rb', line 67 def on_attach handler raise ArgumentError, "Handler must implement an #on_readable method" unless handler.respond_to? :on_readable raise ArgumentError, "Handler must implement an #on_writable method" unless handler.respond_to? :on_writable raise ArgumentError, "Handler must implement an #on_readable_error method" unless handler.respond_to? :on_readable_error raise ArgumentError, "Handler must implement an #on_writable_error method" unless handler.respond_to? :on_writable_error super end |