module EventMachine::Protocols::Redis

def self.connect(*args)

def self.connect(*args)
  f = Fiber.current
  conn = self.aconnect(*args)
  conn.callback { f.resume(conn) }
  Fiber.yield
end

def amapped_mget(*keys)

the asynchronous version of mget
adapted from em-redis' implementation to use
def amapped_mget(*keys)
  self.amget(*keys) do |response|
    result = {}
    response.each do |value|
      key = keys.shift
      result.merge!(key => value) unless value.nil?
    end
    yield result if block_given?
  end
end

def call_command(argv, &blk)

def call_command(argv, &blk)
  # async commands are 'a' prefixed
  if (argv.first[0] == 'a') && !SYNC.include?(argv.first.to_s)
    argv[0] = argv[0].to_s.slice(1,argv[0].size)
    old_call_command(argv, &blk)
  else
    # wrap response blocks into fiber callbacks
    # to emulate the sync api
    f = Fiber.current
    blk = proc { |v| v } if !block_given?
    clb = proc { |v| f.resume(blk.call(v)) }
    old_call_command(argv, &clb)
    Fiber.yield
  end
end

def mapped_mget(*keys)

def mapped_mget(*keys)
  f = Fiber.current
  self.amapped_mget(*keys) do |values|
    f.resume(values)
  end
  Fiber.yield
end