ccache/layeredbucket.go

113 lines
2.2 KiB
Go
Raw Normal View History

2014-10-25 07:19:14 +02:00
package ccache
import (
"sync"
"time"
)
type layeredBucket struct {
2014-10-25 07:19:14 +02:00
sync.RWMutex
buckets map[string]*bucket
2014-10-25 07:19:14 +02:00
}
2019-01-26 06:33:50 +01:00
func (b *layeredBucket) itemCount() int {
count := 0
b.RLock()
defer b.RUnlock()
for _, b := range b.buckets {
count += b.itemCount()
}
return count
}
func (b *layeredBucket) get(primary, secondary string) *Item {
bucket := b.getSecondaryBucket(primary)
if bucket == nil {
return nil
}
return bucket.get(secondary)
}
func (b *layeredBucket) getSecondaryBucket(primary string) *bucket {
2014-10-25 07:19:14 +02:00
b.RLock()
bucket, exists := b.buckets[primary]
b.RUnlock()
if exists == false {
return nil
}
return bucket
2014-10-25 07:19:14 +02:00
}
func (b *layeredBucket) set(primary, secondary string, value interface{}, duration time.Duration) (*Item, *Item) {
2014-10-25 07:19:14 +02:00
b.Lock()
bkt, exists := b.buckets[primary]
2014-10-25 07:19:14 +02:00
if exists == false {
bkt = &bucket{lookup: make(map[string]*Item)}
b.buckets[primary] = bkt
2014-10-25 07:19:14 +02:00
}
b.Unlock()
item, existing := bkt.set(secondary, value, duration, false)
item.group = primary
return item, existing
2014-11-13 16:23:52 +01:00
}
func (b *layeredBucket) delete(primary, secondary string) *Item {
2014-10-25 07:19:14 +02:00
b.RLock()
bucket, exists := b.buckets[primary]
b.RUnlock()
if exists == false {
return nil
}
return bucket.delete(secondary)
}
2020-08-11 18:53:40 +02:00
func (b *layeredBucket) deletePrefix(primary, prefix string, deletables chan *Item) int {
b.RLock()
bucket, exists := b.buckets[primary]
b.RUnlock()
if exists == false {
return 0
}
return bucket.deletePrefix(prefix, deletables)
}
2020-08-13 16:10:22 +02:00
func (b *layeredBucket) deleteFunc(primary string, matches func(key string, item *Item) bool, deletables chan *Item) int {
b.RLock()
bucket, exists := b.buckets[primary]
b.RUnlock()
if exists == false {
return 0
}
return bucket.deleteFunc(matches, deletables)
}
func (b *layeredBucket) deleteAll(primary string, deletables chan *Item) bool {
2014-10-25 07:19:14 +02:00
b.RLock()
bucket, exists := b.buckets[primary]
b.RUnlock()
if exists == false {
return false
2014-10-25 07:19:14 +02:00
}
bucket.Lock()
defer bucket.Unlock()
if l := len(bucket.lookup); l == 0 {
return false
2014-10-25 07:19:14 +02:00
}
for key, item := range bucket.lookup {
delete(bucket.lookup, key)
deletables <- item
}
return true
2014-10-25 07:19:14 +02:00
}
func (b *layeredBucket) clear() {
2014-10-25 07:19:14 +02:00
b.Lock()
defer b.Unlock()
for _, bucket := range b.buckets {
bucket.clear()
}
b.buckets = make(map[string]*bucket)
2014-10-25 07:19:14 +02:00
}