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
|
2013-12-21 11:56:16 +04:00
|
|
|
Back int
|
2013-10-13 21:44:40 +04:00
|
|
|
Capacity int
|
2013-10-13 01:56:43 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
func (eq *eventQueue) insert(e *Event) {
|
2013-12-21 11:56:16 +04:00
|
|
|
eq.Events[eq.Back] = e
|
|
|
|
eq.Back = (eq.Back + 1) % eq.Capacity
|
2013-10-13 01:56:43 +04:00
|
|
|
|
2013-10-13 21:44:40 +04:00
|
|
|
if eq.Size == eq.Capacity { //dequeue
|
2013-12-21 11:56:16 +04:00
|
|
|
eq.Front = (eq.Front + 1) % eq.Capacity
|
2013-10-13 21:44:40 +04:00
|
|
|
} else {
|
|
|
|
eq.Size++
|
|
|
|
}
|
2013-10-13 01:56:43 +04:00
|
|
|
}
|