Use concrete Item rather than an interface. Removes unnecessary dupe structs
This commit is contained in:
@@ -11,20 +11,7 @@ type estore struct {
|
||||
Client *etcd.Client
|
||||
}
|
||||
|
||||
type item struct {
|
||||
key string
|
||||
value []byte
|
||||
}
|
||||
|
||||
func (i *item) Key() string {
|
||||
return i.key
|
||||
}
|
||||
|
||||
func (i *item) Value() []byte {
|
||||
return i.value
|
||||
}
|
||||
|
||||
func (e *estore) Get(key string) (store.Item, error) {
|
||||
func (e *estore) Get(key string) (*store.Item, error) {
|
||||
kv, err := e.Client.Get(key, false, false)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@@ -33,9 +20,9 @@ func (e *estore) Get(key string) (store.Item, error) {
|
||||
return nil, errors.New("key not found")
|
||||
}
|
||||
|
||||
return &item{
|
||||
key: kv.Node.Key,
|
||||
value: []byte(kv.Node.Value),
|
||||
return &store.Item{
|
||||
Key: kv.Node.Key,
|
||||
Value: []byte(kv.Node.Value),
|
||||
}, nil
|
||||
}
|
||||
|
||||
@@ -44,19 +31,12 @@ func (e *estore) Del(key string) error {
|
||||
return err
|
||||
}
|
||||
|
||||
func (e *estore) Put(item store.Item) error {
|
||||
_, err := e.Client.Set(item.Key(), string(item.Value()), 0)
|
||||
func (e *estore) Put(item *store.Item) error {
|
||||
_, err := e.Client.Set(item.Key, string(item.Value), 0)
|
||||
|
||||
return err
|
||||
}
|
||||
|
||||
func (e *estore) NewItem(key string, value []byte) store.Item {
|
||||
return &item{
|
||||
key: key,
|
||||
value: value,
|
||||
}
|
||||
}
|
||||
|
||||
func NewStore(addrs []string, opts ...store.Option) store.Store {
|
||||
if len(addrs) == 0 {
|
||||
addrs = []string{"127.0.0.1:2379"}
|
||||
|
Reference in New Issue
Block a user