2019-04-15 01:32:22 +03:00
|
|
|
// Based on the implementation from https://flaviocopes.com/golang-data-structure-queue/
|
|
|
|
|
|
|
|
package queue
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/elyby/chrly/api/mojang"
|
|
|
|
)
|
|
|
|
|
|
|
|
type jobItem struct {
|
|
|
|
Username string
|
|
|
|
RespondTo chan *mojang.SignedTexturesResponse
|
|
|
|
}
|
|
|
|
|
|
|
|
type jobsQueue struct {
|
|
|
|
items []*jobItem
|
|
|
|
lock sync.RWMutex
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *jobsQueue) New() *jobsQueue {
|
|
|
|
s.items = []*jobItem{}
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *jobsQueue) Enqueue(t *jobItem) {
|
|
|
|
s.lock.Lock()
|
2019-04-19 01:41:52 +03:00
|
|
|
defer s.lock.Unlock()
|
|
|
|
|
2019-04-15 01:32:22 +03:00
|
|
|
s.items = append(s.items, t)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *jobsQueue) Dequeue(n int) []*jobItem {
|
|
|
|
s.lock.Lock()
|
2019-04-19 01:41:52 +03:00
|
|
|
defer s.lock.Unlock()
|
|
|
|
|
2019-04-15 01:32:22 +03:00
|
|
|
if n > s.Size() {
|
|
|
|
n = s.Size()
|
|
|
|
}
|
|
|
|
|
|
|
|
items := s.items[0:n]
|
|
|
|
s.items = s.items[n:len(s.items)]
|
|
|
|
|
|
|
|
return items
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *jobsQueue) IsEmpty() bool {
|
2019-04-19 01:41:52 +03:00
|
|
|
s.lock.Lock()
|
|
|
|
defer s.lock.Unlock()
|
|
|
|
|
2019-04-15 01:32:22 +03:00
|
|
|
return len(s.items) == 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *jobsQueue) Size() int {
|
|
|
|
return len(s.items)
|
|
|
|
}
|