mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-12 06:17:27 -08:00
labels: use ScratchBuilder in ReadLabels
Instead of relying on being able to append to it like a slice. Signed-off-by: Bryan Boreham <bjboreham@gmail.com>
This commit is contained in:
parent
2b8b8d9ac7
commit
617bee60f1
|
@ -17,7 +17,6 @@ import (
|
||||||
"bufio"
|
"bufio"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"sort"
|
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -51,13 +50,14 @@ func ReadLabels(fn string, n int) ([]Labels, error) {
|
||||||
defer f.Close()
|
defer f.Close()
|
||||||
|
|
||||||
scanner := bufio.NewScanner(f)
|
scanner := bufio.NewScanner(f)
|
||||||
|
b := ScratchBuilder{}
|
||||||
|
|
||||||
var mets []Labels
|
var mets []Labels
|
||||||
hashes := map[uint64]struct{}{}
|
hashes := map[uint64]struct{}{}
|
||||||
i := 0
|
i := 0
|
||||||
|
|
||||||
for scanner.Scan() && i < n {
|
for scanner.Scan() && i < n {
|
||||||
m := make(Labels, 0, 10)
|
b.Reset()
|
||||||
|
|
||||||
r := strings.NewReplacer("\"", "", "{", "", "}", "")
|
r := strings.NewReplacer("\"", "", "{", "", "}", "")
|
||||||
s := r.Replace(scanner.Text())
|
s := r.Replace(scanner.Text())
|
||||||
|
@ -65,10 +65,11 @@ func ReadLabels(fn string, n int) ([]Labels, error) {
|
||||||
labelChunks := strings.Split(s, ",")
|
labelChunks := strings.Split(s, ",")
|
||||||
for _, labelChunk := range labelChunks {
|
for _, labelChunk := range labelChunks {
|
||||||
split := strings.Split(labelChunk, ":")
|
split := strings.Split(labelChunk, ":")
|
||||||
m = append(m, Label{Name: split[0], Value: split[1]})
|
b.Add(split[0], split[1])
|
||||||
}
|
}
|
||||||
// Order of the k/v labels matters, don't assume we'll always receive them already sorted.
|
// Order of the k/v labels matters, don't assume we'll always receive them already sorted.
|
||||||
sort.Sort(m)
|
b.Sort()
|
||||||
|
m := b.Labels()
|
||||||
|
|
||||||
h := m.Hash()
|
h := m.Hash()
|
||||||
if _, ok := hashes[h]; ok {
|
if _, ok := hashes[h]; ok {
|
||||||
|
|
Loading…
Reference in a new issue