Index: webrtc/stats/rtcstats.cc |
diff --git a/webrtc/stats/rtcstats.cc b/webrtc/stats/rtcstats.cc |
index 5d0a937e6f31c12abadc55fa95be9adfb4fac6da..20a3eeb7105492ac5577799708f3daaaa8132983 100644 |
--- a/webrtc/stats/rtcstats.cc |
+++ b/webrtc/stats/rtcstats.cc |
@@ -10,6 +10,7 @@ |
#include "webrtc/api/stats/rtcstats.h" |
+#include <iomanip> |
#include <sstream> |
#include "webrtc/rtc_base/stringencode.h" |
@@ -18,33 +19,56 @@ namespace webrtc { |
namespace { |
-// Produces "{ a, b, c }". Works for non-vector |RTCStatsMemberInterface::Type| |
+// Produces "[ a, b, c ]". Works for non-vector |RTCStatsMemberInterface::Type| |
hbos
2017/07/28 09:30:58
nit: Remove spaces from the example in the comment
|
// types. |
template<typename T> |
std::string VectorToString(const std::vector<T>& vector) { |
if (vector.empty()) |
- return "{}"; |
+ return "[]"; |
std::ostringstream oss; |
- oss << "{ " << rtc::ToString<T>(vector[0]); |
+ oss << "[" << rtc::ToString<T>(vector[0]); |
for (size_t i = 1; i < vector.size(); ++i) { |
- oss << ", " << rtc::ToString<T>(vector[i]); |
+ oss << "," << rtc::ToString<T>(vector[i]); |
} |
- oss << " }"; |
+ oss << "]"; |
return oss.str(); |
} |
-// Produces "{ \"a\", \"b\", \"c\" }". Works for vectors of both const char* and |
+// Produces "[ \"a\", \"b\", \"c\" ]". Works for vectors of both const char* and |
hbos
2017/07/28 09:30:58
nit: And here.
|
// std::string element types. |
template<typename T> |
std::string VectorOfStringsToString(const std::vector<T>& strings) { |
if (strings.empty()) |
- return "{}"; |
+ return "[]"; |
std::ostringstream oss; |
- oss << "{ \"" << rtc::ToString<T>(strings[0]) << '\"'; |
+ oss << "[\"" << rtc::ToString<T>(strings[0]) << '\"'; |
for (size_t i = 1; i < strings.size(); ++i) { |
- oss << ", \"" << rtc::ToString<T>(strings[i]) << '\"'; |
+ oss << ",\"" << rtc::ToString<T>(strings[i]) << '\"'; |
} |
- oss << " }"; |
+ oss << "]"; |
+ return oss.str(); |
+} |
+ |
+template <typename T> |
+std::string ToStringAsDouble(const T value) { |
+ // JSON represents numbers as floating point numbers with about 15 decimal |
+ // digits of precision. |
+ const int JSON_PRECISION = 16; |
+ std::ostringstream oss; |
+ oss << std::setprecision(JSON_PRECISION) << static_cast<double>(value); |
+ return oss.str(); |
+} |
+ |
+template <typename T> |
+std::string VectorToStringAsDouble(const std::vector<T>& vector) { |
+ if (vector.empty()) |
+ return "[]"; |
+ std::ostringstream oss; |
+ oss << "[" << ToStringAsDouble<T>(vector[0]); |
+ for (size_t i = 1; i < vector.size(); ++i) { |
+ oss << "," << ToStringAsDouble<T>(vector[i]); |
+ } |
+ oss << "]"; |
return oss.str(); |
} |
@@ -71,22 +95,21 @@ bool RTCStats::operator!=(const RTCStats& other) const { |
return !(*this == other); |
} |
-std::string RTCStats::ToString() const { |
+std::string RTCStats::ToJson() const { |
std::ostringstream oss; |
- oss << type() << " {\n id: \"" << id_ << "\"\n timestamp: " |
- << timestamp_us_ << '\n'; |
+ oss << "{\"type\":\"" << type() << "\"," |
+ << "\"id\":\"" << id_ << "\"," |
+ << "\"timestamp\":" << timestamp_us_; |
for (const RTCStatsMemberInterface* member : Members()) { |
- oss << " " << member->name() << ": "; |
if (member->is_defined()) { |
+ oss << ",\"" << member->name() << "\":"; |
if (member->is_string()) |
- oss << '"' << member->ValueToString() << "\"\n"; |
+ oss << '"' << member->ValueToJson() << '"'; |
else |
- oss << member->ValueToString() << '\n'; |
- } else { |
- oss << "undefined\n"; |
+ oss << member->ValueToJson(); |
} |
} |
- oss << '}'; |
+ oss << "}"; |
return oss.str(); |
} |
@@ -102,54 +125,112 @@ RTCStats::MembersOfThisObjectAndAncestors( |
return members; |
} |
-#define WEBRTC_DEFINE_RTCSTATSMEMBER(T, type, is_seq, is_str, to_str) \ |
- template<> \ |
+#define WEBRTC_DEFINE_RTCSTATSMEMBER(T, type, is_seq, is_str, to_str, to_json) \ |
+ template <> \ |
const RTCStatsMemberInterface::Type RTCStatsMember<T>::kType = \ |
RTCStatsMemberInterface::type; \ |
- template<> \ |
- bool RTCStatsMember<T>::is_sequence() const { return is_seq; } \ |
- template<> \ |
- bool RTCStatsMember<T>::is_string() const { return is_str; } \ |
- template<> \ |
+ template <> \ |
+ bool RTCStatsMember<T>::is_sequence() const { \ |
+ return is_seq; \ |
+ } \ |
+ template <> \ |
+ bool RTCStatsMember<T>::is_string() const { \ |
+ return is_str; \ |
+ } \ |
+ template <> \ |
std::string RTCStatsMember<T>::ValueToString() const { \ |
RTC_DCHECK(is_defined_); \ |
return to_str; \ |
+ } \ |
+ template <> \ |
+ std::string RTCStatsMember<T>::ValueToJson() const { \ |
+ RTC_DCHECK(is_defined_); \ |
+ return to_json; \ |
} |
-WEBRTC_DEFINE_RTCSTATSMEMBER(bool, kBool, false, false, |
- rtc::ToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER(int32_t, kInt32, false, false, |
- rtc::ToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER(uint32_t, kUint32, false, false, |
- rtc::ToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER(int64_t, kInt64, false, false, |
+WEBRTC_DEFINE_RTCSTATSMEMBER(bool, |
+ kBool, |
+ false, |
+ false, |
+ rtc::ToString(value_), |
rtc::ToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER(uint64_t, kUint64, false, false, |
+WEBRTC_DEFINE_RTCSTATSMEMBER(int32_t, |
+ kInt32, |
+ false, |
+ false, |
+ rtc::ToString(value_), |
rtc::ToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER(double, kDouble, false, false, |
+WEBRTC_DEFINE_RTCSTATSMEMBER(uint32_t, |
+ kUint32, |
+ false, |
+ false, |
+ rtc::ToString(value_), |
rtc::ToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER(std::string, kString, false, true, |
+WEBRTC_DEFINE_RTCSTATSMEMBER(int64_t, |
+ kInt64, |
+ false, |
+ false, |
+ rtc::ToString(value_), |
+ ToStringAsDouble(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(uint64_t, |
+ kUint64, |
+ false, |
+ false, |
+ rtc::ToString(value_), |
+ ToStringAsDouble(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(double, |
+ kDouble, |
+ false, |
+ false, |
+ rtc::ToString(value_), |
+ ToStringAsDouble(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::string, |
+ kString, |
+ false, |
+ true, |
+ value_, |
value_); |
-WEBRTC_DEFINE_RTCSTATSMEMBER( |
- std::vector<bool>, kSequenceBool, true, false, |
- VectorToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER( |
- std::vector<int32_t>, kSequenceInt32, true, false, |
- VectorToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER( |
- std::vector<uint32_t>, kSequenceUint32, true, false, |
- VectorToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER( |
- std::vector<int64_t>, kSequenceInt64, true, false, |
- VectorToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER( |
- std::vector<uint64_t>, kSequenceUint64, true, false, |
- VectorToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER( |
- std::vector<double>, kSequenceDouble, true, false, |
- VectorToString(value_)); |
-WEBRTC_DEFINE_RTCSTATSMEMBER( |
- std::vector<std::string>, kSequenceString, true, false, |
- VectorOfStringsToString(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::vector<bool>, |
+ kSequenceBool, |
+ true, |
+ false, |
+ VectorToString(value_), |
+ VectorToString(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::vector<int32_t>, |
+ kSequenceInt32, |
+ true, |
+ false, |
+ VectorToString(value_), |
+ VectorToString(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::vector<uint32_t>, |
+ kSequenceUint32, |
+ true, |
+ false, |
+ VectorToString(value_), |
+ VectorToString(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::vector<int64_t>, |
+ kSequenceInt64, |
+ true, |
+ false, |
+ VectorToString(value_), |
+ VectorToStringAsDouble(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::vector<uint64_t>, |
+ kSequenceUint64, |
+ true, |
+ false, |
+ VectorToString(value_), |
+ VectorToStringAsDouble(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::vector<double>, |
+ kSequenceDouble, |
+ true, |
+ false, |
+ VectorToString(value_), |
+ VectorToStringAsDouble(value_)); |
+WEBRTC_DEFINE_RTCSTATSMEMBER(std::vector<std::string>, |
+ kSequenceString, |
+ true, |
+ false, |
+ VectorOfStringsToString(value_), |
+ VectorOfStringsToString(value_)); |
} // namespace webrtc |