249 lines
6.8 KiB
Cheetah
249 lines
6.8 KiB
Cheetah
package query
|
|
|
|
import (
|
|
"context"
|
|
"encoding/binary"
|
|
"io"
|
|
|
|
internal "github.com/influxdata/influxdb/query/internal"
|
|
"google.golang.org/protobuf/proto"
|
|
)
|
|
|
|
{{range .}}
|
|
|
|
// {{.Name}}Point represents a point with a {{.Type}} value.
|
|
// DO NOT ADD ADDITIONAL FIELDS TO THIS STRUCT.
|
|
// See TestPoint_Fields in influxql/point_test.go for more details.
|
|
type {{.Name}}Point struct {
|
|
Name string
|
|
Tags Tags
|
|
|
|
Time int64
|
|
Value {{.Type}}
|
|
Aux []interface{}
|
|
|
|
// Total number of points that were combined into this point from an aggregate.
|
|
// If this is zero, the point is not the result of an aggregate function.
|
|
Aggregated uint32
|
|
Nil bool
|
|
}
|
|
|
|
func (v *{{.Name}}Point) name() string { return v.Name }
|
|
func (v *{{.Name}}Point) tags() Tags { return v.Tags }
|
|
func (v *{{.Name}}Point) time() int64 { return v.Time }
|
|
func (v *{{.Name}}Point) nil() bool { return v.Nil }
|
|
func (v *{{.Name}}Point) value() interface{} {
|
|
if v.Nil {
|
|
return nil
|
|
}
|
|
return v.Value
|
|
}
|
|
func (v *{{.Name}}Point) aux() []interface{} { return v.Aux }
|
|
|
|
// Clone returns a copy of v.
|
|
func (v *{{.Name}}Point) Clone() *{{.Name}}Point {
|
|
if v == nil {
|
|
return nil
|
|
}
|
|
|
|
other := *v
|
|
if v.Aux != nil {
|
|
other.Aux = make([]interface{}, len(v.Aux))
|
|
copy(other.Aux, v.Aux)
|
|
}
|
|
|
|
return &other
|
|
}
|
|
|
|
// CopyTo makes a deep copy into the point.
|
|
func (v *{{.Name}}Point) CopyTo(other *{{.Name}}Point) {
|
|
other.Name, other.Tags = v.Name, v.Tags
|
|
other.Time = v.Time
|
|
other.Value, other.Nil = v.Value, v.Nil
|
|
if v.Aux != nil {
|
|
if len(other.Aux) != len(v.Aux) {
|
|
other.Aux = make([]interface{}, len(v.Aux))
|
|
}
|
|
copy(other.Aux, v.Aux)
|
|
}
|
|
}
|
|
|
|
func encode{{.Name}}Point(p *{{.Name}}Point) *internal.Point {
|
|
return &internal.Point{
|
|
Name: proto.String(p.Name),
|
|
Tags: proto.String(p.Tags.ID()),
|
|
Time: proto.Int64(p.Time),
|
|
Nil: proto.Bool(p.Nil),
|
|
Aux: encodeAux(p.Aux),
|
|
Aggregated: proto.Uint32(p.Aggregated),
|
|
|
|
{{if eq .Name "Float"}}
|
|
FloatValue: proto.Float64(p.Value),
|
|
{{else if eq .Name "Integer"}}
|
|
IntegerValue: proto.Int64(p.Value),
|
|
{{else if eq .Name "String"}}
|
|
StringValue: proto.String(p.Value),
|
|
{{else if eq .Name "Boolean"}}
|
|
BooleanValue: proto.Bool(p.Value),
|
|
{{end}}
|
|
}
|
|
}
|
|
|
|
func decode{{.Name}}Point(pb *internal.Point) *{{.Name}}Point {
|
|
return &{{.Name}}Point{
|
|
Name: pb.GetName(),
|
|
Tags: newTagsID(pb.GetTags()),
|
|
Time: pb.GetTime(),
|
|
Nil: pb.GetNil(),
|
|
Aux: decodeAux(pb.Aux),
|
|
Aggregated: pb.GetAggregated(),
|
|
Value: pb.Get{{.Name}}Value(),
|
|
}
|
|
}
|
|
|
|
// {{.name}}Points represents a slice of points sortable by value.
|
|
type {{.name}}Points []{{.Name}}Point
|
|
|
|
func (a {{.name}}Points) Len() int { return len(a) }
|
|
func (a {{.name}}Points) Less(i, j int) bool {
|
|
if a[i].Time != a[j].Time {
|
|
return a[i].Time < a[j].Time
|
|
}
|
|
return {{if ne .Name "Boolean"}}a[i].Value < a[j].Value{{else}}!a[i].Value{{end}}
|
|
}
|
|
func (a {{.name}}Points) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
|
|
|
|
// {{.name}}PointsByValue represents a slice of points sortable by value.
|
|
type {{.name}}PointsByValue []{{.Name}}Point
|
|
|
|
func (a {{.name}}PointsByValue) Len() int { return len(a) }
|
|
{{if eq .Name "Boolean"}}
|
|
func (a {{.name}}PointsByValue) Less(i, j int) bool { return !a[i].Value }
|
|
{{else}}
|
|
func (a {{.name}}PointsByValue) Less(i, j int) bool { return a[i].Value < a[j].Value }
|
|
{{end}}
|
|
func (a {{.name}}PointsByValue) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
|
|
|
|
// {{.name}}PointsByTime represents a slice of points sortable by value.
|
|
type {{.name}}PointsByTime []{{.Name}}Point
|
|
|
|
func (a {{.name}}PointsByTime) Len() int { return len(a) }
|
|
func (a {{.name}}PointsByTime) Less(i, j int) bool { return a[i].Time < a[j].Time }
|
|
func (a {{.name}}PointsByTime) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
|
|
|
|
// {{.name}}PointByFunc represents a slice of points sortable by a function.
|
|
type {{.name}}PointsByFunc struct {
|
|
points []{{.Name}}Point
|
|
cmp func(a, b *{{.Name}}Point) bool
|
|
}
|
|
|
|
func (a *{{.name}}PointsByFunc) Len() int { return len(a.points) }
|
|
func (a *{{.name}}PointsByFunc) Less(i, j int) bool { return a.cmp(&a.points[i], &a.points[j]) }
|
|
func (a *{{.name}}PointsByFunc) Swap(i, j int) { a.points[i], a.points[j] = a.points[j], a.points[i] }
|
|
|
|
func (a *{{.name}}PointsByFunc) Push(x interface{}) {
|
|
a.points = append(a.points, x.({{.Name}}Point))
|
|
}
|
|
|
|
func (a *{{.name}}PointsByFunc) Pop() interface{} {
|
|
p := a.points[len(a.points)-1]
|
|
a.points = a.points[:len(a.points)-1]
|
|
return p
|
|
}
|
|
|
|
func {{.name}}PointsSortBy(points []{{.Name}}Point, cmp func(a, b *{{.Name}}Point) bool) *{{.name}}PointsByFunc {
|
|
return &{{.name}}PointsByFunc{
|
|
points: points,
|
|
cmp: cmp,
|
|
}
|
|
}
|
|
|
|
// {{.Name}}PointEncoder encodes {{.Name}}Point points to a writer.
|
|
type {{.Name}}PointEncoder struct {
|
|
w io.Writer
|
|
}
|
|
|
|
// New{{.Name}}PointEncoder returns a new instance of {{.Name}}PointEncoder that writes to w.
|
|
func New{{.Name}}PointEncoder(w io.Writer) *{{.Name}}PointEncoder {
|
|
return &{{.Name}}PointEncoder{w: w}
|
|
}
|
|
|
|
// Encode{{.Name}}Point marshals and writes p to the underlying writer.
|
|
func (enc *{{.Name}}PointEncoder) Encode{{.Name}}Point(p *{{.Name}}Point) error {
|
|
// Marshal to bytes.
|
|
buf, err := proto.Marshal(encode{{.Name}}Point(p))
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// Write the length.
|
|
if err := binary.Write(enc.w, binary.BigEndian, uint32(len(buf))); err != nil {
|
|
return err
|
|
}
|
|
|
|
// Write the encoded point.
|
|
if _, err := enc.w.Write(buf); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
|
|
// {{.Name}}PointDecoder decodes {{.Name}}Point points from a reader.
|
|
type {{.Name}}PointDecoder struct {
|
|
r io.Reader
|
|
stats IteratorStats
|
|
ctx context.Context
|
|
}
|
|
|
|
// New{{.Name}}PointDecoder returns a new instance of {{.Name}}PointDecoder that reads from r.
|
|
func New{{.Name}}PointDecoder(ctx context.Context, r io.Reader) *{{.Name}}PointDecoder {
|
|
return &{{.Name}}PointDecoder{r: r, ctx: ctx}
|
|
}
|
|
|
|
// Stats returns iterator stats embedded within the stream.
|
|
func (dec *{{.Name}}PointDecoder) Stats() IteratorStats { return dec.stats }
|
|
|
|
// Decode{{.Name}}Point reads from the underlying reader and unmarshals into p.
|
|
func (dec *{{.Name}}PointDecoder) Decode{{.Name}}Point(p *{{.Name}}Point) error {
|
|
for {
|
|
// Read length.
|
|
var sz uint32
|
|
if err := binary.Read(dec.r, binary.BigEndian, &sz); err != nil {
|
|
return err
|
|
}
|
|
|
|
// Read point data.
|
|
buf := make([]byte, sz)
|
|
if _, err := io.ReadFull(dec.r, buf); err != nil {
|
|
return err
|
|
}
|
|
|
|
// Unmarshal into point.
|
|
var pb internal.Point
|
|
if err := proto.Unmarshal(buf, &pb); err != nil {
|
|
return err
|
|
}
|
|
|
|
// If the point contains stats then read stats and retry.
|
|
if pb.Stats != nil {
|
|
dec.stats = decodeIteratorStats(pb.Stats)
|
|
continue
|
|
}
|
|
|
|
if len(pb.Trace) > 0 {
|
|
if err := decodeIteratorTrace(dec.ctx, pb.Trace); err != nil {
|
|
return err
|
|
}
|
|
continue
|
|
}
|
|
|
|
// Decode into point object.
|
|
*p = *decode{{.Name}}Point(&pb)
|
|
|
|
return nil
|
|
}
|
|
}
|
|
|
|
{{end}}
|