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