mirror of
https://github.com/prometheus/prometheus.git
synced 2024-11-11 08:04:04 -08:00
72d7b325a1
This allows changing the time offset for individual instant and range vectors in a query. For example, this returns the value of `foo` 5 minutes in the past relative to the current query evaluation time: foo offset 5m Note that the `offset` modifier always needs to follow the selector immediately. I.e. the following would be correct: sum(foo offset 5m) // GOOD. While the following would be *incorrect*: sum(foo) offset 5m // INVALID. The same works for range vectors. This returns the 5-minutes-rate that `foo` had a week ago: rate(foo[5m] offset 1w) This change touches the following components: * Lexer/parser: additions to correctly parse the new `offset`/`OFFSET` keyword. * AST: vector and matrix nodes now have an additional `offset` field. This is used during their evaluation to adjust query and result times appropriately. * Query analyzer: now works on separate sets of ranges and instants per offset. Isolating different offsets from each other completely in this way keeps the preloading code relatively simple. No storage engine changes were needed by this change. The rules tests have been changed to not probe the internal implementation details of the query analyzer anymore (how many instants and ranges have been preloaded). This would also become too cumbersome to test with the new model, and measuring the result of the query should be sufficient. This fixes https://github.com/prometheus/prometheus/issues/529 This fixed https://github.com/prometheus/promdash/issues/201
746 lines
15 KiB
Go
746 lines
15 KiB
Go
//line parser.y:15
|
|
package rules
|
|
|
|
import __yyfmt__ "fmt"
|
|
|
|
//line parser.y:15
|
|
import (
|
|
clientmodel "github.com/prometheus/client_golang/model"
|
|
|
|
"github.com/prometheus/prometheus/rules/ast"
|
|
"github.com/prometheus/prometheus/storage/metric"
|
|
)
|
|
|
|
//line parser.y:25
|
|
type yySymType struct {
|
|
yys int
|
|
num clientmodel.SampleValue
|
|
str string
|
|
ruleNode ast.Node
|
|
ruleNodeSlice []ast.Node
|
|
boolean bool
|
|
labelNameSlice clientmodel.LabelNames
|
|
labelSet clientmodel.LabelSet
|
|
labelMatcher *metric.LabelMatcher
|
|
labelMatchers metric.LabelMatchers
|
|
}
|
|
|
|
const START_RULES = 57346
|
|
const START_EXPRESSION = 57347
|
|
const IDENTIFIER = 57348
|
|
const STRING = 57349
|
|
const DURATION = 57350
|
|
const METRICNAME = 57351
|
|
const NUMBER = 57352
|
|
const PERMANENT = 57353
|
|
const GROUP_OP = 57354
|
|
const KEEPING_EXTRA = 57355
|
|
const OFFSET = 57356
|
|
const AGGR_OP = 57357
|
|
const CMP_OP = 57358
|
|
const ADDITIVE_OP = 57359
|
|
const MULT_OP = 57360
|
|
const ALERT = 57361
|
|
const IF = 57362
|
|
const FOR = 57363
|
|
const WITH = 57364
|
|
const SUMMARY = 57365
|
|
const DESCRIPTION = 57366
|
|
|
|
var yyToknames = []string{
|
|
"START_RULES",
|
|
"START_EXPRESSION",
|
|
"IDENTIFIER",
|
|
"STRING",
|
|
"DURATION",
|
|
"METRICNAME",
|
|
"NUMBER",
|
|
"PERMANENT",
|
|
"GROUP_OP",
|
|
"KEEPING_EXTRA",
|
|
"OFFSET",
|
|
"AGGR_OP",
|
|
"CMP_OP",
|
|
"ADDITIVE_OP",
|
|
"MULT_OP",
|
|
"ALERT",
|
|
"IF",
|
|
"FOR",
|
|
"WITH",
|
|
"SUMMARY",
|
|
"DESCRIPTION",
|
|
"'='",
|
|
}
|
|
var yyStatenames = []string{}
|
|
|
|
const yyEofCode = 1
|
|
const yyErrCode = 2
|
|
const yyMaxDepth = 200
|
|
|
|
//line parser.y:261
|
|
|
|
//line yacctab:1
|
|
var yyExca = []int{
|
|
-1, 1,
|
|
1, -1,
|
|
-2, 0,
|
|
-1, 4,
|
|
1, 1,
|
|
-2, 10,
|
|
}
|
|
|
|
const yyNprod = 52
|
|
const yyPrivate = 57344
|
|
|
|
var yyTokenNames []string
|
|
var yyStates []string
|
|
|
|
const yyLast = 142
|
|
|
|
var yyAct = []int{
|
|
|
|
58, 76, 55, 52, 51, 30, 45, 6, 24, 20,
|
|
61, 22, 10, 53, 18, 13, 12, 84, 68, 83,
|
|
67, 11, 18, 36, 37, 38, 21, 19, 20, 21,
|
|
19, 20, 8, 54, 90, 7, 50, 21, 19, 20,
|
|
92, 18, 10, 53, 18, 13, 12, 70, 63, 62,
|
|
88, 11, 18, 57, 31, 21, 19, 20, 86, 87,
|
|
66, 40, 8, 10, 78, 7, 13, 12, 79, 69,
|
|
18, 29, 11, 80, 82, 81, 28, 85, 21, 19,
|
|
20, 19, 20, 8, 91, 77, 7, 41, 40, 94,
|
|
25, 23, 39, 18, 59, 18, 44, 98, 27, 73,
|
|
101, 99, 60, 96, 17, 43, 75, 9, 46, 56,
|
|
31, 47, 16, 33, 97, 102, 13, 65, 35, 48,
|
|
100, 95, 64, 32, 77, 93, 72, 25, 34, 2,
|
|
3, 14, 5, 4, 1, 42, 89, 15, 26, 74,
|
|
71, 49,
|
|
}
|
|
var yyPact = []int{
|
|
|
|
125, -1000, -1000, 57, 93, -1000, 21, 57, 121, 72,
|
|
47, 42, -1000, -1000, -1000, 107, 122, -1000, 110, 57,
|
|
57, 57, 62, 60, -1000, 80, 94, 84, 6, 57,
|
|
96, 24, 68, -1000, 82, -22, -9, -17, 64, -1000,
|
|
121, 94, 115, -1000, -1000, -1000, 109, -1000, 33, -10,
|
|
-1000, -1000, 21, -1000, 39, 18, -1000, 120, 74, 79,
|
|
57, 94, -1000, -1000, -1000, -1000, -1000, -1000, 36, 98,
|
|
57, -11, -1000, 57, 31, -1000, -1000, 25, 13, -1000,
|
|
-1000, 96, 10, -1000, 119, 21, -1000, 118, 114, 81,
|
|
106, -1000, -1000, -1000, -1000, -1000, 68, -1000, 78, 113,
|
|
76, 108, -1000,
|
|
}
|
|
var yyPgo = []int{
|
|
|
|
0, 141, 140, 5, 1, 139, 0, 8, 91, 138,
|
|
3, 4, 137, 2, 136, 107, 135, 6, 134, 133,
|
|
132, 131,
|
|
}
|
|
var yyR1 = []int{
|
|
|
|
0, 18, 18, 19, 19, 20, 21, 21, 14, 14,
|
|
12, 12, 15, 15, 6, 6, 6, 5, 5, 4,
|
|
9, 9, 9, 8, 8, 7, 16, 16, 17, 17,
|
|
10, 10, 10, 10, 10, 10, 10, 10, 10, 10,
|
|
10, 10, 13, 13, 3, 3, 2, 2, 1, 1,
|
|
11, 11,
|
|
}
|
|
var yyR2 = []int{
|
|
|
|
0, 2, 2, 0, 2, 1, 5, 11, 0, 2,
|
|
0, 1, 1, 1, 0, 3, 2, 1, 3, 3,
|
|
0, 2, 3, 1, 3, 3, 1, 1, 0, 2,
|
|
3, 4, 3, 4, 3, 5, 6, 6, 3, 3,
|
|
3, 1, 0, 1, 0, 4, 1, 3, 1, 3,
|
|
1, 1,
|
|
}
|
|
var yyChk = []int{
|
|
|
|
-1000, -18, 4, 5, -19, -20, -10, 29, 26, -15,
|
|
6, 15, 10, 9, -21, -12, 19, 11, 31, 17,
|
|
18, 16, -10, -8, -7, 6, -9, 26, 29, 29,
|
|
-3, 12, -15, 6, 6, 8, -10, -10, -10, 30,
|
|
28, 27, -16, 25, 16, -17, 14, 27, -8, -1,
|
|
30, -11, -10, 7, -10, -13, 13, 29, -6, 26,
|
|
20, 32, -7, -17, 7, 8, 27, 30, 28, 30,
|
|
29, -2, 6, 25, -5, 27, -4, 6, -10, -17,
|
|
-11, -3, -10, 30, 28, -10, 27, 28, 25, -14,
|
|
21, -13, 30, 6, -4, 7, 22, 8, -6, 23,
|
|
7, 24, 7,
|
|
}
|
|
var yyDef = []int{
|
|
|
|
0, -2, 3, 0, -2, 2, 5, 0, 0, 20,
|
|
13, 44, 41, 12, 4, 0, 0, 11, 0, 0,
|
|
0, 0, 0, 0, 23, 0, 28, 0, 0, 0,
|
|
42, 0, 14, 13, 0, 0, 38, 39, 40, 30,
|
|
0, 28, 0, 26, 27, 32, 0, 21, 0, 0,
|
|
34, 48, 50, 51, 0, 0, 43, 0, 0, 0,
|
|
0, 28, 24, 31, 25, 29, 22, 33, 0, 44,
|
|
0, 0, 46, 0, 0, 16, 17, 0, 8, 35,
|
|
49, 42, 0, 45, 0, 6, 15, 0, 0, 0,
|
|
0, 36, 37, 47, 18, 19, 14, 9, 0, 0,
|
|
0, 0, 7,
|
|
}
|
|
var yyTok1 = []int{
|
|
|
|
1, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
29, 30, 3, 3, 28, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 25, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 31, 3, 32, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
|
|
3, 3, 3, 26, 3, 27,
|
|
}
|
|
var yyTok2 = []int{
|
|
|
|
2, 3, 4, 5, 6, 7, 8, 9, 10, 11,
|
|
12, 13, 14, 15, 16, 17, 18, 19, 20, 21,
|
|
22, 23, 24,
|
|
}
|
|
var yyTok3 = []int{
|
|
0,
|
|
}
|
|
|
|
//line yaccpar:1
|
|
|
|
/* parser for yacc output */
|
|
|
|
var yyDebug = 0
|
|
|
|
type yyLexer interface {
|
|
Lex(lval *yySymType) int
|
|
Error(s string)
|
|
}
|
|
|
|
const yyFlag = -1000
|
|
|
|
func yyTokname(c int) string {
|
|
// 4 is TOKSTART above
|
|
if c >= 4 && c-4 < len(yyToknames) {
|
|
if yyToknames[c-4] != "" {
|
|
return yyToknames[c-4]
|
|
}
|
|
}
|
|
return __yyfmt__.Sprintf("tok-%v", c)
|
|
}
|
|
|
|
func yyStatname(s int) string {
|
|
if s >= 0 && s < len(yyStatenames) {
|
|
if yyStatenames[s] != "" {
|
|
return yyStatenames[s]
|
|
}
|
|
}
|
|
return __yyfmt__.Sprintf("state-%v", s)
|
|
}
|
|
|
|
func yylex1(lex yyLexer, lval *yySymType) int {
|
|
c := 0
|
|
char := lex.Lex(lval)
|
|
if char <= 0 {
|
|
c = yyTok1[0]
|
|
goto out
|
|
}
|
|
if char < len(yyTok1) {
|
|
c = yyTok1[char]
|
|
goto out
|
|
}
|
|
if char >= yyPrivate {
|
|
if char < yyPrivate+len(yyTok2) {
|
|
c = yyTok2[char-yyPrivate]
|
|
goto out
|
|
}
|
|
}
|
|
for i := 0; i < len(yyTok3); i += 2 {
|
|
c = yyTok3[i+0]
|
|
if c == char {
|
|
c = yyTok3[i+1]
|
|
goto out
|
|
}
|
|
}
|
|
|
|
out:
|
|
if c == 0 {
|
|
c = yyTok2[1] /* unknown char */
|
|
}
|
|
if yyDebug >= 3 {
|
|
__yyfmt__.Printf("lex %s(%d)\n", yyTokname(c), uint(char))
|
|
}
|
|
return c
|
|
}
|
|
|
|
func yyParse(yylex yyLexer) int {
|
|
var yyn int
|
|
var yylval yySymType
|
|
var yyVAL yySymType
|
|
yyS := make([]yySymType, yyMaxDepth)
|
|
|
|
Nerrs := 0 /* number of errors */
|
|
Errflag := 0 /* error recovery flag */
|
|
yystate := 0
|
|
yychar := -1
|
|
yyp := -1
|
|
goto yystack
|
|
|
|
ret0:
|
|
return 0
|
|
|
|
ret1:
|
|
return 1
|
|
|
|
yystack:
|
|
/* put a state and value onto the stack */
|
|
if yyDebug >= 4 {
|
|
__yyfmt__.Printf("char %v in %v\n", yyTokname(yychar), yyStatname(yystate))
|
|
}
|
|
|
|
yyp++
|
|
if yyp >= len(yyS) {
|
|
nyys := make([]yySymType, len(yyS)*2)
|
|
copy(nyys, yyS)
|
|
yyS = nyys
|
|
}
|
|
yyS[yyp] = yyVAL
|
|
yyS[yyp].yys = yystate
|
|
|
|
yynewstate:
|
|
yyn = yyPact[yystate]
|
|
if yyn <= yyFlag {
|
|
goto yydefault /* simple state */
|
|
}
|
|
if yychar < 0 {
|
|
yychar = yylex1(yylex, &yylval)
|
|
}
|
|
yyn += yychar
|
|
if yyn < 0 || yyn >= yyLast {
|
|
goto yydefault
|
|
}
|
|
yyn = yyAct[yyn]
|
|
if yyChk[yyn] == yychar { /* valid shift */
|
|
yychar = -1
|
|
yyVAL = yylval
|
|
yystate = yyn
|
|
if Errflag > 0 {
|
|
Errflag--
|
|
}
|
|
goto yystack
|
|
}
|
|
|
|
yydefault:
|
|
/* default state action */
|
|
yyn = yyDef[yystate]
|
|
if yyn == -2 {
|
|
if yychar < 0 {
|
|
yychar = yylex1(yylex, &yylval)
|
|
}
|
|
|
|
/* look through exception table */
|
|
xi := 0
|
|
for {
|
|
if yyExca[xi+0] == -1 && yyExca[xi+1] == yystate {
|
|
break
|
|
}
|
|
xi += 2
|
|
}
|
|
for xi += 2; ; xi += 2 {
|
|
yyn = yyExca[xi+0]
|
|
if yyn < 0 || yyn == yychar {
|
|
break
|
|
}
|
|
}
|
|
yyn = yyExca[xi+1]
|
|
if yyn < 0 {
|
|
goto ret0
|
|
}
|
|
}
|
|
if yyn == 0 {
|
|
/* error ... attempt to resume parsing */
|
|
switch Errflag {
|
|
case 0: /* brand new error */
|
|
yylex.Error("syntax error")
|
|
Nerrs++
|
|
if yyDebug >= 1 {
|
|
__yyfmt__.Printf("%s", yyStatname(yystate))
|
|
__yyfmt__.Printf(" saw %s\n", yyTokname(yychar))
|
|
}
|
|
fallthrough
|
|
|
|
case 1, 2: /* incompletely recovered error ... try again */
|
|
Errflag = 3
|
|
|
|
/* find a state where "error" is a legal shift action */
|
|
for yyp >= 0 {
|
|
yyn = yyPact[yyS[yyp].yys] + yyErrCode
|
|
if yyn >= 0 && yyn < yyLast {
|
|
yystate = yyAct[yyn] /* simulate a shift of "error" */
|
|
if yyChk[yystate] == yyErrCode {
|
|
goto yystack
|
|
}
|
|
}
|
|
|
|
/* the current p has no shift on "error", pop stack */
|
|
if yyDebug >= 2 {
|
|
__yyfmt__.Printf("error recovery pops state %d\n", yyS[yyp].yys)
|
|
}
|
|
yyp--
|
|
}
|
|
/* there is no state on the stack with an error shift ... abort */
|
|
goto ret1
|
|
|
|
case 3: /* no shift yet; clobber input char */
|
|
if yyDebug >= 2 {
|
|
__yyfmt__.Printf("error recovery discards %s\n", yyTokname(yychar))
|
|
}
|
|
if yychar == yyEofCode {
|
|
goto ret1
|
|
}
|
|
yychar = -1
|
|
goto yynewstate /* try again in the same state */
|
|
}
|
|
}
|
|
|
|
/* reduction by production yyn */
|
|
if yyDebug >= 2 {
|
|
__yyfmt__.Printf("reduce %v in:\n\t%v\n", yyn, yyStatname(yystate))
|
|
}
|
|
|
|
yynt := yyn
|
|
yypt := yyp
|
|
_ = yypt // guard against "declared and not used"
|
|
|
|
yyp -= yyR2[yyn]
|
|
yyVAL = yyS[yyp+1]
|
|
|
|
/* consult goto table to find next state */
|
|
yyn = yyR1[yyn]
|
|
yyg := yyPgo[yyn]
|
|
yyj := yyg + yyS[yyp].yys + 1
|
|
|
|
if yyj >= yyLast {
|
|
yystate = yyAct[yyg]
|
|
} else {
|
|
yystate = yyAct[yyj]
|
|
if yyChk[yystate] != -yyn {
|
|
yystate = yyAct[yyg]
|
|
}
|
|
}
|
|
// dummy call; replaced with literal code
|
|
switch yynt {
|
|
|
|
case 5:
|
|
//line parser.y:74
|
|
{
|
|
yylex.(*RulesLexer).parsedExpr = yyS[yypt-0].ruleNode
|
|
}
|
|
case 6:
|
|
//line parser.y:79
|
|
{
|
|
rule, err := CreateRecordingRule(yyS[yypt-3].str, yyS[yypt-2].labelSet, yyS[yypt-0].ruleNode, yyS[yypt-4].boolean)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
yylex.(*RulesLexer).parsedRules = append(yylex.(*RulesLexer).parsedRules, rule)
|
|
}
|
|
case 7:
|
|
//line parser.y:85
|
|
{
|
|
rule, err := CreateAlertingRule(yyS[yypt-9].str, yyS[yypt-7].ruleNode, yyS[yypt-6].str, yyS[yypt-4].labelSet, yyS[yypt-2].str, yyS[yypt-0].str)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
yylex.(*RulesLexer).parsedRules = append(yylex.(*RulesLexer).parsedRules, rule)
|
|
}
|
|
case 8:
|
|
//line parser.y:93
|
|
{
|
|
yyVAL.str = "0s"
|
|
}
|
|
case 9:
|
|
//line parser.y:95
|
|
{
|
|
yyVAL.str = yyS[yypt-0].str
|
|
}
|
|
case 10:
|
|
//line parser.y:99
|
|
{
|
|
yyVAL.boolean = false
|
|
}
|
|
case 11:
|
|
//line parser.y:101
|
|
{
|
|
yyVAL.boolean = true
|
|
}
|
|
case 12:
|
|
//line parser.y:105
|
|
{
|
|
yyVAL.str = yyS[yypt-0].str
|
|
}
|
|
case 13:
|
|
//line parser.y:107
|
|
{
|
|
yyVAL.str = yyS[yypt-0].str
|
|
}
|
|
case 14:
|
|
//line parser.y:111
|
|
{
|
|
yyVAL.labelSet = clientmodel.LabelSet{}
|
|
}
|
|
case 15:
|
|
//line parser.y:113
|
|
{
|
|
yyVAL.labelSet = yyS[yypt-1].labelSet
|
|
}
|
|
case 16:
|
|
//line parser.y:115
|
|
{
|
|
yyVAL.labelSet = clientmodel.LabelSet{}
|
|
}
|
|
case 17:
|
|
//line parser.y:118
|
|
{
|
|
yyVAL.labelSet = yyS[yypt-0].labelSet
|
|
}
|
|
case 18:
|
|
//line parser.y:120
|
|
{
|
|
for k, v := range yyS[yypt-0].labelSet {
|
|
yyVAL.labelSet[k] = v
|
|
}
|
|
}
|
|
case 19:
|
|
//line parser.y:124
|
|
{
|
|
yyVAL.labelSet = clientmodel.LabelSet{clientmodel.LabelName(yyS[yypt-2].str): clientmodel.LabelValue(yyS[yypt-0].str)}
|
|
}
|
|
case 20:
|
|
//line parser.y:128
|
|
{
|
|
yyVAL.labelMatchers = metric.LabelMatchers{}
|
|
}
|
|
case 21:
|
|
//line parser.y:130
|
|
{
|
|
yyVAL.labelMatchers = metric.LabelMatchers{}
|
|
}
|
|
case 22:
|
|
//line parser.y:132
|
|
{
|
|
yyVAL.labelMatchers = yyS[yypt-1].labelMatchers
|
|
}
|
|
case 23:
|
|
//line parser.y:136
|
|
{
|
|
yyVAL.labelMatchers = metric.LabelMatchers{yyS[yypt-0].labelMatcher}
|
|
}
|
|
case 24:
|
|
//line parser.y:138
|
|
{
|
|
yyVAL.labelMatchers = append(yyVAL.labelMatchers, yyS[yypt-0].labelMatcher)
|
|
}
|
|
case 25:
|
|
//line parser.y:142
|
|
{
|
|
var err error
|
|
yyVAL.labelMatcher, err = newLabelMatcher(yyS[yypt-1].str, clientmodel.LabelName(yyS[yypt-2].str), clientmodel.LabelValue(yyS[yypt-0].str))
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 26:
|
|
//line parser.y:150
|
|
{
|
|
yyVAL.str = "="
|
|
}
|
|
case 27:
|
|
//line parser.y:152
|
|
{
|
|
yyVAL.str = yyS[yypt-0].str
|
|
}
|
|
case 28:
|
|
//line parser.y:156
|
|
{
|
|
yyVAL.str = "0s"
|
|
}
|
|
case 29:
|
|
//line parser.y:158
|
|
{
|
|
yyVAL.str = yyS[yypt-0].str
|
|
}
|
|
case 30:
|
|
//line parser.y:162
|
|
{
|
|
yyVAL.ruleNode = yyS[yypt-1].ruleNode
|
|
}
|
|
case 31:
|
|
//line parser.y:164
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewVectorSelector(yyS[yypt-2].labelMatchers, yyS[yypt-0].str)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 32:
|
|
//line parser.y:170
|
|
{
|
|
var err error
|
|
m, err := metric.NewLabelMatcher(metric.Equal, clientmodel.MetricNameLabel, clientmodel.LabelValue(yyS[yypt-2].str))
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
yyS[yypt-1].labelMatchers = append(yyS[yypt-1].labelMatchers, m)
|
|
yyVAL.ruleNode, err = NewVectorSelector(yyS[yypt-1].labelMatchers, yyS[yypt-0].str)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 33:
|
|
//line parser.y:179
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewFunctionCall(yyS[yypt-3].str, yyS[yypt-1].ruleNodeSlice)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 34:
|
|
//line parser.y:185
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewFunctionCall(yyS[yypt-2].str, []ast.Node{})
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 35:
|
|
//line parser.y:191
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewMatrixSelector(yyS[yypt-4].ruleNode, yyS[yypt-2].str, yyS[yypt-0].str)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 36:
|
|
//line parser.y:197
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewVectorAggregation(yyS[yypt-5].str, yyS[yypt-3].ruleNode, yyS[yypt-1].labelNameSlice, yyS[yypt-0].boolean)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 37:
|
|
//line parser.y:203
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewVectorAggregation(yyS[yypt-5].str, yyS[yypt-1].ruleNode, yyS[yypt-4].labelNameSlice, yyS[yypt-3].boolean)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 38:
|
|
//line parser.y:211
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewArithExpr(yyS[yypt-1].str, yyS[yypt-2].ruleNode, yyS[yypt-0].ruleNode)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 39:
|
|
//line parser.y:217
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewArithExpr(yyS[yypt-1].str, yyS[yypt-2].ruleNode, yyS[yypt-0].ruleNode)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 40:
|
|
//line parser.y:223
|
|
{
|
|
var err error
|
|
yyVAL.ruleNode, err = NewArithExpr(yyS[yypt-1].str, yyS[yypt-2].ruleNode, yyS[yypt-0].ruleNode)
|
|
if err != nil {
|
|
yylex.Error(err.Error())
|
|
return 1
|
|
}
|
|
}
|
|
case 41:
|
|
//line parser.y:229
|
|
{
|
|
yyVAL.ruleNode = ast.NewScalarLiteral(yyS[yypt-0].num)
|
|
}
|
|
case 42:
|
|
//line parser.y:233
|
|
{
|
|
yyVAL.boolean = false
|
|
}
|
|
case 43:
|
|
//line parser.y:235
|
|
{
|
|
yyVAL.boolean = true
|
|
}
|
|
case 44:
|
|
//line parser.y:239
|
|
{
|
|
yyVAL.labelNameSlice = clientmodel.LabelNames{}
|
|
}
|
|
case 45:
|
|
//line parser.y:241
|
|
{
|
|
yyVAL.labelNameSlice = yyS[yypt-1].labelNameSlice
|
|
}
|
|
case 46:
|
|
//line parser.y:245
|
|
{
|
|
yyVAL.labelNameSlice = clientmodel.LabelNames{clientmodel.LabelName(yyS[yypt-0].str)}
|
|
}
|
|
case 47:
|
|
//line parser.y:247
|
|
{
|
|
yyVAL.labelNameSlice = append(yyVAL.labelNameSlice, clientmodel.LabelName(yyS[yypt-0].str))
|
|
}
|
|
case 48:
|
|
//line parser.y:251
|
|
{
|
|
yyVAL.ruleNodeSlice = []ast.Node{yyS[yypt-0].ruleNode}
|
|
}
|
|
case 49:
|
|
//line parser.y:253
|
|
{
|
|
yyVAL.ruleNodeSlice = append(yyVAL.ruleNodeSlice, yyS[yypt-0].ruleNode)
|
|
}
|
|
case 50:
|
|
//line parser.y:257
|
|
{
|
|
yyVAL.ruleNode = yyS[yypt-0].ruleNode
|
|
}
|
|
case 51:
|
|
//line parser.y:259
|
|
{
|
|
yyVAL.ruleNode = ast.NewStringLiteral(yyS[yypt-0].str)
|
|
}
|
|
}
|
|
goto yystack /* stack new state and value */
|
|
}
|