Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" | 5 #include "chrome/browser/media/router/presentation_service_delegate_impl.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <unordered_map> | 8 #include <unordered_map> |
| 9 #include <utility> | 9 #include <utility> |
| 10 #include <vector> | 10 #include <vector> |
| (...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 162 std::unique_ptr<PresentationConnectionStateSubscription>> | 162 std::unique_ptr<PresentationConnectionStateSubscription>> |
| 163 connection_state_subscriptions_; | 163 connection_state_subscriptions_; |
| 164 std::unordered_map< | 164 std::unordered_map< |
| 165 MediaRoute::Id, | 165 MediaRoute::Id, |
| 166 std::unique_ptr<PresentationSessionMessagesObserver>> | 166 std::unique_ptr<PresentationSessionMessagesObserver>> |
| 167 session_messages_observers_; | 167 session_messages_observers_; |
| 168 | 168 |
| 169 RenderFrameHostId render_frame_host_id_; | 169 RenderFrameHostId render_frame_host_id_; |
| 170 | 170 |
| 171 // References to the owning WebContents, and the corresponding MediaRouter. | 171 // References to the owning WebContents, and the corresponding MediaRouter. |
| 172 const content::WebContents* web_contents_; | 172 content::WebContents* web_contents_; |
| 173 MediaRouter* router_; | 173 MediaRouter* router_; |
| 174 }; | 174 }; |
| 175 | 175 |
| 176 PresentationFrame::PresentationFrame( | 176 PresentationFrame::PresentationFrame( |
| 177 const RenderFrameHostId& render_frame_host_id, | 177 const RenderFrameHostId& render_frame_host_id, |
| 178 content::WebContents* web_contents, | 178 content::WebContents* web_contents, |
| 179 MediaRouter* router) | 179 MediaRouter* router) |
| 180 : render_frame_host_id_(render_frame_host_id), | 180 : render_frame_host_id_(render_frame_host_id), |
| 181 web_contents_(web_contents), | 181 web_contents_(web_contents), |
| 182 router_(router) { | 182 router_(router) { |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 237 } | 237 } |
| 238 return false; | 238 return false; |
| 239 } | 239 } |
| 240 | 240 |
| 241 bool PresentationFrame::HasScreenAvailabilityListenerForTest( | 241 bool PresentationFrame::HasScreenAvailabilityListenerForTest( |
| 242 const MediaSource::Id& source_id) const { | 242 const MediaSource::Id& source_id) const { |
| 243 return url_to_sinks_observer_.find(source_id) != url_to_sinks_observer_.end(); | 243 return url_to_sinks_observer_.find(source_id) != url_to_sinks_observer_.end(); |
| 244 } | 244 } |
| 245 | 245 |
| 246 void PresentationFrame::Reset() { | 246 void PresentationFrame::Reset() { |
| 247 for (const auto& pid_route_id : presentation_id_to_route_id_) | 247 auto offscreen_presentation_manager = OffscreenPresentationManagerFactory:: |
| 248 GetOrCreateForControllerBrowserContext(web_contents_); | |
| 249 | |
| 250 for (const auto& pid_route_id : presentation_id_to_route_id_) { | |
| 251 offscreen_presentation_manager->UnregisterOffscreenPresentationController( | |
| 252 pid_route_id.first, render_frame_host_id_); | |
|
mark a. foltz
2016/11/16 01:25:37
Side comment: If we could ensure 1 route == 1 pres
| |
| 248 router_->DetachRoute(pid_route_id.second); | 253 router_->DetachRoute(pid_route_id.second); |
| 254 } | |
| 249 | 255 |
| 250 presentation_id_to_route_id_.clear(); | 256 presentation_id_to_route_id_.clear(); |
| 251 url_to_sinks_observer_.clear(); | 257 url_to_sinks_observer_.clear(); |
| 252 connection_state_subscriptions_.clear(); | 258 connection_state_subscriptions_.clear(); |
| 253 session_messages_observers_.clear(); | 259 session_messages_observers_.clear(); |
| 254 } | 260 } |
| 255 | 261 |
| 256 void PresentationFrame::RemoveConnection(const std::string& presentation_id, | 262 void PresentationFrame::RemoveConnection(const std::string& presentation_id, |
| 257 const MediaRoute::Id& route_id) { | 263 const MediaRoute::Id& route_id) { |
| 258 // Remove the presentation id mapping so a later call to Reset is a no-op. | 264 // Remove the presentation id mapping so a later call to Reset is a no-op. |
| (...skipping 692 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 951 bool PresentationServiceDelegateImpl::HasScreenAvailabilityListenerForTest( | 957 bool PresentationServiceDelegateImpl::HasScreenAvailabilityListenerForTest( |
| 952 int render_process_id, | 958 int render_process_id, |
| 953 int render_frame_id, | 959 int render_frame_id, |
| 954 const MediaSource::Id& source_id) const { | 960 const MediaSource::Id& source_id) const { |
| 955 RenderFrameHostId render_frame_host_id(render_process_id, render_frame_id); | 961 RenderFrameHostId render_frame_host_id(render_process_id, render_frame_id); |
| 956 return frame_manager_->HasScreenAvailabilityListenerForTest( | 962 return frame_manager_->HasScreenAvailabilityListenerForTest( |
| 957 render_frame_host_id, source_id); | 963 render_frame_host_id, source_id); |
| 958 } | 964 } |
| 959 | 965 |
| 960 } // namespace media_router | 966 } // namespace media_router |
| OLD | NEW |