1
0
mirror of https://github.com/DataDog/go-profiler-notes.git synced 2025-07-12 23:50:13 +02:00
Files
go-profiler-notes/bench/csv.go
Felix Geisendörfer c7f8adc8cc update bench
2021-02-03 15:06:19 +01:00

70 lines
1.5 KiB
Go

package main
import (
"fmt"
"time"
)
type Record struct {
Blockprofilerate int
Bufsize int
Depth int
Duration time.Duration
Goroutines int
Ops int
Run int
Workload string
}
type Column struct {
Name string
MarshalValue func(*Record) (string, error)
}
var Columns = []Column{
{"workload", func(r *Record) (string, error) {
return fmt.Sprintf("%s", r.Workload), nil
}},
{"ops", func(r *Record) (string, error) {
return fmt.Sprintf("%d", r.Ops), nil
}},
{"goroutines", func(r *Record) (string, error) {
return fmt.Sprintf("%d", r.Goroutines), nil
}},
{"depth", func(r *Record) (string, error) {
return fmt.Sprintf("%d", r.Depth), nil
}},
{"bufsize", func(r *Record) (string, error) {
return fmt.Sprintf("%d", r.Bufsize), nil
}},
{"blockprofilerate", func(r *Record) (string, error) {
return fmt.Sprintf("%d", r.Blockprofilerate), nil
}},
{"run", func(r *Record) (string, error) {
return fmt.Sprintf("%d", r.Run), nil
}},
{"ms", func(r *Record) (string, error) {
return fmt.Sprintf("%f", r.Duration.Seconds()*1000), nil
}},
}
func (r *Record) MarshalRecord() ([]string, error) {
record := make([]string, len(Columns))
for i, col := range Columns {
val, err := col.MarshalValue(r)
if err != nil {
return nil, err
}
record[i] = val
}
return record, nil
}
func Headers() []string {
headers := make([]string, len(Columns))
for i, col := range Columns {
headers[i] = col.Name
}
return headers
}