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