class Redis::Connection::Synchrony

def self.connect(config)

def self.connect(config)
  if config[:scheme] == "unix"
    begin
      conn = EventMachine.connect_unix_domain(config[:path], RedisClient)
    rescue RuntimeError => e
      if e.message == "no connection"
        raise Errno::ECONNREFUSED
      else
        raise e
      end
    end
  elsif config[:scheme] == "rediss" || config[:ssl]
    raise NotImplementedError, "SSL not supported by synchrony driver"
  else
    conn = EventMachine.connect(config[:host], config[:port], RedisClient) do |c|
      c.pending_connect_timeout = [config[:connect_timeout], 0.1].max
    end
  end
  fiber = Fiber.current
  conn.callback { fiber.resume }
  conn.errback { fiber.resume :refused }
  raise Errno::ECONNREFUSED if Fiber.yield == :refused
  instance = new(conn)
  instance.timeout = config[:read_timeout]
  instance
end

def connected?

def connected?
  @connection && @connection.connected?
end

def disconnect

def disconnect
  @connection.close_connection
  @connection = nil
end

def initialize(connection)

def initialize(connection)
  @connection = connection
end

def read

def read
  type, payload = @connection.read
  if type == :reply
    payload
  elsif type == :error
    raise payload
  elsif type == :timeout
    raise TimeoutError
  else
    raise "Unknown type #{type.inspect}"
  end
end

def timeout=(timeout)

def timeout=(timeout)
  @connection.timeout = timeout
end

def write(command)

def write(command)
  @connection.send(build_command(command))
end