| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- // Copyright 2015 CoreOS, Inc.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- package storage
- import (
- "sync"
- "github.com/coreos/etcd/storage/storagepb"
- )
- // Watcher watches on the KV. It will be notified if there is an event
- // happened on the watched key or prefix.
- type Watcher interface {
- // Event returns a channel that receives observed event that matches the
- // context of watcher. When watch finishes or is canceled or aborted, the
- // channel is closed and returns empty event.
- // Successive calls to Event return the same value.
- Event() <-chan storagepb.Event
- // Err returns a non-nil error value after Event is closed. Err returns
- // Compacted if the history was compacted, Canceled if watch is canceled,
- // or EOF if watch reaches the end revision. No other values for Err are defined.
- // After Event is closed, successive calls to Err return the same value.
- Err() error
- }
- type watcher struct {
- key []byte
- prefix bool
- cur int64
- ch chan storagepb.Event
- mu sync.Mutex
- err error
- }
- func newWatcher(key []byte, prefix bool, start int64) *watcher {
- return &watcher{
- key: key,
- prefix: prefix,
- cur: start,
- ch: make(chan storagepb.Event, 10),
- }
- }
- func (w *watcher) Event() <-chan storagepb.Event { return w.ch }
- func (w *watcher) Err() error {
- w.mu.Lock()
- defer w.mu.Unlock()
- return w.err
- }
- func (w *watcher) stopWithError(err error) {
- if w.err != nil {
- return
- }
- close(w.ch)
- w.mu.Lock()
- w.err = err
- w.mu.Unlock()
- }
|