public
Fork of riham/eventmachine
Description: A fast network I/O and event-management framework for Ruby, Java, and C++ programmers.
Homepage: http://rubyeventmachine.com
Clone URL: git://github.com/espace/eventmachine.git
eventmachine / KEYBOARD
100644 39 lines (25 sloc) 1.226 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
EventMachine (EM) can respond to keyboard events. This gives your event-driven programs the ability to respond to input from local users.
 
Programming EM to handle keyboard input in Ruby is simplicity itself. Just use EventMachine#open_keyboard, and supply the name of a Ruby module or class that will receive the input:
 
 require 'rubygems'
 require 'eventmachine'
 
 module MyKeyboardHandler
  def receive_data keystrokes
  puts "I received the following data from the keyboard: #{keystrokes}"
  end
 end
 
 EM.run {
  EM.open_keyboard(MyKeyboardHandler)
 }
 
 
If you want EM to send line-buffered keyboard input to your program, just include the LineText2 protocol module in your handler class or module:
 
 
 
 require 'rubygems'
 require 'eventmachine'
 
 module MyKeyboardHandler
  include EM::Protocols::LineText2
  def receive_line data
  puts "I received the following line from the keyboard: #{data}"
  end
 end
 
 EM.run {
  EM.open_keyboard(MyKeyboardHandler)
 }
 
As we said, simplicity itself. You can call EventMachine#open_keyboard at any time while the EM reactor loop is running. In other words, the method invocation may appear anywhere in an EventMachine#run block, or in any code invoked in the #run block.