mirror of
https://github.com/kubernetes-sigs/prometheus-adapter.git
synced 2026-04-06 17:57:51 +00:00
Travis seems to be having issues pulling deps, so we'll have to check in the vendor directory and prevent the makefile from trying to regenerate it normally.
81 lines
1.9 KiB
Go
81 lines
1.9 KiB
Go
// Copyright 2012 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package build
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"reflect"
|
|
|
|
"golang.org/x/text/internal/colltab"
|
|
)
|
|
|
|
// table is an intermediate structure that roughly resembles the table in collate.
|
|
type table struct {
|
|
colltab.Table
|
|
trie trie
|
|
root *trieHandle
|
|
}
|
|
|
|
// print writes the table as Go compilable code to w. It prefixes the
|
|
// variable names with name. It returns the number of bytes written
|
|
// and the size of the resulting table.
|
|
func (t *table) fprint(w io.Writer, name string) (n, size int, err error) {
|
|
update := func(nn, sz int, e error) {
|
|
n += nn
|
|
if err == nil {
|
|
err = e
|
|
}
|
|
size += sz
|
|
}
|
|
// Write arrays needed for the structure.
|
|
update(printColElems(w, t.ExpandElem, name+"ExpandElem"))
|
|
update(printColElems(w, t.ContractElem, name+"ContractElem"))
|
|
update(t.trie.printArrays(w, name))
|
|
update(printArray(t.ContractTries, w, name))
|
|
|
|
nn, e := fmt.Fprintf(w, "// Total size of %sTable is %d bytes\n", name, size)
|
|
update(nn, 0, e)
|
|
return
|
|
}
|
|
|
|
func (t *table) fprintIndex(w io.Writer, h *trieHandle, id string) (n int, err error) {
|
|
p := func(f string, a ...interface{}) {
|
|
nn, e := fmt.Fprintf(w, f, a...)
|
|
n += nn
|
|
if err == nil {
|
|
err = e
|
|
}
|
|
}
|
|
p("\t{ // %s\n", id)
|
|
p("\t\tlookupOffset: 0x%x,\n", h.lookupStart)
|
|
p("\t\tvaluesOffset: 0x%x,\n", h.valueStart)
|
|
p("\t},\n")
|
|
return
|
|
}
|
|
|
|
func printColElems(w io.Writer, a []uint32, name string) (n, sz int, err error) {
|
|
p := func(f string, a ...interface{}) {
|
|
nn, e := fmt.Fprintf(w, f, a...)
|
|
n += nn
|
|
if err == nil {
|
|
err = e
|
|
}
|
|
}
|
|
sz = len(a) * int(reflect.TypeOf(uint32(0)).Size())
|
|
p("// %s: %d entries, %d bytes\n", name, len(a), sz)
|
|
p("var %s = [%d]uint32 {", name, len(a))
|
|
for i, c := range a {
|
|
switch {
|
|
case i%64 == 0:
|
|
p("\n\t// Block %d, offset 0x%x\n", i/64, i)
|
|
case (i%64)%6 == 0:
|
|
p("\n\t")
|
|
}
|
|
p("0x%.8X, ", c)
|
|
}
|
|
p("\n}\n\n")
|
|
return
|
|
}
|