Documentation ¶
Overview ¶
Package cache implements a simple cache where the entries are expired after a given time (5 minutes of disuse by default).
Index ¶
- type Cache
- func (c *Cache) Clear()
- func (c *Cache) Delete(key string) bool
- func (c *Cache) DeletePrefix(prefix string) (deleted int)
- func (c *Cache) Entries() int
- func (c *Cache) EntriesWithPinCount() (pinned, unpinned int)
- func (c *Cache) Get(key string, create CreateFunc) (value interface{}, err error)
- func (c *Cache) GetMaybe(key string) (value interface{}, found bool)
- func (c *Cache) Pin(key string)
- func (c *Cache) Put(key string, value interface{})
- func (c *Cache) PutErr(key string, value interface{}, err error)
- func (c *Cache) Rename(oldKey, newKey string) (value interface{}, found bool)
- func (c *Cache) SetExpireDuration(d time.Duration) *Cache
- func (c *Cache) SetExpireInterval(d time.Duration) *Cache
- func (c *Cache) SetFinalizer(finalize func(interface{}))
- func (c *Cache) Unpin(key string)
- type CreateFunc
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Cache ¶
type Cache struct {
// contains filtered or unexported fields
}
Cache holds values indexed by string, but expired after a given (5 minutes by default).
func (*Cache) DeletePrefix ¶
DeletePrefix deletes all entries with the given prefix
Returns number of entries deleted
func (*Cache) EntriesWithPinCount ¶
EntriesWithPinCount returns the number of pinned and unpinned entries in the cache
Each entry is counted only once, regardless of entry.pinCount
func (*Cache) Get ¶
func (c *Cache) Get(key string, create CreateFunc) (value interface{}, err error)
Get gets a value named key either from the cache or creates it afresh with the create function.
func (*Cache) Rename ¶
Rename renames the item at oldKey to newKey.
If there was an existing item at newKey then it takes precedence and is returned otherwise the item (if any) at oldKey is returned.
func (*Cache) SetExpireDuration ¶
SetExpireDuration sets the interval at which things expire
If it is less than or equal to 0 then things are never cached
func (*Cache) SetExpireInterval ¶
SetExpireInterval sets the interval at which the cache expiry runs
Set to 0 or a -ve number to disable
func (*Cache) SetFinalizer ¶
func (c *Cache) SetFinalizer(finalize func(interface{}))
SetFinalizer sets a function to be called when a value drops out of the cache
type CreateFunc ¶
CreateFunc is called to create new values. If the create function returns an error it will be cached if ok is true, otherwise the error will just be returned, allowing negative caching if required.