mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-03 18:07:27 -08:00
Code was already working, added working tests
This commit is contained in:
parent
59ef72d3ed
commit
22652359d3
|
@ -586,10 +586,7 @@ label_matcher : IDENTIFIER match_op STRING
|
|||
| string_identifier match_op STRING
|
||||
{ $$ = yylex.(*parser).newLabelMatcher($1, $2, $3); }
|
||||
| string_identifier
|
||||
{
|
||||
// metric name matcher!
|
||||
$$ = yylex.(*parser).newMetricNameMatcher($1);
|
||||
}
|
||||
{ $$ = yylex.(*parser).newMetricNameMatcher($1); }
|
||||
| IDENTIFIER match_op error
|
||||
{ yylex.(*parser).unexpected("label matching", "string"); $$ = nil}
|
||||
| IDENTIFIER error
|
||||
|
@ -612,10 +609,7 @@ metric : metric_identifier label_set
|
|||
metric_identifier: AVG | BOTTOMK | BY | COUNT | COUNT_VALUES | GROUP | IDENTIFIER | LAND | LOR | LUNLESS | MAX | METRIC_IDENTIFIER | MIN | OFFSET | QUANTILE | STDDEV | STDVAR | SUM | TOPK | WITHOUT | START | END;
|
||||
|
||||
label_set : LEFT_BRACE label_set_list RIGHT_BRACE
|
||||
{
|
||||
// LEFT_BRACE label_set_list RIGHT_BRACE
|
||||
$$ = labels.New($2...)
|
||||
}
|
||||
{ $$ = labels.New($2...) }
|
||||
| LEFT_BRACE label_set_list COMMA RIGHT_BRACE
|
||||
{ $$ = labels.New($2...) }
|
||||
| LEFT_BRACE RIGHT_BRACE
|
||||
|
@ -634,17 +628,7 @@ label_set_list : label_set_list COMMA label_set_item
|
|||
;
|
||||
|
||||
label_set_item : IDENTIFIER EQL STRING
|
||||
{
|
||||
// ident eq string
|
||||
$$ = labels.Label{Name: $1.Val, Value: yylex.(*parser).unquoteString($3.Val) } }
|
||||
// | STRING EQL STRING
|
||||
// {
|
||||
// // string eq string
|
||||
// $$ = labels.Label{Name: yylex.(*parser).unquoteString($3.Val), Value: yylex.(*parser).unquoteString($3.Val) } }
|
||||
// | STRING
|
||||
// {
|
||||
// // looks good?
|
||||
// $$ = labels.Label{Name: labels.MetricName, Value: yylex.(*parser).unquoteString($1.Val) } }
|
||||
{ $$ = labels.Label{Name: $1.Val, Value: yylex.(*parser).unquoteString($3.Val) } }
|
||||
| IDENTIFIER EQL error
|
||||
{ yylex.(*parser).unexpected("label set", "string"); $$ = labels.Label{}}
|
||||
| IDENTIFIER error
|
||||
|
@ -925,7 +909,6 @@ string_literal : STRING
|
|||
|
||||
string_identifier : STRING
|
||||
{
|
||||
// string_identifier
|
||||
$$ = Item{
|
||||
Typ: METRIC_IDENTIFIER,
|
||||
Pos: $1.PositionRange().Start,
|
||||
|
|
|
@ -1404,7 +1404,10 @@ yydefault:
|
|||
case 85:
|
||||
yyDollar = yyS[yypt-3 : yypt+1]
|
||||
{
|
||||
// label_matchers
|
||||
// name := yylex.(*parser).findNameMatcher($2)
|
||||
yyVAL.node = &VectorSelector{
|
||||
// Name: name,
|
||||
LabelMatchers: yyDollar[2].matchers,
|
||||
PosRange: mergeRanges(&yyDollar[1].item, &yyDollar[3].item),
|
||||
}
|
||||
|
@ -1412,7 +1415,9 @@ yydefault:
|
|||
case 86:
|
||||
yyDollar = yyS[yypt-4 : yypt+1]
|
||||
{
|
||||
// name := yylex.(*parser).findNameMatcher($2)
|
||||
yyVAL.node = &VectorSelector{
|
||||
// Name: name,
|
||||
LabelMatchers: yyDollar[2].matchers,
|
||||
PosRange: mergeRanges(&yyDollar[1].item, &yyDollar[4].item),
|
||||
}
|
||||
|
|
|
@ -403,6 +403,8 @@ func (p *parser) newBinaryExpression(lhs Node, op Item, modifiers, rhs Node) *Bi
|
|||
}
|
||||
|
||||
func (p *parser) assembleVectorSelector(vs *VectorSelector) {
|
||||
// If the metric name was set outside the braces, add a matcher for it.
|
||||
// If the metric name was inside the braces we don't need to do anything.
|
||||
if vs.Name != "" {
|
||||
nameMatcher, err := labels.NewMatcher(labels.MatchEqual, labels.MetricName, vs.Name)
|
||||
if err != nil {
|
||||
|
|
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue