2014-11-15 19:04:30 +00:00
|
|
|
package influxql
|
|
|
|
|
2014-11-19 23:47:46 +00:00
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
2014-11-15 19:04:30 +00:00
|
|
|
// Token is a lexical token of the InfluxQL language.
|
|
|
|
type Token int
|
|
|
|
|
2016-01-14 15:36:38 +00:00
|
|
|
// These are a comprehensive list of InfluxQL language tokens.
|
2014-11-15 19:04:30 +00:00
|
|
|
const (
|
2016-01-14 15:36:38 +00:00
|
|
|
// ILLEGAL Token, EOF, WS are Special InfluxQL tokens.
|
2014-11-15 19:04:30 +00:00
|
|
|
ILLEGAL Token = iota
|
|
|
|
EOF
|
2014-11-19 23:47:46 +00:00
|
|
|
WS
|
2014-11-15 19:04:30 +00:00
|
|
|
|
2016-01-14 15:36:38 +00:00
|
|
|
literalBeg
|
|
|
|
// IDENT and the following are InfluxQL literal tokens.
|
|
|
|
IDENT // main
|
|
|
|
NUMBER // 12345.67
|
|
|
|
DURATIONVAL // 13h
|
|
|
|
STRING // "abc"
|
|
|
|
BADSTRING // "abc
|
|
|
|
BADESCAPE // \q
|
|
|
|
TRUE // true
|
|
|
|
FALSE // false
|
|
|
|
REGEX // Regular expressions
|
|
|
|
BADREGEX // `.*
|
|
|
|
literalEnd
|
2014-11-15 19:04:30 +00:00
|
|
|
|
2016-01-14 15:36:38 +00:00
|
|
|
operatorBeg
|
|
|
|
// ADD and the following are InfluxQL Operators
|
2014-11-15 19:04:30 +00:00
|
|
|
ADD // +
|
|
|
|
SUB // -
|
|
|
|
MUL // *
|
|
|
|
DIV // /
|
|
|
|
|
|
|
|
AND // AND
|
|
|
|
OR // OR
|
|
|
|
|
2015-02-13 18:25:48 +00:00
|
|
|
EQ // =
|
|
|
|
NEQ // !=
|
|
|
|
EQREGEX // =~
|
|
|
|
NEQREGEX // !~
|
|
|
|
LT // <
|
|
|
|
LTE // <=
|
|
|
|
GT // >
|
|
|
|
GTE // >=
|
2016-01-14 15:36:38 +00:00
|
|
|
operatorEnd
|
2014-11-15 19:04:30 +00:00
|
|
|
|
2014-11-20 15:02:47 +00:00
|
|
|
LPAREN // (
|
|
|
|
RPAREN // )
|
|
|
|
COMMA // ,
|
2015-08-27 23:23:21 +00:00
|
|
|
COLON // :
|
2014-11-20 15:02:47 +00:00
|
|
|
SEMICOLON // ;
|
2015-01-06 22:34:01 +00:00
|
|
|
DOT // .
|
2014-11-15 19:04:30 +00:00
|
|
|
|
2016-01-14 15:36:38 +00:00
|
|
|
keywordBeg
|
|
|
|
// ALL and the following are InfluxQL Keywords
|
2014-12-29 18:14:33 +00:00
|
|
|
ALL
|
2015-01-05 18:24:50 +00:00
|
|
|
ALTER
|
2015-10-08 16:45:23 +00:00
|
|
|
ANY
|
2014-11-15 19:04:30 +00:00
|
|
|
AS
|
|
|
|
ASC
|
2015-01-06 21:30:27 +00:00
|
|
|
BEGIN
|
2014-11-15 19:04:30 +00:00
|
|
|
BY
|
2014-11-25 04:49:09 +00:00
|
|
|
CREATE
|
2014-11-15 19:04:30 +00:00
|
|
|
CONTINUOUS
|
2015-12-30 13:15:00 +00:00
|
|
|
DATA
|
2014-12-29 18:14:33 +00:00
|
|
|
DATABASE
|
2015-01-09 15:47:57 +00:00
|
|
|
DATABASES
|
2014-12-31 13:47:21 +00:00
|
|
|
DEFAULT
|
2014-11-15 19:04:30 +00:00
|
|
|
DELETE
|
|
|
|
DESC
|
2015-10-08 16:45:23 +00:00
|
|
|
DESTINATIONS
|
|
|
|
DIAGNOSTICS
|
2015-05-18 21:36:50 +00:00
|
|
|
DISTINCT
|
2014-11-15 19:04:30 +00:00
|
|
|
DROP
|
2015-01-05 02:50:56 +00:00
|
|
|
DURATION
|
2015-01-06 21:30:27 +00:00
|
|
|
END
|
2015-12-18 20:32:05 +00:00
|
|
|
EVERY
|
2014-12-29 18:14:33 +00:00
|
|
|
EXISTS
|
2014-11-15 19:04:30 +00:00
|
|
|
EXPLAIN
|
2014-12-10 05:07:29 +00:00
|
|
|
FIELD
|
2015-04-03 14:14:09 +00:00
|
|
|
FOR
|
2015-10-03 02:49:11 +00:00
|
|
|
FORCE
|
2014-11-15 19:04:30 +00:00
|
|
|
FROM
|
2015-01-03 03:56:26 +00:00
|
|
|
GRANT
|
2015-05-24 07:27:02 +00:00
|
|
|
GRANTS
|
2014-11-22 04:12:48 +00:00
|
|
|
GROUP
|
2015-11-13 23:26:30 +00:00
|
|
|
GROUPS
|
2014-12-29 18:14:33 +00:00
|
|
|
IF
|
2015-01-29 17:09:05 +00:00
|
|
|
IN
|
2015-03-05 23:19:43 +00:00
|
|
|
INF
|
2014-11-15 19:04:30 +00:00
|
|
|
INNER
|
2014-11-20 15:02:47 +00:00
|
|
|
INSERT
|
|
|
|
INTO
|
2015-01-28 10:02:36 +00:00
|
|
|
KEY
|
2014-12-10 05:07:29 +00:00
|
|
|
KEYS
|
2014-11-15 19:04:30 +00:00
|
|
|
LIMIT
|
2015-12-30 13:15:00 +00:00
|
|
|
META
|
2014-12-10 05:07:29 +00:00
|
|
|
MEASUREMENT
|
|
|
|
MEASUREMENTS
|
2015-11-27 19:35:46 +00:00
|
|
|
NAME
|
2015-08-29 00:41:43 +00:00
|
|
|
NOT
|
2015-01-25 20:34:49 +00:00
|
|
|
OFFSET
|
2014-12-29 18:14:33 +00:00
|
|
|
ON
|
2014-11-15 19:04:30 +00:00
|
|
|
ORDER
|
2014-12-29 18:14:33 +00:00
|
|
|
PASSWORD
|
|
|
|
POLICY
|
2015-01-13 20:21:06 +00:00
|
|
|
POLICIES
|
2014-12-29 18:14:33 +00:00
|
|
|
PRIVILEGES
|
2014-11-15 19:04:30 +00:00
|
|
|
QUERIES
|
2014-11-22 23:33:21 +00:00
|
|
|
QUERY
|
2014-12-29 18:14:33 +00:00
|
|
|
READ
|
2015-01-05 02:50:56 +00:00
|
|
|
REPLICATION
|
2015-12-18 20:32:05 +00:00
|
|
|
RESAMPLE
|
2014-12-29 18:14:33 +00:00
|
|
|
RETENTION
|
|
|
|
REVOKE
|
2014-11-15 19:04:30 +00:00
|
|
|
SELECT
|
|
|
|
SERIES
|
2015-10-03 02:49:11 +00:00
|
|
|
SERVER
|
2015-03-10 19:46:05 +00:00
|
|
|
SERVERS
|
2015-04-03 14:14:09 +00:00
|
|
|
SET
|
2015-03-10 01:46:05 +00:00
|
|
|
SHOW
|
2015-11-13 23:26:30 +00:00
|
|
|
SHARD
|
2015-08-24 19:29:17 +00:00
|
|
|
SHARDS
|
2015-03-10 01:46:05 +00:00
|
|
|
SLIMIT
|
|
|
|
SOFFSET
|
2015-10-08 16:45:23 +00:00
|
|
|
STATS
|
|
|
|
SUBSCRIPTION
|
|
|
|
SUBSCRIPTIONS
|
2014-12-10 05:07:29 +00:00
|
|
|
TAG
|
2014-12-29 18:14:33 +00:00
|
|
|
TO
|
|
|
|
USER
|
2015-01-14 16:53:17 +00:00
|
|
|
USERS
|
2014-12-10 05:07:29 +00:00
|
|
|
VALUES
|
2014-11-15 19:04:30 +00:00
|
|
|
WHERE
|
2014-12-29 18:14:33 +00:00
|
|
|
WITH
|
|
|
|
WRITE
|
2016-01-14 15:36:38 +00:00
|
|
|
keywordEnd
|
2014-11-15 19:04:30 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var tokens = [...]string{
|
|
|
|
ILLEGAL: "ILLEGAL",
|
2014-11-19 23:47:46 +00:00
|
|
|
EOF: "EOF",
|
|
|
|
WS: "WS",
|
2014-11-15 19:04:30 +00:00
|
|
|
|
2016-01-14 15:36:38 +00:00
|
|
|
IDENT: "IDENT",
|
|
|
|
NUMBER: "NUMBER",
|
|
|
|
DURATIONVAL: "DURATIONVAL",
|
|
|
|
STRING: "STRING",
|
|
|
|
BADSTRING: "BADSTRING",
|
|
|
|
BADESCAPE: "BADESCAPE",
|
|
|
|
TRUE: "TRUE",
|
|
|
|
FALSE: "FALSE",
|
|
|
|
REGEX: "REGEX",
|
2014-11-15 19:04:30 +00:00
|
|
|
|
|
|
|
ADD: "+",
|
|
|
|
SUB: "-",
|
|
|
|
MUL: "*",
|
|
|
|
DIV: "/",
|
|
|
|
|
|
|
|
AND: "AND",
|
|
|
|
OR: "OR",
|
|
|
|
|
2015-02-13 18:25:48 +00:00
|
|
|
EQ: "=",
|
|
|
|
NEQ: "!=",
|
|
|
|
EQREGEX: "=~",
|
|
|
|
NEQREGEX: "!~",
|
|
|
|
LT: "<",
|
|
|
|
LTE: "<=",
|
|
|
|
GT: ">",
|
|
|
|
GTE: ">=",
|
2014-11-15 19:04:30 +00:00
|
|
|
|
2014-11-20 15:02:47 +00:00
|
|
|
LPAREN: "(",
|
|
|
|
RPAREN: ")",
|
|
|
|
COMMA: ",",
|
2015-08-27 23:23:21 +00:00
|
|
|
COLON: ":",
|
2014-11-20 15:02:47 +00:00
|
|
|
SEMICOLON: ";",
|
2015-01-06 22:34:01 +00:00
|
|
|
DOT: ".",
|
2014-11-15 19:04:30 +00:00
|
|
|
|
2015-10-08 16:45:23 +00:00
|
|
|
ALL: "ALL",
|
|
|
|
ALTER: "ALTER",
|
|
|
|
ANY: "ANY",
|
|
|
|
AS: "AS",
|
|
|
|
ASC: "ASC",
|
|
|
|
BEGIN: "BEGIN",
|
|
|
|
BY: "BY",
|
|
|
|
CREATE: "CREATE",
|
|
|
|
CONTINUOUS: "CONTINUOUS",
|
2015-12-30 13:15:00 +00:00
|
|
|
DATA: "DATA",
|
2015-10-08 16:45:23 +00:00
|
|
|
DATABASE: "DATABASE",
|
|
|
|
DATABASES: "DATABASES",
|
|
|
|
DEFAULT: "DEFAULT",
|
|
|
|
DELETE: "DELETE",
|
|
|
|
DESC: "DESC",
|
|
|
|
DESTINATIONS: "DESTINATIONS",
|
|
|
|
DIAGNOSTICS: "DIAGNOSTICS",
|
|
|
|
DISTINCT: "DISTINCT",
|
|
|
|
DROP: "DROP",
|
|
|
|
DURATION: "DURATION",
|
|
|
|
END: "END",
|
2015-12-18 20:32:05 +00:00
|
|
|
EVERY: "EVERY",
|
2015-10-08 16:45:23 +00:00
|
|
|
EXISTS: "EXISTS",
|
|
|
|
EXPLAIN: "EXPLAIN",
|
|
|
|
FIELD: "FIELD",
|
|
|
|
FOR: "FOR",
|
|
|
|
FORCE: "FORCE",
|
|
|
|
FROM: "FROM",
|
|
|
|
GRANT: "GRANT",
|
|
|
|
GRANTS: "GRANTS",
|
|
|
|
GROUP: "GROUP",
|
2015-11-13 23:26:30 +00:00
|
|
|
GROUPS: "GROUPS",
|
2015-10-08 16:45:23 +00:00
|
|
|
IF: "IF",
|
|
|
|
IN: "IN",
|
|
|
|
INF: "INF",
|
|
|
|
INNER: "INNER",
|
|
|
|
INSERT: "INSERT",
|
|
|
|
INTO: "INTO",
|
|
|
|
KEY: "KEY",
|
|
|
|
KEYS: "KEYS",
|
|
|
|
LIMIT: "LIMIT",
|
|
|
|
MEASUREMENT: "MEASUREMENT",
|
|
|
|
MEASUREMENTS: "MEASUREMENTS",
|
2015-12-30 13:15:00 +00:00
|
|
|
META: "META",
|
2015-11-27 19:35:46 +00:00
|
|
|
NAME: "NAME",
|
2015-10-08 16:45:23 +00:00
|
|
|
NOT: "NOT",
|
|
|
|
OFFSET: "OFFSET",
|
|
|
|
ON: "ON",
|
|
|
|
ORDER: "ORDER",
|
|
|
|
PASSWORD: "PASSWORD",
|
|
|
|
POLICY: "POLICY",
|
|
|
|
POLICIES: "POLICIES",
|
|
|
|
PRIVILEGES: "PRIVILEGES",
|
|
|
|
QUERIES: "QUERIES",
|
|
|
|
QUERY: "QUERY",
|
|
|
|
READ: "READ",
|
|
|
|
REPLICATION: "REPLICATION",
|
2015-12-18 20:32:05 +00:00
|
|
|
RESAMPLE: "RESAMPLE",
|
2015-10-08 16:45:23 +00:00
|
|
|
RETENTION: "RETENTION",
|
|
|
|
REVOKE: "REVOKE",
|
|
|
|
SELECT: "SELECT",
|
|
|
|
SERIES: "SERIES",
|
|
|
|
SERVER: "SERVER",
|
|
|
|
SERVERS: "SERVERS",
|
|
|
|
SET: "SET",
|
|
|
|
SHOW: "SHOW",
|
2015-11-13 23:26:30 +00:00
|
|
|
SHARD: "SHARD",
|
2015-10-08 16:45:23 +00:00
|
|
|
SHARDS: "SHARDS",
|
|
|
|
SLIMIT: "SLIMIT",
|
|
|
|
SOFFSET: "SOFFSET",
|
|
|
|
STATS: "STATS",
|
|
|
|
SUBSCRIPTION: "SUBSCRIPTION",
|
|
|
|
SUBSCRIPTIONS: "SUBSCRIPTIONS",
|
|
|
|
TAG: "TAG",
|
|
|
|
TO: "TO",
|
|
|
|
USER: "USER",
|
|
|
|
USERS: "USERS",
|
|
|
|
VALUES: "VALUES",
|
|
|
|
WHERE: "WHERE",
|
|
|
|
WITH: "WITH",
|
|
|
|
WRITE: "WRITE",
|
2014-11-15 19:04:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
var keywords map[string]Token
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
keywords = make(map[string]Token)
|
2016-01-14 15:36:38 +00:00
|
|
|
for tok := keywordBeg + 1; tok < keywordEnd; tok++ {
|
2014-11-19 23:47:46 +00:00
|
|
|
keywords[strings.ToLower(tokens[tok])] = tok
|
|
|
|
}
|
|
|
|
for _, tok := range []Token{AND, OR} {
|
|
|
|
keywords[strings.ToLower(tokens[tok])] = tok
|
2014-11-15 19:04:30 +00:00
|
|
|
}
|
|
|
|
keywords["true"] = TRUE
|
|
|
|
keywords["false"] = FALSE
|
|
|
|
}
|
|
|
|
|
|
|
|
// String returns the string representation of the token.
|
|
|
|
func (tok Token) String() string {
|
|
|
|
if tok >= 0 && tok < Token(len(tokens)) {
|
|
|
|
return tokens[tok]
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// Precedence returns the operator precedence of the binary operator token.
|
|
|
|
func (tok Token) Precedence() int {
|
|
|
|
switch tok {
|
|
|
|
case OR:
|
|
|
|
return 1
|
|
|
|
case AND:
|
|
|
|
return 2
|
2015-03-02 16:33:51 +00:00
|
|
|
case EQ, NEQ, EQREGEX, NEQREGEX, LT, LTE, GT, GTE:
|
2014-11-15 19:04:30 +00:00
|
|
|
return 3
|
|
|
|
case ADD, SUB:
|
|
|
|
return 4
|
|
|
|
case MUL, DIV:
|
|
|
|
return 5
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2014-11-22 23:33:21 +00:00
|
|
|
// isOperator returns true for operator tokens.
|
2016-01-14 15:36:38 +00:00
|
|
|
func (tok Token) isOperator() bool { return tok > operatorBeg && tok < operatorEnd }
|
2014-11-22 04:12:48 +00:00
|
|
|
|
|
|
|
// tokstr returns a literal if provided, otherwise returns the token string.
|
|
|
|
func tokstr(tok Token, lit string) string {
|
|
|
|
if lit != "" {
|
|
|
|
return lit
|
|
|
|
}
|
|
|
|
return tok.String()
|
|
|
|
}
|
|
|
|
|
2014-11-15 19:04:30 +00:00
|
|
|
// Lookup returns the token associated with a given string.
|
|
|
|
func Lookup(ident string) Token {
|
2015-04-09 20:01:34 +00:00
|
|
|
if tok, ok := keywords[strings.ToLower(ident)]; ok {
|
2014-11-15 19:04:30 +00:00
|
|
|
return tok
|
|
|
|
}
|
|
|
|
return IDENT
|
|
|
|
}
|
|
|
|
|
|
|
|
// Pos specifies the line and character position of a token.
|
|
|
|
// The Char and Line are both zero-based indexes.
|
|
|
|
type Pos struct {
|
|
|
|
Line int
|
|
|
|
Char int
|
|
|
|
}
|