| /* | 
 |  *  Copyright 2016 The WebRTC Project Authors. All rights reserved. | 
 |  * | 
 |  *  Use of this source code is governed by a BSD-style license | 
 |  *  that can be found in the LICENSE file in the root of the source | 
 |  *  tree. An additional intellectual property rights grant can be found | 
 |  *  in the file PATENTS.  All contributing project authors may | 
 |  *  be found in the AUTHORS file in the root of the source tree. | 
 |  */ | 
 |  | 
 | #ifndef API_STATS_RTC_STATS_REPORT_H_ | 
 | #define API_STATS_RTC_STATS_REPORT_H_ | 
 |  | 
 | #include <stddef.h> | 
 | #include <stdint.h> | 
 |  | 
 | #include <map> | 
 | #include <memory> | 
 | #include <string> | 
 | #include <utility> | 
 | #include <vector> | 
 |  | 
 | #include "api/ref_counted_base.h" | 
 | #include "api/scoped_refptr.h" | 
 | #include "api/stats/rtc_stats.h" | 
 | #include "api/units/timestamp.h" | 
 | #include "rtc_base/system/rtc_export.h" | 
 |  | 
 | namespace webrtc { | 
 |  | 
 | // A collection of stats. | 
 | // This is accessible as a map from `RTCStats::id` to `RTCStats`. | 
 | class RTC_EXPORT RTCStatsReport final | 
 |     : public RefCountedNonVirtual<RTCStatsReport> { | 
 |  public: | 
 |   typedef std::map<std::string, std::unique_ptr<const RTCStats>> StatsMap; | 
 |  | 
 |   class RTC_EXPORT ConstIterator { | 
 |    public: | 
 |     ConstIterator(ConstIterator&& other); | 
 |     ~ConstIterator(); | 
 |  | 
 |     ConstIterator& operator++(); | 
 |     ConstIterator& operator++(int); | 
 |     const RTCStats& operator*() const; | 
 |     const RTCStats* operator->() const; | 
 |     bool operator==(const ConstIterator& other) const; | 
 |     bool operator!=(const ConstIterator& other) const; | 
 |  | 
 |    private: | 
 |     friend class RTCStatsReport; | 
 |     ConstIterator(const scoped_refptr<const RTCStatsReport>& report, | 
 |                   StatsMap::const_iterator it); | 
 |  | 
 |     // Reference report to make sure it is kept alive. | 
 |     scoped_refptr<const RTCStatsReport> report_; | 
 |     StatsMap::const_iterator it_; | 
 |   }; | 
 |  | 
 |   static scoped_refptr<RTCStatsReport> Create(Timestamp timestamp); | 
 |  | 
 |   explicit RTCStatsReport(Timestamp timestamp); | 
 |  | 
 |   RTCStatsReport(const RTCStatsReport& other) = delete; | 
 |   scoped_refptr<RTCStatsReport> Copy() const; | 
 |  | 
 |   Timestamp timestamp() const { return timestamp_; } | 
 |   void AddStats(std::unique_ptr<const RTCStats> stats); | 
 |   // On success, returns a non-owning pointer to `stats`. If the stats ID is not | 
 |   // unique, `stats` is not inserted and nullptr is returned. | 
 |   template <typename T> | 
 |   T* TryAddStats(std::unique_ptr<T> stats) { | 
 |     T* stats_ptr = stats.get(); | 
 |     if (!stats_ | 
 |              .insert(std::make_pair(std::string(stats->id()), std::move(stats))) | 
 |              .second) { | 
 |       return nullptr; | 
 |     } | 
 |     return stats_ptr; | 
 |   } | 
 |   const RTCStats* Get(const std::string& id) const; | 
 |   size_t size() const { return stats_.size(); } | 
 |  | 
 |   // Gets the stat object of type `T` by ID, where `T` is any class descending | 
 |   // from `RTCStats`. | 
 |   // Returns null if there is no stats object for the given ID or it is the | 
 |   // wrong type. | 
 |   template <typename T> | 
 |   const T* GetAs(const std::string& id) const { | 
 |     const RTCStats* stats = Get(id); | 
 |     if (!stats || stats->type() != T::kType) { | 
 |       return nullptr; | 
 |     } | 
 |     return &stats->cast_to<const T>(); | 
 |   } | 
 |  | 
 |   // Removes the stats object from the report, returning ownership of it or null | 
 |   // if there is no object with `id`. | 
 |   std::unique_ptr<const RTCStats> Take(const std::string& id); | 
 |   // Takes ownership of all the stats in `other`, leaving it empty. | 
 |   void TakeMembersFrom(scoped_refptr<RTCStatsReport> other); | 
 |  | 
 |   // Stats iterators. Stats are ordered lexicographically on `RTCStats::id`. | 
 |   ConstIterator begin() const; | 
 |   ConstIterator end() const; | 
 |  | 
 |   // Gets the subset of stats that are of type `T`, where `T` is any class | 
 |   // descending from `RTCStats`. | 
 |   template <typename T> | 
 |   std::vector<const T*> GetStatsOfType() const { | 
 |     std::vector<const T*> stats_of_type; | 
 |     for (const RTCStats& stats : *this) { | 
 |       if (stats.type() == T::kType) | 
 |         stats_of_type.push_back(&stats.cast_to<const T>()); | 
 |     } | 
 |     return stats_of_type; | 
 |   } | 
 |  | 
 |   // Creates a JSON readable string representation of the report, | 
 |   // listing all of its stats objects. | 
 |   std::string ToJson() const; | 
 |  | 
 |  protected: | 
 |   friend class RefCountedNonVirtual<RTCStatsReport>; | 
 |   ~RTCStatsReport() = default; | 
 |  | 
 |  private: | 
 |   Timestamp timestamp_; | 
 |   StatsMap stats_; | 
 | }; | 
 |  | 
 | }  // namespace webrtc | 
 |  | 
 | #endif  // API_STATS_RTC_STATS_REPORT_H_ |