Chromium Code Reviews| Index: chrome/browser/media/router/presentation_frame_map.cc |
| diff --git a/chrome/browser/media/router/presentation_frame_map.cc b/chrome/browser/media/router/presentation_frame_map.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..1dbdfcdc7b5381d312b87847d16b32a035103ad1 |
| --- /dev/null |
| +++ b/chrome/browser/media/router/presentation_frame_map.cc |
| @@ -0,0 +1,106 @@ |
| +// Copyright 2015 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. |
| + |
| +#include "chrome/browser/media/router/presentation_frame_map.h" |
| + |
| +#include "chrome/browser/media/router/media_router.h" |
| +#include "chrome/browser/media/router/media_router_impl_factory.h" |
| +#include "chrome/browser/media/router/presentation_frame.h" |
| +#include "chrome/browser/media/router/presentation_media_sinks_observer.h" |
| + |
| +namespace media_router { |
| + |
| +PresentationFrameMap::PresentationFrameMap(content::WebContents* web_contents) |
| + : web_contents_(web_contents), |
| + router_(MediaRouterImplFactory::GetMediaRouterForBrowserContext( |
| + web_contents_->GetBrowserContext())) { |
| + DCHECK(router_); |
| +} |
| + |
| +PresentationFrameMap::~PresentationFrameMap() { |
| +} |
| + |
| +bool PresentationFrameMap::AddScreenAvailabilityListener( |
| + int render_process_id, |
| + int render_frame_id, |
| + content::PresentationScreenAvailabilityListener* listener) { |
| + if (num_sink_observers_ >= kMaxNumSources) { |
|
mark a. foltz
2015/05/14 22:20:45
I would rename this to num_screen_availability_lis
haibinlu
2015/05/15 23:32:29
Done.
|
| + return false; |
| + } |
| + |
| + RenderFrameHostId rfh_id(render_process_id, render_frame_id); |
| + auto frame = GetOrAddFrame(rfh_id); |
|
mark a. foltz
2015/05/14 22:20:45
presentation_frame here and below (so as not to co
haibinlu
2015/05/15 23:32:29
Done.
|
| + if (frame->AddScreenAvailabilityListener(listener)) { |
| + num_sink_observers_++; |
| + return true; |
| + } |
| + return false; |
| +} |
| + |
| +void PresentationFrameMap::RemoveScreenAvailabilityListener( |
| + int render_process_id, |
| + int render_frame_id, |
| + content::PresentationScreenAvailabilityListener* listener) { |
| + DCHECK(listener); |
| + |
| + RenderFrameHostId rfh_id(render_process_id, render_frame_id); |
| + auto frame = frames_.get(rfh_id); |
| + if (frame && frame->RemoveScreenAvailabilityListener(listener)) { |
| + num_sink_observers_--; |
| + return true; |
| + } |
| + return false; |
| +} |
| + |
| +void PresentationFrameMap::SetDefaultPresentationInfo( |
| + int render_process_id, |
| + int render_frame_id, |
| + const std::string& default_presentation_url, |
| + const std::string& default_presentation_id) { |
| + RenderFrameHostId rfh_id(render_process_id, render_frame_id); |
| + auto frame = GetOrAddFrame(rfh_id); |
| + frame->SetDefaultPresentationInfo(default_presentation_url, |
| + default_presentation_id); |
| +} |
| + |
| +std::string PresentationFrameMap::GetDefaultPresentationId( |
| + RenderFrameHostId rfh_id) const { |
| + auto frame = frames_.get(rfh_id); |
| + return frame ? frame->GetDefaultPresentationId() : ""; |
| +} |
| + |
| +void PresentationFrameMap::SetDelegateObserver( |
| + int render_process_id, |
| + int render_frame_id, |
| + content::PresentationServiceDelegate::Observer* observer) { |
| + RenderFrameHostId rfh_id(render_process_id, render_frame_id); |
| + auto frame = GetOrAddFrame(rfh_id); |
| + frame->SetDelegateObserver(observer); |
| +} |
| + |
| +DelegateObserver* PresentationFrameMap::GetDelegateObserver( |
| + RenderFrameHostId rfh_id) const { |
| + auto frame = frames_.get(rfh_id); |
| + return frame ? frame->GetDelegateObserver(observer) : NULL; |
| +} |
| + |
| +void PresentationFrameMap::Reset(int render_process_id, int render_frame_id) { |
| + RenderFrameHostId rfh_id(render_process_id, render_frame_id); |
| + auto frame = frames_.get(rfh_id); |
| + if (frame) { |
|
mark a. foltz
2015/05/14 22:20:45
Omit { } on single-line if's
|
| + frame->Reset(); |
| + } |
| +} |
| + |
| +scoped_ptr<PresentationFrame>* PresentationFrameMap::GetOrAddFrame( |
| + RenderFrameHostId rfh_id) { |
| + auto frame = frames_.get(rfh_id); |
| + if (!frames_.contains(rfh_id)) { |
| + frames_.add(rfh_id, |
| + scoped_ptr<PresentationFrame>(new PresentationFrame(web_contents)); |
| + } |
| + return frames_.get(rfh_id); |
| +} |
| + |
| +} // namespace media_router |