2013-10-13 01:56:43 +04:00
|
|
|
package store
|
|
|
|
|
|
|
|
type eventQueue struct {
|
2013-10-13 21:44:40 +04:00
|
|
|
Events []*Event
|
|
|
|
Size int
|
|
|
|
Front int
|
|
|
|
Capacity int
|
2013-10-13 01:56:43 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (eq *eventQueue) back() int {
|
2013-10-13 21:44:40 +04:00
|
|
|
return (eq.Front + eq.Size - 1 + eq.Capacity) % eq.Capacity
|
2013-10-13 01:56:43 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (eq *eventQueue) insert(e *Event) {
|
2013-10-13 21:44:40 +04:00
|
|
|
index := (eq.back() + 1) % eq.Capacity
|
2013-10-13 01:56:43 +04:00
|
|
|
|
2013-10-13 21:44:40 +04:00
|
|
|
eq.Events[index] = e
|
2013-10-13 01:56:43 +04:00
|
|
|
|
2013-10-13 21:44:40 +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
|
|
|
|
|
|
|
}
|