Like Prometheus, but for logs.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
loki/pkg/logql/vector/heap.go

65 lines
1.0 KiB

package vector
import (
"math"
"github.com/prometheus/prometheus/promql"
)
type HeapByMaxValue promql.Vector
func (s HeapByMaxValue) Len() int {
return len(s)
}
func (s HeapByMaxValue) Less(i, j int) bool {
if math.IsNaN(s[i].F) {
return true
}
return s[i].F < s[j].F
}
func (s HeapByMaxValue) Swap(i, j int) {
s[i], s[j] = s[j], s[i]
}
func (s *HeapByMaxValue) Push(x interface{}) {
*s = append(*s, *(x.(*promql.Sample)))
}
func (s *HeapByMaxValue) Pop() interface{} {
old := *s
n := len(old)
el := old[n-1]
*s = old[0 : n-1]
return el
}
type HeapByMinValue promql.Vector
func (s HeapByMinValue) Len() int {
return len(s)
}
func (s HeapByMinValue) Less(i, j int) bool {
if math.IsNaN(s[i].F) {
return true
}
return s[i].F > s[j].F
}
func (s HeapByMinValue) Swap(i, j int) {
s[i], s[j] = s[j], s[i]
}
func (s *HeapByMinValue) Push(x interface{}) {
*s = append(*s, *(x.(*promql.Sample)))
}
func (s *HeapByMinValue) Pop() interface{} {
old := *s
n := len(old)
el := old[n-1]
*s = old[0 : n-1]
return el
}