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:
Bryan Boreham 2022-06-26 20:11:53 +01:00
parent 2b8b8d9ac7
commit 617bee60f1

View file

@ -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 {