-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
colorpicker.go
65 lines (53 loc) · 2.13 KB
/
colorpicker.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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
/*
Copyright 2021 The Skaffold Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package output
import (
tag "github.com/GoogleContainerTools/skaffold/v2/pkg/skaffold/tag/util"
)
type ColorPicker interface {
AddImage(string)
Pick(string) Color
}
// ColorPicker associates colors with images such that container logs can be output to
// the terminal with a consistent color being used to identify individual log streams.
type colorPicker struct {
imageColors map[string]Color
}
// NewColorPicker creates a new ColorPicker.
func NewColorPicker() ColorPicker {
imageColors := make(map[string]Color)
return &colorPicker{
imageColors: imageColors,
}
}
// AddImage adds an image to the ColorPicker. Each image added will be paired with a color
// selected sequentially from `DefaultColorCodes`. If all colors are used, the first color
// will be used again. The formatter for the associated color will then be returned by `Pick`
// each time it is called for the artifact and can be used to write to out in that color.
func (p *colorPicker) AddImage(image string) {
imageName := tag.StripTag(image, false)
if _, ok := p.imageColors[imageName]; ok {
return
}
p.imageColors[imageName] = DefaultColorCodes[len(p.imageColors)%len(DefaultColorCodes)]
}
// Pick will return the color that was associated with the image when it was added to the
// ColorPicker. If no color was associated with the image, the none color will be returned,
// which will write with no formatting.
func (p *colorPicker) Pick(image string) Color {
if c, present := p.imageColors[tag.StripTag(image, false)]; present {
return c
}
// If no mapping is found, don't add any color formatting
return None
}