// // // Copyright 2017 gRPC authors. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // // #include #include "src/core/lib/debug/stats.h" #include #include #include #include "absl/strings/str_cat.h" #include "absl/strings/str_join.h" namespace grpc_core { namespace stats_detail { namespace { template std::string ArrayToJson(absl::Span values) { std::vector parts; for (auto value : values) { parts.push_back(absl::StrCat(value)); } return absl::StrCat("[", absl::StrJoin(parts, ","), "]"); } } // namespace std::string StatsAsJson(absl::Span counters, absl::Span counter_name, absl::Span histograms, absl::Span histogram_name) { std::vector parts; for (size_t i = 0; i < counters.size(); i++) { parts.push_back(absl::StrCat("\"", counter_name[i], "\": ", counters[i])); } for (size_t i = 0; i < histograms.size(); i++) { parts.push_back( absl::StrCat("\"", histogram_name[i], "\": ", ArrayToJson(absl::Span( histograms[i].buckets, histograms[i].num_buckets)))); parts.push_back(absl::StrCat( "\"", histogram_name[i], "_bkt\": ", ArrayToJson(absl::Span(histograms[i].bucket_boundaries, histograms[i].num_buckets)))); } return absl::StrCat("{", absl::StrJoin(parts, ", "), "}"); } } // namespace stats_detail } // namespace grpc_core