From 13417d5fb36cdc8bd27865612b1c75170f62d1bb Mon Sep 17 00:00:00 2001 From: Christoph Pech Date: Thu, 23 Feb 2017 16:50:36 +0100 Subject: [PATCH] thread safety bugfix --- draw2dbase/text.go | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/draw2dbase/text.go b/draw2dbase/text.go index 4283bad..cad6b97 100644 --- a/draw2dbase/text.go +++ b/draw2dbase/text.go @@ -1,8 +1,13 @@ package draw2dbase -import "github.com/llgcode/draw2d" +import ( + "sync" + + "github.com/llgcode/draw2d" +) var glyphCache map[string]map[rune]*Glyph +var glyphCacheLock sync.RWMutex func init() { glyphCache = make(map[string]map[rune]*Glyph) @@ -10,6 +15,22 @@ func init() { // FetchGlyph fetches a glyph from the cache, calling renderGlyph first if it doesn't already exist func FetchGlyph(gc draw2d.GraphicContext, fontName string, chr rune) *Glyph { + //fast parallel access with read-lock only + glyphCacheLock.RLock() + gCFont, _ := glyphCache[fontName] + if gCFont != nil { + gcRune, _ := gCFont[chr] + if gcRune != nil { + glyphCacheLock.RUnlock() + return gcRune + } + } + glyphCacheLock.RUnlock() + + //cache miss requires write-lock + glyphCacheLock.Lock() + defer glyphCacheLock.Unlock() + if glyphCache[fontName] == nil { glyphCache[fontName] = make(map[rune]*Glyph, 60) }