etcd/store/event_queue.go

26 lines
414 B
Go
Raw Normal View History

2013-10-13 01:56:43 +04:00
package store
type eventQueue struct {
Events []*Event
Size int
Front int
Capacity int
2013-10-13 01:56:43 +04:00
}
func (eq *eventQueue) back() int {
return (eq.Front + eq.Size - 1 + eq.Capacity) % eq.Capacity
2013-10-13 01:56:43 +04:00
}
func (eq *eventQueue) insert(e *Event) {
index := (eq.back() + 1) % eq.Capacity
2013-10-13 01:56:43 +04:00
eq.Events[index] = e
2013-10-13 01:56:43 +04:00
if eq.Size == eq.Capacity { //dequeue
eq.Front = (index + 1) % eq.Capacity
} else {
eq.Size++
}
2013-10-13 01:56:43 +04:00
}