mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 15:16:42 +00:00
wip
This commit is contained in:
parent
a2878feb1e
commit
84631d8c04
4 changed files with 69 additions and 69 deletions
|
@ -1,12 +1,9 @@
|
||||||
package logstorage
|
package logstorage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"math"
|
|
||||||
"strconv"
|
|
||||||
"sync"
|
"sync"
|
||||||
|
|
||||||
"github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil"
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil"
|
||||||
"github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding"
|
|
||||||
"github.com/VictoriaMetrics/VictoriaMetrics/lib/logger"
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/logger"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -66,72 +63,6 @@ func (fs *streamFilter) apply(bs *blockSearch, bm *bitmap) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func toUint64Range(minValue, maxValue float64) (uint64, uint64) {
|
|
||||||
minValue = math.Ceil(minValue)
|
|
||||||
maxValue = math.Floor(maxValue)
|
|
||||||
return toUint64Clamp(minValue), toUint64Clamp(maxValue)
|
|
||||||
}
|
|
||||||
|
|
||||||
func toUint64Clamp(f float64) uint64 {
|
|
||||||
if f < 0 {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
if f > math.MaxUint64 {
|
|
||||||
return math.MaxUint64
|
|
||||||
}
|
|
||||||
return uint64(f)
|
|
||||||
}
|
|
||||||
|
|
||||||
func quoteFieldNameIfNeeded(s string) string {
|
|
||||||
if isMsgFieldName(s) {
|
|
||||||
return ""
|
|
||||||
}
|
|
||||||
return quoteTokenIfNeeded(s) + ":"
|
|
||||||
}
|
|
||||||
|
|
||||||
func isMsgFieldName(fieldName string) bool {
|
|
||||||
return fieldName == "" || fieldName == "_msg"
|
|
||||||
}
|
|
||||||
|
|
||||||
func toUint8String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
|
||||||
if len(v) != 1 {
|
|
||||||
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint8 number: got %d; want 1", bs.partPath(), len(v))
|
|
||||||
}
|
|
||||||
n := uint64(v[0])
|
|
||||||
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
|
||||||
return bytesutil.ToUnsafeString(bb.B)
|
|
||||||
}
|
|
||||||
|
|
||||||
func toUint16String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
|
||||||
if len(v) != 2 {
|
|
||||||
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint16 number: got %d; want 2", bs.partPath(), len(v))
|
|
||||||
}
|
|
||||||
b := bytesutil.ToUnsafeBytes(v)
|
|
||||||
n := uint64(encoding.UnmarshalUint16(b))
|
|
||||||
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
|
||||||
return bytesutil.ToUnsafeString(bb.B)
|
|
||||||
}
|
|
||||||
|
|
||||||
func toUint32String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
|
||||||
if len(v) != 4 {
|
|
||||||
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint32 number: got %d; want 4", bs.partPath(), len(v))
|
|
||||||
}
|
|
||||||
b := bytesutil.ToUnsafeBytes(v)
|
|
||||||
n := uint64(encoding.UnmarshalUint32(b))
|
|
||||||
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
|
||||||
return bytesutil.ToUnsafeString(bb.B)
|
|
||||||
}
|
|
||||||
|
|
||||||
func toUint64String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
|
||||||
if len(v) != 8 {
|
|
||||||
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint64 number: got %d; want 8", bs.partPath(), len(v))
|
|
||||||
}
|
|
||||||
b := bytesutil.ToUnsafeBytes(v)
|
|
||||||
n := encoding.UnmarshalUint64(b)
|
|
||||||
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
|
||||||
return bytesutil.ToUnsafeString(bb.B)
|
|
||||||
}
|
|
||||||
|
|
||||||
func toFloat64StringExt(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
func toFloat64StringExt(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
||||||
if len(v) != 8 {
|
if len(v) != 8 {
|
||||||
logger.Panicf("FATAL: %s: unexpected length for binary representation of floating-point number: got %d; want 8", bs.partPath(), len(v))
|
logger.Panicf("FATAL: %s: unexpected length for binary representation of floating-point number: got %d; want 8", bs.partPath(), len(v))
|
||||||
|
|
|
@ -281,3 +281,14 @@ func matchBloomFilterAllTokens(bs *blockSearch, ch *columnHeader, tokens []strin
|
||||||
bf := bs.getBloomFilterForColumn(ch)
|
bf := bs.getBloomFilterForColumn(ch)
|
||||||
return bf.containsAll(tokens)
|
return bf.containsAll(tokens)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func quoteFieldNameIfNeeded(s string) string {
|
||||||
|
if isMsgFieldName(s) {
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
return quoteTokenIfNeeded(s) + ":"
|
||||||
|
}
|
||||||
|
|
||||||
|
func isMsgFieldName(fieldName string) bool {
|
||||||
|
return fieldName == "" || fieldName == "_msg"
|
||||||
|
}
|
||||||
|
|
|
@ -2,10 +2,13 @@ package logstorage
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
"unicode/utf8"
|
"unicode/utf8"
|
||||||
|
|
||||||
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/bytesutil"
|
||||||
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/encoding"
|
||||||
"github.com/VictoriaMetrics/VictoriaMetrics/lib/logger"
|
"github.com/VictoriaMetrics/VictoriaMetrics/lib/logger"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -314,3 +317,42 @@ func getTokensSkipLast(s string) []string {
|
||||||
}
|
}
|
||||||
return tokenizeStrings(nil, []string{s})
|
return tokenizeStrings(nil, []string{s})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func toUint8String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
||||||
|
if len(v) != 1 {
|
||||||
|
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint8 number: got %d; want 1", bs.partPath(), len(v))
|
||||||
|
}
|
||||||
|
n := uint64(v[0])
|
||||||
|
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
||||||
|
return bytesutil.ToUnsafeString(bb.B)
|
||||||
|
}
|
||||||
|
|
||||||
|
func toUint16String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
||||||
|
if len(v) != 2 {
|
||||||
|
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint16 number: got %d; want 2", bs.partPath(), len(v))
|
||||||
|
}
|
||||||
|
b := bytesutil.ToUnsafeBytes(v)
|
||||||
|
n := uint64(encoding.UnmarshalUint16(b))
|
||||||
|
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
||||||
|
return bytesutil.ToUnsafeString(bb.B)
|
||||||
|
}
|
||||||
|
|
||||||
|
func toUint32String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
||||||
|
if len(v) != 4 {
|
||||||
|
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint32 number: got %d; want 4", bs.partPath(), len(v))
|
||||||
|
}
|
||||||
|
b := bytesutil.ToUnsafeBytes(v)
|
||||||
|
n := uint64(encoding.UnmarshalUint32(b))
|
||||||
|
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
||||||
|
return bytesutil.ToUnsafeString(bb.B)
|
||||||
|
}
|
||||||
|
|
||||||
|
func toUint64String(bs *blockSearch, bb *bytesutil.ByteBuffer, v string) string {
|
||||||
|
if len(v) != 8 {
|
||||||
|
logger.Panicf("FATAL: %s: unexpected length for binary representation of uint64 number: got %d; want 8", bs.partPath(), len(v))
|
||||||
|
}
|
||||||
|
b := bytesutil.ToUnsafeBytes(v)
|
||||||
|
n := encoding.UnmarshalUint64(b)
|
||||||
|
bb.B = strconv.AppendUint(bb.B[:0], n, 10)
|
||||||
|
return bytesutil.ToUnsafeString(bb.B)
|
||||||
|
}
|
||||||
|
|
|
@ -185,3 +185,19 @@ func matchRange(s string, minValue, maxValue float64) bool {
|
||||||
}
|
}
|
||||||
return f >= minValue && f <= maxValue
|
return f >= minValue && f <= maxValue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func toUint64Range(minValue, maxValue float64) (uint64, uint64) {
|
||||||
|
minValue = math.Ceil(minValue)
|
||||||
|
maxValue = math.Floor(maxValue)
|
||||||
|
return toUint64Clamp(minValue), toUint64Clamp(maxValue)
|
||||||
|
}
|
||||||
|
|
||||||
|
func toUint64Clamp(f float64) uint64 {
|
||||||
|
if f < 0 {
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
if f > math.MaxUint64 {
|
||||||
|
return math.MaxUint64
|
||||||
|
}
|
||||||
|
return uint64(f)
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue