Chromium Code Reviews| Index: content/browser/renderer_host/media/media_stream_track_metrics_host.h |
| diff --git a/content/browser/renderer_host/media/media_stream_track_metrics_host.h b/content/browser/renderer_host/media/media_stream_track_metrics_host.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..9dd5de83a910e46db22337a1e07e2db0f8ec7c7e |
| --- /dev/null |
| +++ b/content/browser/renderer_host/media/media_stream_track_metrics_host.h |
| @@ -0,0 +1,67 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#ifndef CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_TRACK_METRICS_HOST_H_ |
|
perkj_chrome
2014/03/12 07:12:40
nit : git mv is the reviewers friend I think.Or lo
Jói
2014/03/12 08:50:04
I used git mv, indirectly. There are two problems:
|
| +#define CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_TRACK_METRICS_HOST_H_ |
| + |
| +#include <map> |
| +#include <string> |
| + |
| +#include "base/time/time.h" |
| +#include "content/public/browser/browser_message_filter.h" |
| +#include "content/public/browser/render_process_host_observer.h" |
| + |
| +namespace content { |
| + |
| +// Responsible for logging metrics about audio and video track |
| +// lifetimes. These are based on messages from the renderer that are |
| +// sent when tracks are created and destroyed. Unfortunately we can't |
| +// reliably log the lifetime metric in the renderer because that |
| +// process may be destroyed at any time by the fast shutdown path (see |
| +// RenderProcessHost::FastShutdownIfPossible). |
| +// |
| +// There is one instance of this class per render process. |
| +// |
| +// If the renderer process goes away without sending messages that |
| +// tracks were removed, this class instead infers that the tracks were |
| +// removed. |
| +class MediaStreamTrackMetricsHost |
| + : public BrowserMessageFilter, |
| + public RenderProcessHostObserver { |
| + public: |
| + explicit MediaStreamTrackMetricsHost(RenderProcessHost* owner); |
| + |
| + protected: |
| + virtual ~MediaStreamTrackMetricsHost(); |
| + |
| + // BrowserMessageFilter override. |
| + virtual bool OnMessageReceived(const IPC::Message& message, |
| + bool* message_was_ok) OVERRIDE; |
| + |
| + // RenderProcessHostObserver override. |
| + virtual void RenderProcessExited(RenderProcessHost* host, |
| + base::ProcessHandle handle, |
| + base::TerminationStatus status, |
| + int exit_code) OVERRIDE; |
| + |
| + private: |
| + void OnAddTrack(const std::string& id, bool is_audio, bool is_remote); |
| + void OnRemoveTrack(const std::string& id); |
| + |
| + void ReportDuration(bool is_audio, base::TimeTicks start_time); |
| + |
| + // Keys are track IDs, values are pairs: A boolean indicating |
| + // whether the track is an audio track, and a timestamp from when |
| + // the track was created. |
| + typedef std::pair<bool, base::TimeTicks> IsAudioPlusTimestamp; |
| + typedef std::map<std::string, IsAudioPlusTimestamp> TrackMap; |
| + TrackMap tracks_; |
| + |
| + // Non-owning pointer. |
| + RenderProcessHost* owner_; |
| +}; |
| + |
| +} // namespace content |
| + |
| +#endif // CONTENT_BROWSER_RENDERER_HOST_MEDIA_MEDIA_STREAM_TRACK_METRICS_HOST_H_ |