Merge pull request #5623 from influxdata/jw-query-panic
Fix panic: runtime error: index out of rangepull/5170/head
commit
0b3d367e5c
|
@ -1,5 +1,8 @@
|
||||||
// Generated by tmpl
|
// Generated by tmpl
|
||||||
// https://github.com/benbjohnson/tmpl
|
// https://github.com/benbjohnson/tmpl
|
||||||
|
//
|
||||||
|
// DO NOT EDIT!
|
||||||
|
// Source: iterator.gen.go.tmpl
|
||||||
|
|
||||||
package tsm1
|
package tsm1
|
||||||
|
|
||||||
|
@ -240,7 +243,6 @@ func (c *floatAscendingCursor) peekCache() (t int64, v float64) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *floatAscendingCursor) peekTSM() (t int64, v float64) {
|
func (c *floatAscendingCursor) peekTSM() (t int64, v float64) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, math.NaN()
|
return tsdb.EOF, math.NaN()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,7 +296,6 @@ func (c *floatAscendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadFloatBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadFloatBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -352,7 +353,6 @@ func (c *floatDescendingCursor) peekCache() (t int64, v float64) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *floatDescendingCursor) peekTSM() (t int64, v float64) {
|
func (c *floatDescendingCursor) peekTSM() (t int64, v float64) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, math.NaN()
|
return tsdb.EOF, math.NaN()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -406,7 +406,6 @@ func (c *floatDescendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadFloatBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadFloatBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -576,7 +575,6 @@ func (c *integerAscendingCursor) peekCache() (t int64, v int64) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *integerAscendingCursor) peekTSM() (t int64, v int64) {
|
func (c *integerAscendingCursor) peekTSM() (t int64, v int64) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, 0
|
return tsdb.EOF, 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -630,7 +628,6 @@ func (c *integerAscendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadIntegerBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadIntegerBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -688,7 +685,6 @@ func (c *integerDescendingCursor) peekCache() (t int64, v int64) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *integerDescendingCursor) peekTSM() (t int64, v int64) {
|
func (c *integerDescendingCursor) peekTSM() (t int64, v int64) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, 0
|
return tsdb.EOF, 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -742,7 +738,6 @@ func (c *integerDescendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadIntegerBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadIntegerBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -912,7 +907,6 @@ func (c *stringAscendingCursor) peekCache() (t int64, v string) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *stringAscendingCursor) peekTSM() (t int64, v string) {
|
func (c *stringAscendingCursor) peekTSM() (t int64, v string) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, ""
|
return tsdb.EOF, ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -966,7 +960,6 @@ func (c *stringAscendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadStringBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadStringBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -1024,7 +1017,6 @@ func (c *stringDescendingCursor) peekCache() (t int64, v string) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *stringDescendingCursor) peekTSM() (t int64, v string) {
|
func (c *stringDescendingCursor) peekTSM() (t int64, v string) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, ""
|
return tsdb.EOF, ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1078,7 +1070,6 @@ func (c *stringDescendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadStringBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadStringBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -1248,7 +1239,6 @@ func (c *booleanAscendingCursor) peekCache() (t int64, v bool) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *booleanAscendingCursor) peekTSM() (t int64, v bool) {
|
func (c *booleanAscendingCursor) peekTSM() (t int64, v bool) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, false
|
return tsdb.EOF, false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1302,7 +1292,6 @@ func (c *booleanAscendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadBooleanBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadBooleanBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -1360,7 +1349,6 @@ func (c *booleanDescendingCursor) peekCache() (t int64, v bool) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *booleanDescendingCursor) peekTSM() (t int64, v bool) {
|
func (c *booleanDescendingCursor) peekTSM() (t int64, v bool) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, false
|
return tsdb.EOF, false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1414,7 +1402,6 @@ func (c *booleanDescendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.ReadBooleanBlock(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.ReadBooleanBlock(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
|
|
@ -4,7 +4,7 @@ import (
|
||||||
"sort"
|
"sort"
|
||||||
"fmt"
|
"fmt"
|
||||||
"math"
|
"math"
|
||||||
|
|
||||||
"github.com/influxdata/influxdb/influxql"
|
"github.com/influxdata/influxdb/influxql"
|
||||||
"github.com/influxdata/influxdb/tsdb"
|
"github.com/influxdata/influxdb/tsdb"
|
||||||
)
|
)
|
||||||
|
@ -72,7 +72,7 @@ func (c *bufCursor) nextAt(seek int64) interface{} {
|
||||||
} else if k < seek {
|
} else if k < seek {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
c.unread(k, v)
|
c.unread(k, v)
|
||||||
|
|
||||||
// Return "nil" value for type.
|
// Return "nil" value for type.
|
||||||
|
@ -239,7 +239,6 @@ func (c *{{.name}}AscendingCursor) peekCache() (t int64, v {{.Type}}) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *{{.name}}AscendingCursor) peekTSM() (t int64, v {{.Type}}) {
|
func (c *{{.name}}AscendingCursor) peekTSM() (t int64, v {{.Type}}) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, {{.Nil}}
|
return tsdb.EOF, {{.Nil}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -293,7 +292,6 @@ func (c *{{.name}}AscendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.Read{{.Name}}Block(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.Read{{.Name}}Block(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
@ -351,7 +349,6 @@ func (c *{{.name}}DescendingCursor) peekCache() (t int64, v {{.Type}}) {
|
||||||
// peekTSM returns the current time/value from tsm.
|
// peekTSM returns the current time/value from tsm.
|
||||||
func (c *{{.name}}DescendingCursor) peekTSM() (t int64, v {{.Type}}) {
|
func (c *{{.name}}DescendingCursor) peekTSM() (t int64, v {{.Type}}) {
|
||||||
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
if c.tsm.pos < 0 || c.tsm.pos >= len(c.tsm.values) {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return tsdb.EOF, {{.Nil}}
|
return tsdb.EOF, {{.Nil}}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -405,7 +402,6 @@ func (c *{{.name}}DescendingCursor) nextTSM() {
|
||||||
c.tsm.keyCursor.Next()
|
c.tsm.keyCursor.Next()
|
||||||
c.tsm.values, _ = c.tsm.keyCursor.Read{{.Name}}Block(c.tsm.buf)
|
c.tsm.values, _ = c.tsm.keyCursor.Read{{.Name}}Block(c.tsm.buf)
|
||||||
if len(c.tsm.values) == 0 {
|
if len(c.tsm.values) == 0 {
|
||||||
c.tsm.keyCursor.Close()
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
c.tsm.pos = 0
|
c.tsm.pos = 0
|
||||||
|
|
Loading…
Reference in New Issue