-
-
Notifications
You must be signed in to change notification settings - Fork 49
/
imagecache.go
43 lines (37 loc) · 863 Bytes
/
imagecache.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/*
* Copyright (c) 2018 LI Zhennan
*
* Use of this work is governed by an MIT License.
* You may find a license copy in project root.
*
*/
package orly
import (
"image"
"sync"
)
// ImageCache is an in-memory key-value image store
//
// ImageCache is safe for concurrency use.
type ImageCache struct {
m sync.Map
}
// NewImageCache returns a empty image store
func NewImageCache() *ImageCache {
return new(ImageCache)
}
// Store sets the image for a key.
func (i *ImageCache) Store(key string, img image.Image) {
i.m.Store(key, img)
}
// Load returns the image stored in the map for a key,
// or nil if no value is present.
//
// The found result indicates whether value was found in the map.
func (i *ImageCache) Load(key string) (img image.Image, found bool) {
thing, found := i.m.Load(key)
if found {
img = thing.(image.Image)
}
return
}