mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2024-12-31 15:06:26 +00:00
wip
This commit is contained in:
parent
5a883be63f
commit
790a9491b2
8 changed files with 8 additions and 13 deletions
|
@ -39,12 +39,17 @@ type lexer struct {
|
||||||
currentTimestamp int64
|
currentTimestamp int64
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// newLexer returns new lexer for the given s.
|
||||||
|
//
|
||||||
|
// The lex.token points to the first token in s.
|
||||||
func newLexer(s string) *lexer {
|
func newLexer(s string) *lexer {
|
||||||
return &lexer{
|
lex := &lexer{
|
||||||
s: s,
|
s: s,
|
||||||
sOrig: s,
|
sOrig: s,
|
||||||
currentTimestamp: time.Now().UnixNano(),
|
currentTimestamp: time.Now().UnixNano(),
|
||||||
}
|
}
|
||||||
|
lex.nextToken()
|
||||||
|
return lex
|
||||||
}
|
}
|
||||||
|
|
||||||
func (lex *lexer) isEnd() bool {
|
func (lex *lexer) isEnd() bool {
|
||||||
|
@ -240,7 +245,7 @@ func ParseQuery(s string) (*Query, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func parseFilter(lex *lexer) (filter, error) {
|
func parseFilter(lex *lexer) (filter, error) {
|
||||||
if !lex.mustNextToken() || lex.isKeyword("|") {
|
if lex.isKeyword("|", "") {
|
||||||
return nil, fmt.Errorf("missing query")
|
return nil, fmt.Errorf("missing query")
|
||||||
}
|
}
|
||||||
fo, err := parseFilterOr(lex, "")
|
fo, err := parseFilterOr(lex, "")
|
||||||
|
@ -1026,9 +1031,6 @@ func parseFilterStream(lex *lexer) (*filterStream, error) {
|
||||||
|
|
||||||
func newStreamFilter(s string) (*StreamFilter, error) {
|
func newStreamFilter(s string) (*StreamFilter, error) {
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
if !lex.mustNextToken() {
|
|
||||||
return nil, fmt.Errorf("missing '{' in _stream filter")
|
|
||||||
}
|
|
||||||
fs, err := parseFilterStream(lex)
|
fs, err := parseFilterStream(lex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
|
|
@ -12,12 +12,11 @@ func TestLexer(t *testing.T) {
|
||||||
t.Helper()
|
t.Helper()
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
for _, tokenExpected := range tokensExpected {
|
for _, tokenExpected := range tokensExpected {
|
||||||
lex.nextToken()
|
|
||||||
if lex.token != tokenExpected {
|
if lex.token != tokenExpected {
|
||||||
t.Fatalf("unexpected token; got %q; want %q", lex.token, tokenExpected)
|
t.Fatalf("unexpected token; got %q; want %q", lex.token, tokenExpected)
|
||||||
}
|
}
|
||||||
}
|
|
||||||
lex.nextToken()
|
lex.nextToken()
|
||||||
|
}
|
||||||
if lex.token != "" {
|
if lex.token != "" {
|
||||||
t.Fatalf("unexpected tail token: %q", lex.token)
|
t.Fatalf("unexpected tail token: %q", lex.token)
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,6 @@ func TestPipeCopyUpdateNeededFields(t *testing.T) {
|
||||||
unfs := newTestFieldsSet(unneededFields)
|
unfs := newTestFieldsSet(unneededFields)
|
||||||
|
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
lex.nextToken()
|
|
||||||
p, err := parsePipeCopy(lex)
|
p, err := parsePipeCopy(lex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("cannot parse %s: %s", s, err)
|
t.Fatalf("cannot parse %s: %s", s, err)
|
||||||
|
|
|
@ -12,7 +12,6 @@ func TestPipeDeleteUpdateNeededFields(t *testing.T) {
|
||||||
unfs := newTestFieldsSet(unneededFields)
|
unfs := newTestFieldsSet(unneededFields)
|
||||||
|
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
lex.nextToken()
|
|
||||||
p, err := parsePipeDelete(lex)
|
p, err := parsePipeDelete(lex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("cannot parse %s: %s", s, err)
|
t.Fatalf("cannot parse %s: %s", s, err)
|
||||||
|
|
|
@ -12,7 +12,6 @@ func TestPipeFieldsUpdateNeededFields(t *testing.T) {
|
||||||
unfs := newTestFieldsSet(unneededFields)
|
unfs := newTestFieldsSet(unneededFields)
|
||||||
|
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
lex.nextToken()
|
|
||||||
p, err := parsePipeFields(lex)
|
p, err := parsePipeFields(lex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("cannot parse %s: %s", s, err)
|
t.Fatalf("cannot parse %s: %s", s, err)
|
||||||
|
|
|
@ -12,7 +12,6 @@ func TestPipeRenameUpdateNeededFields(t *testing.T) {
|
||||||
unfs := newTestFieldsSet(unneededFields)
|
unfs := newTestFieldsSet(unneededFields)
|
||||||
|
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
lex.nextToken()
|
|
||||||
p, err := parsePipeRename(lex)
|
p, err := parsePipeRename(lex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("cannot parse %s: %s", s, err)
|
t.Fatalf("cannot parse %s: %s", s, err)
|
||||||
|
|
|
@ -12,7 +12,6 @@ func TestPipeSortUpdateNeededFields(t *testing.T) {
|
||||||
unfs := newTestFieldsSet(unneededFields)
|
unfs := newTestFieldsSet(unneededFields)
|
||||||
|
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
lex.nextToken()
|
|
||||||
p, err := parsePipeSort(lex)
|
p, err := parsePipeSort(lex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("cannot parse %s: %s", s, err)
|
t.Fatalf("cannot parse %s: %s", s, err)
|
||||||
|
|
|
@ -12,7 +12,6 @@ func TestPipeStatsUpdateNeededFields(t *testing.T) {
|
||||||
unfs := newTestFieldsSet(unneededFields)
|
unfs := newTestFieldsSet(unneededFields)
|
||||||
|
|
||||||
lex := newLexer(s)
|
lex := newLexer(s)
|
||||||
lex.nextToken()
|
|
||||||
p, err := parsePipeStats(lex)
|
p, err := parsePipeStats(lex)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
t.Fatalf("unexpected error when parsing %s: %s", s, err)
|
t.Fatalf("unexpected error when parsing %s: %s", s, err)
|
||||||
|
|
Loading…
Reference in a new issue