// Code generated by qtc from "query_range_response.qtpl". DO NOT EDIT. // See https://github.com/valyala/quicktemplate for details. //line app/vmselect/prometheus/query_range_response.qtpl:1 package prometheus //line app/vmselect/prometheus/query_range_response.qtpl:1 import ( "github.com/VictoriaMetrics/VictoriaMetrics/app/vmselect/netstorage" "github.com/VictoriaMetrics/VictoriaMetrics/app/vmselect/promql" "github.com/VictoriaMetrics/VictoriaMetrics/lib/querytracer" ) // QueryRangeResponse generates response for /api/v1/query_range.See https://prometheus.io/docs/prometheus/latest/querying/api/#range-queries //line app/vmselect/prometheus/query_range_response.qtpl:10 import ( qtio422016 "io" qt422016 "github.com/valyala/quicktemplate" ) //line app/vmselect/prometheus/query_range_response.qtpl:10 var ( _ = qtio422016.Copy _ = qt422016.AcquireByteBuffer ) //line app/vmselect/prometheus/query_range_response.qtpl:10 func StreamQueryRangeResponse(qw422016 *qt422016.Writer, isPartial bool, rs []netstorage.Result, qt *querytracer.Tracer, qtDone func(), qs *promql.QueryStats) { //line app/vmselect/prometheus/query_range_response.qtpl:10 qw422016.N().S(`{`) //line app/vmselect/prometheus/query_range_response.qtpl:13 seriesCount := len(rs) pointsCount := 0 //line app/vmselect/prometheus/query_range_response.qtpl:15 qw422016.N().S(`"status":"success","isPartial":`) //line app/vmselect/prometheus/query_range_response.qtpl:17 if isPartial { //line app/vmselect/prometheus/query_range_response.qtpl:17 qw422016.N().S(`true`) //line app/vmselect/prometheus/query_range_response.qtpl:17 } else { //line app/vmselect/prometheus/query_range_response.qtpl:17 qw422016.N().S(`false`) //line app/vmselect/prometheus/query_range_response.qtpl:17 } //line app/vmselect/prometheus/query_range_response.qtpl:17 qw422016.N().S(`,"data":{"resultType":"matrix","result":[`) //line app/vmselect/prometheus/query_range_response.qtpl:21 if len(rs) > 0 { //line app/vmselect/prometheus/query_range_response.qtpl:22 streamqueryRangeLine(qw422016, &rs[0]) //line app/vmselect/prometheus/query_range_response.qtpl:23 pointsCount += len(rs[0].Values) //line app/vmselect/prometheus/query_range_response.qtpl:24 rs = rs[1:] //line app/vmselect/prometheus/query_range_response.qtpl:25 for i := range rs { //line app/vmselect/prometheus/query_range_response.qtpl:25 qw422016.N().S(`,`) //line app/vmselect/prometheus/query_range_response.qtpl:26 streamqueryRangeLine(qw422016, &rs[i]) //line app/vmselect/prometheus/query_range_response.qtpl:27 pointsCount += len(rs[i].Values) //line app/vmselect/prometheus/query_range_response.qtpl:28 } //line app/vmselect/prometheus/query_range_response.qtpl:29 } //line app/vmselect/prometheus/query_range_response.qtpl:29 qw422016.N().S(`]},"stats":{`) //line app/vmselect/prometheus/query_range_response.qtpl:34 // seriesFetched is string instead of int because of historical reasons. // It cannot be converted to int without breaking backwards compatibility at vmalert :( //line app/vmselect/prometheus/query_range_response.qtpl:36 qw422016.N().S(`"seriesFetched": "`) //line app/vmselect/prometheus/query_range_response.qtpl:37 qw422016.N().DL(qs.SeriesFetched.Load()) //line app/vmselect/prometheus/query_range_response.qtpl:37 qw422016.N().S(`","executionTimeMsec":`) //line app/vmselect/prometheus/query_range_response.qtpl:38 qw422016.N().DL(qs.ExecutionTimeMsec.Load()) //line app/vmselect/prometheus/query_range_response.qtpl:38 qw422016.N().S(`}`) //line app/vmselect/prometheus/query_range_response.qtpl:41 qt.Printf("generate /api/v1/query_range response for series=%d, points=%d", seriesCount, pointsCount) qtDone() //line app/vmselect/prometheus/query_range_response.qtpl:44 streamdumpQueryTrace(qw422016, qt) //line app/vmselect/prometheus/query_range_response.qtpl:44 qw422016.N().S(`}`) //line app/vmselect/prometheus/query_range_response.qtpl:46 } //line app/vmselect/prometheus/query_range_response.qtpl:46 func WriteQueryRangeResponse(qq422016 qtio422016.Writer, isPartial bool, rs []netstorage.Result, qt *querytracer.Tracer, qtDone func(), qs *promql.QueryStats) { //line app/vmselect/prometheus/query_range_response.qtpl:46 qw422016 := qt422016.AcquireWriter(qq422016) //line app/vmselect/prometheus/query_range_response.qtpl:46 StreamQueryRangeResponse(qw422016, isPartial, rs, qt, qtDone, qs) //line app/vmselect/prometheus/query_range_response.qtpl:46 qt422016.ReleaseWriter(qw422016) //line app/vmselect/prometheus/query_range_response.qtpl:46 } //line app/vmselect/prometheus/query_range_response.qtpl:46 func QueryRangeResponse(isPartial bool, rs []netstorage.Result, qt *querytracer.Tracer, qtDone func(), qs *promql.QueryStats) string { //line app/vmselect/prometheus/query_range_response.qtpl:46 qb422016 := qt422016.AcquireByteBuffer() //line app/vmselect/prometheus/query_range_response.qtpl:46 WriteQueryRangeResponse(qb422016, isPartial, rs, qt, qtDone, qs) //line app/vmselect/prometheus/query_range_response.qtpl:46 qs422016 := string(qb422016.B) //line app/vmselect/prometheus/query_range_response.qtpl:46 qt422016.ReleaseByteBuffer(qb422016) //line app/vmselect/prometheus/query_range_response.qtpl:46 return qs422016 //line app/vmselect/prometheus/query_range_response.qtpl:46 } //line app/vmselect/prometheus/query_range_response.qtpl:48 func streamqueryRangeLine(qw422016 *qt422016.Writer, r *netstorage.Result) { //line app/vmselect/prometheus/query_range_response.qtpl:48 qw422016.N().S(`{"metric":`) //line app/vmselect/prometheus/query_range_response.qtpl:50 streammetricNameObject(qw422016, &r.MetricName) //line app/vmselect/prometheus/query_range_response.qtpl:50 qw422016.N().S(`,"values":`) //line app/vmselect/prometheus/query_range_response.qtpl:51 streamvaluesWithTimestamps(qw422016, r.Values, r.Timestamps) //line app/vmselect/prometheus/query_range_response.qtpl:51 qw422016.N().S(`}`) //line app/vmselect/prometheus/query_range_response.qtpl:53 } //line app/vmselect/prometheus/query_range_response.qtpl:53 func writequeryRangeLine(qq422016 qtio422016.Writer, r *netstorage.Result) { //line app/vmselect/prometheus/query_range_response.qtpl:53 qw422016 := qt422016.AcquireWriter(qq422016) //line app/vmselect/prometheus/query_range_response.qtpl:53 streamqueryRangeLine(qw422016, r) //line app/vmselect/prometheus/query_range_response.qtpl:53 qt422016.ReleaseWriter(qw422016) //line app/vmselect/prometheus/query_range_response.qtpl:53 } //line app/vmselect/prometheus/query_range_response.qtpl:53 func queryRangeLine(r *netstorage.Result) string { //line app/vmselect/prometheus/query_range_response.qtpl:53 qb422016 := qt422016.AcquireByteBuffer() //line app/vmselect/prometheus/query_range_response.qtpl:53 writequeryRangeLine(qb422016, r) //line app/vmselect/prometheus/query_range_response.qtpl:53 qs422016 := string(qb422016.B) //line app/vmselect/prometheus/query_range_response.qtpl:53 qt422016.ReleaseByteBuffer(qb422016) //line app/vmselect/prometheus/query_range_response.qtpl:53 return qs422016 //line app/vmselect/prometheus/query_range_response.qtpl:53 }