ledisdb/server/cmd_list.go

394 lines
6.3 KiB
Go

package server
import (
"strconv"
"time"
"github.com/siddontang/go/hack"
"github.com/siddontang/ledisdb/ledis"
)
func lpushCommand(c *client) error {
args := c.args
if len(args) < 2 {
return ErrCmdParams
}
if n, err := c.db.LPush(args[0], args[1:]...); err != nil {
return err
} else {
c.resp.writeInteger(n)
}
return nil
}
func rpushCommand(c *client) error {
args := c.args
if len(args) < 2 {
return ErrCmdParams
}
if n, err := c.db.RPush(args[0], args[1:]...); err != nil {
return err
} else {
c.resp.writeInteger(n)
}
return nil
}
func lpopCommand(c *client) error {
args := c.args
if len(args) != 1 {
return ErrCmdParams
}
if v, err := c.db.LPop(args[0]); err != nil {
return err
} else {
c.resp.writeBulk(v)
}
return nil
}
func rpopCommand(c *client) error {
args := c.args
if len(args) != 1 {
return ErrCmdParams
}
if v, err := c.db.RPop(args[0]); err != nil {
return err
} else {
c.resp.writeBulk(v)
}
return nil
}
func llenCommand(c *client) error {
args := c.args
if len(args) != 1 {
return ErrCmdParams
}
if n, err := c.db.LLen(args[0]); err != nil {
return err
} else {
c.resp.writeInteger(n)
}
return nil
}
func lindexCommand(c *client) error {
args := c.args
if len(args) != 2 {
return ErrCmdParams
}
index, err := ledis.StrInt64(args[1], nil)
if err != nil {
return ErrValue
}
if v, err := c.db.LIndex(args[0], int32(index)); err != nil {
return err
} else {
c.resp.writeBulk(v)
}
return nil
}
func lrangeCommand(c *client) error {
args := c.args
if len(args) != 3 {
return ErrCmdParams
}
var start int64
var stop int64
var err error
start, err = ledis.StrInt64(args[1], nil)
if err != nil {
return ErrValue
}
stop, err = ledis.StrInt64(args[2], nil)
if err != nil {
return ErrValue
}
if v, err := c.db.LRange(args[0], int32(start), int32(stop)); err != nil {
return err
} else {
c.resp.writeSliceArray(v)
}
return nil
}
func lclearCommand(c *client) error {
args := c.args
if len(args) != 1 {
return ErrCmdParams
}
if n, err := c.db.LClear(args[0]); err != nil {
return err
} else {
c.resp.writeInteger(n)
}
return nil
}
func lmclearCommand(c *client) error {
args := c.args
if len(args) < 1 {
return ErrCmdParams
}
if n, err := c.db.LMclear(args...); err != nil {
return err
} else {
c.resp.writeInteger(n)
}
return nil
}
func lexpireCommand(c *client) error {
args := c.args
if len(args) != 2 {
return ErrCmdParams
}
duration, err := ledis.StrInt64(args[1], nil)
if err != nil {
return ErrValue
}
if v, err := c.db.LExpire(args[0], duration); err != nil {
return err
} else {
c.resp.writeInteger(v)
}
return nil
}
func lexpireAtCommand(c *client) error {
args := c.args
if len(args) != 2 {
return ErrCmdParams
}
when, err := ledis.StrInt64(args[1], nil)
if err != nil {
return ErrValue
}
if v, err := c.db.LExpireAt(args[0], when); err != nil {
return err
} else {
c.resp.writeInteger(v)
}
return nil
}
func lttlCommand(c *client) error {
args := c.args
if len(args) != 1 {
return ErrCmdParams
}
if v, err := c.db.LTTL(args[0]); err != nil {
return err
} else {
c.resp.writeInteger(v)
}
return nil
}
func lpersistCommand(c *client) error {
args := c.args
if len(args) != 1 {
return ErrCmdParams
}
if n, err := c.db.LPersist(args[0]); err != nil {
return err
} else {
c.resp.writeInteger(n)
}
return nil
}
func blpopCommand(c *client) error {
keys, timeout, err := lParseBPopArgs(c)
if err != nil {
return err
}
if ay, err := c.db.BLPop(keys, timeout); err != nil {
return err
} else {
c.resp.writeArray(ay)
}
return nil
}
func brpopCommand(c *client) error {
keys, timeout, err := lParseBPopArgs(c)
if err != nil {
return err
}
if ay, err := c.db.BRPop(keys, timeout); err != nil {
return err
} else {
c.resp.writeArray(ay)
}
return nil
}
func lParseBPopArgs(c *client) (keys [][]byte, timeout time.Duration, err error) {
args := c.args
if len(args) < 2 {
err = ErrCmdParams
return
}
var t float64
if t, err = strconv.ParseFloat(hack.String(args[len(args)-1]), 64); err != nil {
return
}
timeout = time.Duration(t * float64(time.Second))
keys = args[0 : len(args)-1]
return
}
func lkeyexistsCommand(c *client) error {
args := c.args
if len(args) != 1 {
return ErrCmdParams
}
if n, err := c.db.LKeyExists(args[0]); err != nil {
return err
} else {
c.resp.writeInteger(n)
}
return nil
}
func lTrimCommand(c *client) error {
args := c.args
if len(args) != 3 {
return ErrCmdParams
}
var start int32
var stop int32
var err error
start, err = ledis.StrInt64(args[1], nil)
if err != nil {
return ErrValue
}
stop, err = ledis.StrInt64(args[2], nil)
if err != nil {
return ErrValue
}
if err := c.db.LTrim(args[0], start, stop); err != nil {
return err
} else {
c.resp.writeStatus(OK)
}
return nil
}
func lTrimFrontCommand(c *client) error {
args := c.args
if len(args) != 2 {
return ErrCmdParams
}
var trimSize int32
var err error
trimSize, err = ledis.StrInt32(args[1], nil)
if err != nil || trimSize < 0 {
return ErrValue
}
if n, err := c.db.LTrimFront(args[0], trimSize); err != nil {
return err
} else {
c.resp.writeInteger(int64(n))
}
return nil
}
func lTrimBackCommand(c *client) error {
args := c.args
if len(args) != 2 {
return ErrCmdParams
}
var trimSize int32
var err error
trimSize, err = ledis.StrInt32(args[1], nil)
if err != nil || trimSize < 0 {
return ErrValue
}
if n, err := c.db.LTrimBack(args[0], trimSize); err != nil {
return err
} else {
c.resp.writeInteger(int64(n))
}
return nil
}
func init() {
register("blpop", blpopCommand)
register("brpop", brpopCommand)
register("lindex", lindexCommand)
register("llen", llenCommand)
register("lpop", lpopCommand)
register("lrange", lrangeCommand)
register("lpush", lpushCommand)
register("rpop", rpopCommand)
register("rpush", rpushCommand)
//ledisdb special command
register("lclear", lclearCommand)
register("lmclear", lmclearCommand)
register("lexpire", lexpireCommand)
register("lexpireat", lexpireAtCommand)
register("lttl", lttlCommand)
register("lpersist", lpersistCommand)
register("lkeyexists", lkeyexistsCommand)
register("ltrim_front", lTrimFrontCommand)
register("ltrim_back", lTrimBackCommand)
register("ltrim", lTrimCommand)
}