fix: remove segment from cache on empty template

This commit is contained in:
Jan De Dobbeleer 2023-01-26 19:45:31 +01:00 committed by Jan De Dobbeleer
parent 51fd45dc60
commit 8ba753e08c
2 changed files with 24 additions and 5 deletions

View file

@ -47,6 +47,7 @@ type Segment struct {
writer SegmentWriter writer SegmentWriter
text string text string
styleCache SegmentStyle styleCache SegmentStyle
name string
} }
// SegmentTiming holds the timing context for a segment // SegmentTiming holds the timing context for a segment
@ -427,6 +428,18 @@ func (segment *Segment) string() string {
return text return text
} }
func (segment *Segment) Name() string {
if len(segment.name) != 0 {
return segment.name
}
name := segment.Alias
if len(name) == 0 {
name = c.Title(language.English).String(string(segment.Type))
}
segment.name = name
return name
}
func (segment *Segment) SetEnabled(env platform.Environment) { func (segment *Segment) SetEnabled(env platform.Environment) {
defer func() { defer func() {
err := recover() err := recover()
@ -456,11 +469,7 @@ func (segment *Segment) SetEnabled(env platform.Environment) {
} }
if segment.writer.Enabled() { if segment.writer.Enabled() {
segment.Enabled = true segment.Enabled = true
name := segment.Alias env.TemplateCache().AddSegmentData(segment.Name(), segment.writer)
if len(name) == 0 {
name = c.Title(language.English).String(string(segment.Type))
}
env.TemplateCache().AddSegmentData(name, segment.writer)
} }
} }
@ -470,6 +479,10 @@ func (segment *Segment) SetText() {
} }
segment.text = segment.string() segment.text = segment.string()
segment.Enabled = len(strings.ReplaceAll(segment.text, " ", "")) > 0 segment.Enabled = len(strings.ReplaceAll(segment.text, " ", "")) > 0
if !segment.Enabled {
segment.env.TemplateCache().RemoveSegmentData(segment.Name())
}
if segment.Interactive { if segment.Interactive {
return return
} }

View file

@ -163,6 +163,12 @@ func (t *TemplateCache) AddSegmentData(key string, value interface{}) {
t.Unlock() t.Unlock()
} }
func (t *TemplateCache) RemoveSegmentData(key string) {
t.Lock()
delete(t.Segments, key)
t.Unlock()
}
type Environment interface { type Environment interface {
Getenv(key string) string Getenv(key string) string
Pwd() string Pwd() string