mirror of
https://github.com/diamondburned/arikawa.git
synced 2024-11-01 12:34:28 +00:00
45 lines
764 B
Go
45 lines
764 B
Go
|
package handler
|
||
|
|
||
|
type slabEntry struct {
|
||
|
handler
|
||
|
index int
|
||
|
}
|
||
|
|
||
|
func (entry slabEntry) isInvalid() bool {
|
||
|
return entry.index != -1
|
||
|
}
|
||
|
|
||
|
// slab is an implementation of the internal handler free list.
|
||
|
type slab struct {
|
||
|
Entries []slabEntry
|
||
|
free int
|
||
|
}
|
||
|
|
||
|
func (s *slab) Put(entry handler) int {
|
||
|
if s.free == len(s.Entries) {
|
||
|
index := len(s.Entries)
|
||
|
s.Entries = append(s.Entries, slabEntry{entry, -1})
|
||
|
s.free++
|
||
|
return index
|
||
|
}
|
||
|
|
||
|
next := s.Entries[s.free].index
|
||
|
s.Entries[s.free] = slabEntry{entry, -1}
|
||
|
|
||
|
i := s.free
|
||
|
s.free = next
|
||
|
|
||
|
return i
|
||
|
}
|
||
|
|
||
|
func (s *slab) Get(i int) handler {
|
||
|
return s.Entries[i].handler
|
||
|
}
|
||
|
|
||
|
func (s *slab) Pop(i int) handler {
|
||
|
popped := s.Entries[i].handler
|
||
|
s.Entries[i] = slabEntry{handler{}, s.free}
|
||
|
s.free = i
|
||
|
return popped
|
||
|
}
|