/* * * 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