redis.go 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. // Copyright 2012 Gary Burd
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License"): you may
  4. // not use this file except in compliance with the License. You may obtain
  5. // a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
  11. // WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
  12. // License for the specific language governing permissions and limitations
  13. // under the License.
  14. package redis
  15. // Error represents an error returned in a command reply.
  16. type Error string
  17. func (err Error) Error() string { return string(err) }
  18. // Conn represents a connection to a Redis server.
  19. type Conn interface {
  20. // Close closes the connection.
  21. Close() error
  22. // Err returns a non-nil value when the connection is not usable.
  23. Err() error
  24. // Do sends a command to the server and returns the received reply.
  25. Do(commandName string, args ...interface{}) (reply interface{}, err error)
  26. // Send writes the command to the client's output buffer.
  27. Send(commandName string, args ...interface{}) error
  28. // Flush flushes the output buffer to the Redis server.
  29. Flush() error
  30. // Receive receives a single reply from the Redis server
  31. Receive() (reply interface{}, err error)
  32. }
  33. // Argument is the interface implemented by an object which wants to control how
  34. // the object is converted to Redis bulk strings.
  35. type Argument interface {
  36. // RedisArg returns a value to be encoded as a bulk string per the
  37. // conversions listed in the section 'Executing Commands'.
  38. // Implementations should typically return a []byte or string.
  39. RedisArg() interface{}
  40. }
  41. // Scanner is implemented by an object which wants to control its value is
  42. // interpreted when read from Redis.
  43. type Scanner interface {
  44. // RedisScan assigns a value from a Redis value. The argument src is one of
  45. // the reply types listed in the section `Executing Commands`.
  46. //
  47. // An error should be returned if the value cannot be stored without
  48. // loss of information.
  49. RedisScan(src interface{}) error
  50. }