// Generated by tmpl // https://github.com/benbjohnson/tmpl // // DO NOT EDIT! // Source: point.gen.go.tmpl package query import ( "context" "encoding/binary" "io" internal "github.com/influxdata/influxdb/query/internal" "google.golang.org/protobuf/proto" ) // FloatPoint represents a point with a float64 value. // DO NOT ADD ADDITIONAL FIELDS TO THIS STRUCT. // See TestPoint_Fields in influxql/point_test.go for more details. type FloatPoint struct { Name string Tags Tags Time int64 Value float64 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 *FloatPoint) name() string { return v.Name } func (v *FloatPoint) tags() Tags { return v.Tags } func (v *FloatPoint) time() int64 { return v.Time } func (v *FloatPoint) nil() bool { return v.Nil } func (v *FloatPoint) value() interface{} { if v.Nil { return nil } return v.Value } func (v *FloatPoint) aux() []interface{} { return v.Aux } // Clone returns a copy of v. func (v *FloatPoint) Clone() *FloatPoint { 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 *FloatPoint) CopyTo(other *FloatPoint) { 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 encodeFloatPoint(p *FloatPoint) *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), FloatValue: proto.Float64(p.Value), } } func decodeFloatPoint(pb *internal.Point) *FloatPoint { return &FloatPoint{ Name: pb.GetName(), Tags: newTagsID(pb.GetTags()), Time: pb.GetTime(), Nil: pb.GetNil(), Aux: decodeAux(pb.Aux), Aggregated: pb.GetAggregated(), Value: pb.GetFloatValue(), } } // floatPoints represents a slice of points sortable by value. type floatPoints []FloatPoint func (a floatPoints) Len() int { return len(a) } func (a floatPoints) Less(i, j int) bool { if a[i].Time != a[j].Time { return a[i].Time < a[j].Time } return a[i].Value < a[j].Value } func (a floatPoints) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // floatPointsByValue represents a slice of points sortable by value. type floatPointsByValue []FloatPoint func (a floatPointsByValue) Len() int { return len(a) } func (a floatPointsByValue) Less(i, j int) bool { return a[i].Value < a[j].Value } func (a floatPointsByValue) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // floatPointsByTime represents a slice of points sortable by value. type floatPointsByTime []FloatPoint func (a floatPointsByTime) Len() int { return len(a) } func (a floatPointsByTime) Less(i, j int) bool { return a[i].Time < a[j].Time } func (a floatPointsByTime) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // floatPointByFunc represents a slice of points sortable by a function. type floatPointsByFunc struct { points []FloatPoint cmp func(a, b *FloatPoint) bool } func (a *floatPointsByFunc) Len() int { return len(a.points) } func (a *floatPointsByFunc) Less(i, j int) bool { return a.cmp(&a.points[i], &a.points[j]) } func (a *floatPointsByFunc) Swap(i, j int) { a.points[i], a.points[j] = a.points[j], a.points[i] } func (a *floatPointsByFunc) Push(x interface{}) { a.points = append(a.points, x.(FloatPoint)) } func (a *floatPointsByFunc) Pop() interface{} { p := a.points[len(a.points)-1] a.points = a.points[:len(a.points)-1] return p } func floatPointsSortBy(points []FloatPoint, cmp func(a, b *FloatPoint) bool) *floatPointsByFunc { return &floatPointsByFunc{ points: points, cmp: cmp, } } // FloatPointEncoder encodes FloatPoint points to a writer. type FloatPointEncoder struct { w io.Writer } // NewFloatPointEncoder returns a new instance of FloatPointEncoder that writes to w. func NewFloatPointEncoder(w io.Writer) *FloatPointEncoder { return &FloatPointEncoder{w: w} } // EncodeFloatPoint marshals and writes p to the underlying writer. func (enc *FloatPointEncoder) EncodeFloatPoint(p *FloatPoint) error { // Marshal to bytes. buf, err := proto.Marshal(encodeFloatPoint(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 } // FloatPointDecoder decodes FloatPoint points from a reader. type FloatPointDecoder struct { r io.Reader stats IteratorStats ctx context.Context } // NewFloatPointDecoder returns a new instance of FloatPointDecoder that reads from r. func NewFloatPointDecoder(ctx context.Context, r io.Reader) *FloatPointDecoder { return &FloatPointDecoder{r: r, ctx: ctx} } // Stats returns iterator stats embedded within the stream. func (dec *FloatPointDecoder) Stats() IteratorStats { return dec.stats } // DecodeFloatPoint reads from the underlying reader and unmarshals into p. func (dec *FloatPointDecoder) DecodeFloatPoint(p *FloatPoint) 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 = *decodeFloatPoint(&pb) return nil } } // IntegerPoint represents a point with a int64 value. // DO NOT ADD ADDITIONAL FIELDS TO THIS STRUCT. // See TestPoint_Fields in influxql/point_test.go for more details. type IntegerPoint struct { Name string Tags Tags Time int64 Value int64 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 *IntegerPoint) name() string { return v.Name } func (v *IntegerPoint) tags() Tags { return v.Tags } func (v *IntegerPoint) time() int64 { return v.Time } func (v *IntegerPoint) nil() bool { return v.Nil } func (v *IntegerPoint) value() interface{} { if v.Nil { return nil } return v.Value } func (v *IntegerPoint) aux() []interface{} { return v.Aux } // Clone returns a copy of v. func (v *IntegerPoint) Clone() *IntegerPoint { 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 *IntegerPoint) CopyTo(other *IntegerPoint) { 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 encodeIntegerPoint(p *IntegerPoint) *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), IntegerValue: proto.Int64(p.Value), } } func decodeIntegerPoint(pb *internal.Point) *IntegerPoint { return &IntegerPoint{ Name: pb.GetName(), Tags: newTagsID(pb.GetTags()), Time: pb.GetTime(), Nil: pb.GetNil(), Aux: decodeAux(pb.Aux), Aggregated: pb.GetAggregated(), Value: pb.GetIntegerValue(), } } // integerPoints represents a slice of points sortable by value. type integerPoints []IntegerPoint func (a integerPoints) Len() int { return len(a) } func (a integerPoints) Less(i, j int) bool { if a[i].Time != a[j].Time { return a[i].Time < a[j].Time } return a[i].Value < a[j].Value } func (a integerPoints) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // integerPointsByValue represents a slice of points sortable by value. type integerPointsByValue []IntegerPoint func (a integerPointsByValue) Len() int { return len(a) } func (a integerPointsByValue) Less(i, j int) bool { return a[i].Value < a[j].Value } func (a integerPointsByValue) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // integerPointsByTime represents a slice of points sortable by value. type integerPointsByTime []IntegerPoint func (a integerPointsByTime) Len() int { return len(a) } func (a integerPointsByTime) Less(i, j int) bool { return a[i].Time < a[j].Time } func (a integerPointsByTime) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // integerPointByFunc represents a slice of points sortable by a function. type integerPointsByFunc struct { points []IntegerPoint cmp func(a, b *IntegerPoint) bool } func (a *integerPointsByFunc) Len() int { return len(a.points) } func (a *integerPointsByFunc) Less(i, j int) bool { return a.cmp(&a.points[i], &a.points[j]) } func (a *integerPointsByFunc) Swap(i, j int) { a.points[i], a.points[j] = a.points[j], a.points[i] } func (a *integerPointsByFunc) Push(x interface{}) { a.points = append(a.points, x.(IntegerPoint)) } func (a *integerPointsByFunc) Pop() interface{} { p := a.points[len(a.points)-1] a.points = a.points[:len(a.points)-1] return p } func integerPointsSortBy(points []IntegerPoint, cmp func(a, b *IntegerPoint) bool) *integerPointsByFunc { return &integerPointsByFunc{ points: points, cmp: cmp, } } // IntegerPointEncoder encodes IntegerPoint points to a writer. type IntegerPointEncoder struct { w io.Writer } // NewIntegerPointEncoder returns a new instance of IntegerPointEncoder that writes to w. func NewIntegerPointEncoder(w io.Writer) *IntegerPointEncoder { return &IntegerPointEncoder{w: w} } // EncodeIntegerPoint marshals and writes p to the underlying writer. func (enc *IntegerPointEncoder) EncodeIntegerPoint(p *IntegerPoint) error { // Marshal to bytes. buf, err := proto.Marshal(encodeIntegerPoint(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 } // IntegerPointDecoder decodes IntegerPoint points from a reader. type IntegerPointDecoder struct { r io.Reader stats IteratorStats ctx context.Context } // NewIntegerPointDecoder returns a new instance of IntegerPointDecoder that reads from r. func NewIntegerPointDecoder(ctx context.Context, r io.Reader) *IntegerPointDecoder { return &IntegerPointDecoder{r: r, ctx: ctx} } // Stats returns iterator stats embedded within the stream. func (dec *IntegerPointDecoder) Stats() IteratorStats { return dec.stats } // DecodeIntegerPoint reads from the underlying reader and unmarshals into p. func (dec *IntegerPointDecoder) DecodeIntegerPoint(p *IntegerPoint) 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 = *decodeIntegerPoint(&pb) return nil } } // UnsignedPoint represents a point with a uint64 value. // DO NOT ADD ADDITIONAL FIELDS TO THIS STRUCT. // See TestPoint_Fields in influxql/point_test.go for more details. type UnsignedPoint struct { Name string Tags Tags Time int64 Value uint64 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 *UnsignedPoint) name() string { return v.Name } func (v *UnsignedPoint) tags() Tags { return v.Tags } func (v *UnsignedPoint) time() int64 { return v.Time } func (v *UnsignedPoint) nil() bool { return v.Nil } func (v *UnsignedPoint) value() interface{} { if v.Nil { return nil } return v.Value } func (v *UnsignedPoint) aux() []interface{} { return v.Aux } // Clone returns a copy of v. func (v *UnsignedPoint) Clone() *UnsignedPoint { 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 *UnsignedPoint) CopyTo(other *UnsignedPoint) { 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 encodeUnsignedPoint(p *UnsignedPoint) *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), } } func decodeUnsignedPoint(pb *internal.Point) *UnsignedPoint { return &UnsignedPoint{ Name: pb.GetName(), Tags: newTagsID(pb.GetTags()), Time: pb.GetTime(), Nil: pb.GetNil(), Aux: decodeAux(pb.Aux), Aggregated: pb.GetAggregated(), Value: pb.GetUnsignedValue(), } } // unsignedPoints represents a slice of points sortable by value. type unsignedPoints []UnsignedPoint func (a unsignedPoints) Len() int { return len(a) } func (a unsignedPoints) Less(i, j int) bool { if a[i].Time != a[j].Time { return a[i].Time < a[j].Time } return a[i].Value < a[j].Value } func (a unsignedPoints) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // unsignedPointsByValue represents a slice of points sortable by value. type unsignedPointsByValue []UnsignedPoint func (a unsignedPointsByValue) Len() int { return len(a) } func (a unsignedPointsByValue) Less(i, j int) bool { return a[i].Value < a[j].Value } func (a unsignedPointsByValue) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // unsignedPointsByTime represents a slice of points sortable by value. type unsignedPointsByTime []UnsignedPoint func (a unsignedPointsByTime) Len() int { return len(a) } func (a unsignedPointsByTime) Less(i, j int) bool { return a[i].Time < a[j].Time } func (a unsignedPointsByTime) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // unsignedPointByFunc represents a slice of points sortable by a function. type unsignedPointsByFunc struct { points []UnsignedPoint cmp func(a, b *UnsignedPoint) bool } func (a *unsignedPointsByFunc) Len() int { return len(a.points) } func (a *unsignedPointsByFunc) Less(i, j int) bool { return a.cmp(&a.points[i], &a.points[j]) } func (a *unsignedPointsByFunc) Swap(i, j int) { a.points[i], a.points[j] = a.points[j], a.points[i] } func (a *unsignedPointsByFunc) Push(x interface{}) { a.points = append(a.points, x.(UnsignedPoint)) } func (a *unsignedPointsByFunc) Pop() interface{} { p := a.points[len(a.points)-1] a.points = a.points[:len(a.points)-1] return p } func unsignedPointsSortBy(points []UnsignedPoint, cmp func(a, b *UnsignedPoint) bool) *unsignedPointsByFunc { return &unsignedPointsByFunc{ points: points, cmp: cmp, } } // UnsignedPointEncoder encodes UnsignedPoint points to a writer. type UnsignedPointEncoder struct { w io.Writer } // NewUnsignedPointEncoder returns a new instance of UnsignedPointEncoder that writes to w. func NewUnsignedPointEncoder(w io.Writer) *UnsignedPointEncoder { return &UnsignedPointEncoder{w: w} } // EncodeUnsignedPoint marshals and writes p to the underlying writer. func (enc *UnsignedPointEncoder) EncodeUnsignedPoint(p *UnsignedPoint) error { // Marshal to bytes. buf, err := proto.Marshal(encodeUnsignedPoint(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 } // UnsignedPointDecoder decodes UnsignedPoint points from a reader. type UnsignedPointDecoder struct { r io.Reader stats IteratorStats ctx context.Context } // NewUnsignedPointDecoder returns a new instance of UnsignedPointDecoder that reads from r. func NewUnsignedPointDecoder(ctx context.Context, r io.Reader) *UnsignedPointDecoder { return &UnsignedPointDecoder{r: r, ctx: ctx} } // Stats returns iterator stats embedded within the stream. func (dec *UnsignedPointDecoder) Stats() IteratorStats { return dec.stats } // DecodeUnsignedPoint reads from the underlying reader and unmarshals into p. func (dec *UnsignedPointDecoder) DecodeUnsignedPoint(p *UnsignedPoint) 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 = *decodeUnsignedPoint(&pb) return nil } } // StringPoint represents a point with a string value. // DO NOT ADD ADDITIONAL FIELDS TO THIS STRUCT. // See TestPoint_Fields in influxql/point_test.go for more details. type StringPoint struct { Name string Tags Tags Time int64 Value string 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 *StringPoint) name() string { return v.Name } func (v *StringPoint) tags() Tags { return v.Tags } func (v *StringPoint) time() int64 { return v.Time } func (v *StringPoint) nil() bool { return v.Nil } func (v *StringPoint) value() interface{} { if v.Nil { return nil } return v.Value } func (v *StringPoint) aux() []interface{} { return v.Aux } // Clone returns a copy of v. func (v *StringPoint) Clone() *StringPoint { 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 *StringPoint) CopyTo(other *StringPoint) { 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 encodeStringPoint(p *StringPoint) *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), StringValue: proto.String(p.Value), } } func decodeStringPoint(pb *internal.Point) *StringPoint { return &StringPoint{ Name: pb.GetName(), Tags: newTagsID(pb.GetTags()), Time: pb.GetTime(), Nil: pb.GetNil(), Aux: decodeAux(pb.Aux), Aggregated: pb.GetAggregated(), Value: pb.GetStringValue(), } } // stringPoints represents a slice of points sortable by value. type stringPoints []StringPoint func (a stringPoints) Len() int { return len(a) } func (a stringPoints) Less(i, j int) bool { if a[i].Time != a[j].Time { return a[i].Time < a[j].Time } return a[i].Value < a[j].Value } func (a stringPoints) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // stringPointsByValue represents a slice of points sortable by value. type stringPointsByValue []StringPoint func (a stringPointsByValue) Len() int { return len(a) } func (a stringPointsByValue) Less(i, j int) bool { return a[i].Value < a[j].Value } func (a stringPointsByValue) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // stringPointsByTime represents a slice of points sortable by value. type stringPointsByTime []StringPoint func (a stringPointsByTime) Len() int { return len(a) } func (a stringPointsByTime) Less(i, j int) bool { return a[i].Time < a[j].Time } func (a stringPointsByTime) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // stringPointByFunc represents a slice of points sortable by a function. type stringPointsByFunc struct { points []StringPoint cmp func(a, b *StringPoint) bool } func (a *stringPointsByFunc) Len() int { return len(a.points) } func (a *stringPointsByFunc) Less(i, j int) bool { return a.cmp(&a.points[i], &a.points[j]) } func (a *stringPointsByFunc) Swap(i, j int) { a.points[i], a.points[j] = a.points[j], a.points[i] } func (a *stringPointsByFunc) Push(x interface{}) { a.points = append(a.points, x.(StringPoint)) } func (a *stringPointsByFunc) Pop() interface{} { p := a.points[len(a.points)-1] a.points = a.points[:len(a.points)-1] return p } func stringPointsSortBy(points []StringPoint, cmp func(a, b *StringPoint) bool) *stringPointsByFunc { return &stringPointsByFunc{ points: points, cmp: cmp, } } // StringPointEncoder encodes StringPoint points to a writer. type StringPointEncoder struct { w io.Writer } // NewStringPointEncoder returns a new instance of StringPointEncoder that writes to w. func NewStringPointEncoder(w io.Writer) *StringPointEncoder { return &StringPointEncoder{w: w} } // EncodeStringPoint marshals and writes p to the underlying writer. func (enc *StringPointEncoder) EncodeStringPoint(p *StringPoint) error { // Marshal to bytes. buf, err := proto.Marshal(encodeStringPoint(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 } // StringPointDecoder decodes StringPoint points from a reader. type StringPointDecoder struct { r io.Reader stats IteratorStats ctx context.Context } // NewStringPointDecoder returns a new instance of StringPointDecoder that reads from r. func NewStringPointDecoder(ctx context.Context, r io.Reader) *StringPointDecoder { return &StringPointDecoder{r: r, ctx: ctx} } // Stats returns iterator stats embedded within the stream. func (dec *StringPointDecoder) Stats() IteratorStats { return dec.stats } // DecodeStringPoint reads from the underlying reader and unmarshals into p. func (dec *StringPointDecoder) DecodeStringPoint(p *StringPoint) 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 = *decodeStringPoint(&pb) return nil } } // BooleanPoint represents a point with a bool value. // DO NOT ADD ADDITIONAL FIELDS TO THIS STRUCT. // See TestPoint_Fields in influxql/point_test.go for more details. type BooleanPoint struct { Name string Tags Tags Time int64 Value bool 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 *BooleanPoint) name() string { return v.Name } func (v *BooleanPoint) tags() Tags { return v.Tags } func (v *BooleanPoint) time() int64 { return v.Time } func (v *BooleanPoint) nil() bool { return v.Nil } func (v *BooleanPoint) value() interface{} { if v.Nil { return nil } return v.Value } func (v *BooleanPoint) aux() []interface{} { return v.Aux } // Clone returns a copy of v. func (v *BooleanPoint) Clone() *BooleanPoint { 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 *BooleanPoint) CopyTo(other *BooleanPoint) { 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 encodeBooleanPoint(p *BooleanPoint) *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), BooleanValue: proto.Bool(p.Value), } } func decodeBooleanPoint(pb *internal.Point) *BooleanPoint { return &BooleanPoint{ Name: pb.GetName(), Tags: newTagsID(pb.GetTags()), Time: pb.GetTime(), Nil: pb.GetNil(), Aux: decodeAux(pb.Aux), Aggregated: pb.GetAggregated(), Value: pb.GetBooleanValue(), } } // booleanPoints represents a slice of points sortable by value. type booleanPoints []BooleanPoint func (a booleanPoints) Len() int { return len(a) } func (a booleanPoints) Less(i, j int) bool { if a[i].Time != a[j].Time { return a[i].Time < a[j].Time } return !a[i].Value } func (a booleanPoints) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // booleanPointsByValue represents a slice of points sortable by value. type booleanPointsByValue []BooleanPoint func (a booleanPointsByValue) Len() int { return len(a) } func (a booleanPointsByValue) Less(i, j int) bool { return !a[i].Value } func (a booleanPointsByValue) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // booleanPointsByTime represents a slice of points sortable by value. type booleanPointsByTime []BooleanPoint func (a booleanPointsByTime) Len() int { return len(a) } func (a booleanPointsByTime) Less(i, j int) bool { return a[i].Time < a[j].Time } func (a booleanPointsByTime) Swap(i, j int) { a[i], a[j] = a[j], a[i] } // booleanPointByFunc represents a slice of points sortable by a function. type booleanPointsByFunc struct { points []BooleanPoint cmp func(a, b *BooleanPoint) bool } func (a *booleanPointsByFunc) Len() int { return len(a.points) } func (a *booleanPointsByFunc) Less(i, j int) bool { return a.cmp(&a.points[i], &a.points[j]) } func (a *booleanPointsByFunc) Swap(i, j int) { a.points[i], a.points[j] = a.points[j], a.points[i] } func (a *booleanPointsByFunc) Push(x interface{}) { a.points = append(a.points, x.(BooleanPoint)) } func (a *booleanPointsByFunc) Pop() interface{} { p := a.points[len(a.points)-1] a.points = a.points[:len(a.points)-1] return p } func booleanPointsSortBy(points []BooleanPoint, cmp func(a, b *BooleanPoint) bool) *booleanPointsByFunc { return &booleanPointsByFunc{ points: points, cmp: cmp, } } // BooleanPointEncoder encodes BooleanPoint points to a writer. type BooleanPointEncoder struct { w io.Writer } // NewBooleanPointEncoder returns a new instance of BooleanPointEncoder that writes to w. func NewBooleanPointEncoder(w io.Writer) *BooleanPointEncoder { return &BooleanPointEncoder{w: w} } // EncodeBooleanPoint marshals and writes p to the underlying writer. func (enc *BooleanPointEncoder) EncodeBooleanPoint(p *BooleanPoint) error { // Marshal to bytes. buf, err := proto.Marshal(encodeBooleanPoint(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 } // BooleanPointDecoder decodes BooleanPoint points from a reader. type BooleanPointDecoder struct { r io.Reader stats IteratorStats ctx context.Context } // NewBooleanPointDecoder returns a new instance of BooleanPointDecoder that reads from r. func NewBooleanPointDecoder(ctx context.Context, r io.Reader) *BooleanPointDecoder { return &BooleanPointDecoder{r: r, ctx: ctx} } // Stats returns iterator stats embedded within the stream. func (dec *BooleanPointDecoder) Stats() IteratorStats { return dec.stats } // DecodeBooleanPoint reads from the underlying reader and unmarshals into p. func (dec *BooleanPointDecoder) DecodeBooleanPoint(p *BooleanPoint) 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 = *decodeBooleanPoint(&pb) return nil } }