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 "content/browser/presentation/presentation_service_impl.h" | 5 #include "content/browser/presentation/presentation_service_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <string> | 8 #include <string> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
195 return; | 195 return; |
196 | 196 |
197 scoped_ptr<ScreenAvailabilityListenerImpl> listener( | 197 scoped_ptr<ScreenAvailabilityListenerImpl> listener( |
198 new ScreenAvailabilityListenerImpl(availability_url, this)); | 198 new ScreenAvailabilityListenerImpl(availability_url, this)); |
199 if (delegate_->AddScreenAvailabilityListener( | 199 if (delegate_->AddScreenAvailabilityListener( |
200 render_process_id_, | 200 render_process_id_, |
201 render_frame_id_, | 201 render_frame_id_, |
202 listener.get())) { | 202 listener.get())) { |
203 screen_availability_listeners_.set(availability_url, listener.Pass()); | 203 screen_availability_listeners_.set(availability_url, listener.Pass()); |
204 } else { | 204 } else { |
205 DVLOG(1) << "AddScreenAvailabilityListener failed. Ignoring request."; | 205 DVLOG(1) << "AddScreenAvailabilityListener failed. Returning false."; |
206 client_->OnScreenAvailabilityUpdated(url, false); | |
206 } | 207 } |
207 } | 208 } |
208 | 209 |
209 void PresentationServiceImpl::StopListeningForScreenAvailability( | 210 void PresentationServiceImpl::StopListeningForScreenAvailability( |
210 const mojo::String& url) { | 211 const mojo::String& url) { |
211 DVLOG(2) << "StopListeningForScreenAvailability " << url; | 212 DVLOG(2) << "StopListeningForScreenAvailability " << url; |
212 if (!delegate_) | 213 if (!delegate_) |
213 return; | 214 return; |
214 | 215 |
215 const std::string& availability_url = url.get(); | 216 const std::string& availability_url = url.get(); |
216 auto listener_it = screen_availability_listeners_.find(availability_url); | 217 auto listener_it = screen_availability_listeners_.find(availability_url); |
217 if (listener_it == screen_availability_listeners_.end()) | 218 if (listener_it == screen_availability_listeners_.end()) |
218 return; | 219 return; |
219 | 220 |
220 delegate_->RemoveScreenAvailabilityListener( | 221 delegate_->RemoveScreenAvailabilityListener( |
221 render_process_id_, | 222 render_process_id_, |
222 render_frame_id_, | 223 render_frame_id_, |
223 listener_it->second); | 224 listener_it->second); |
224 screen_availability_listeners_.erase(listener_it); | 225 screen_availability_listeners_.erase(listener_it); |
225 } | 226 } |
226 | 227 |
227 void PresentationServiceImpl::ListenForDefaultSessionStart( | 228 void PresentationServiceImpl::ListenForDefaultSessionStart( |
228 const DefaultSessionMojoCallback& callback) { | 229 const PresentationSessionMojoCallback& callback) { |
229 if (!default_session_start_context_.get()) | 230 if (!default_session_start_context_.get()) |
230 default_session_start_context_.reset(new DefaultSessionStartContext); | 231 default_session_start_context_.reset(new DefaultSessionStartContext); |
231 default_session_start_context_->AddCallback(callback); | 232 default_session_start_context_->AddCallback(callback); |
232 } | 233 } |
233 | 234 |
234 void PresentationServiceImpl::StartSession( | 235 void PresentationServiceImpl::StartSession( |
235 const mojo::String& presentation_url, | 236 const mojo::String& presentation_url, |
236 const NewSessionMojoCallback& callback) { | 237 const NewSessionMojoCallback& callback) { |
237 DVLOG(2) << "StartSession"; | 238 DVLOG(2) << "StartSession"; |
238 if (!delegate_) { | 239 if (!delegate_) { |
(...skipping 211 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
450 if (!delegate_) | 451 if (!delegate_) |
451 return; | 452 return; |
452 | 453 |
453 PresentationSessionInfo session_info(session.To<PresentationSessionInfo>()); | 454 PresentationSessionInfo session_info(session.To<PresentationSessionInfo>()); |
454 delegate_->ListenForSessionMessages( | 455 delegate_->ListenForSessionMessages( |
455 render_process_id_, render_frame_id_, session_info, | 456 render_process_id_, render_frame_id_, session_info, |
456 base::Bind(&PresentationServiceImpl::OnSessionMessages, | 457 base::Bind(&PresentationServiceImpl::OnSessionMessages, |
457 weak_factory_.GetWeakPtr(), session_info)); | 458 weak_factory_.GetWeakPtr(), session_info)); |
458 } | 459 } |
459 | 460 |
461 void PresentationServiceImpl::GetPresentationReceiverSession( | |
462 const PresentationSessionMojoCallback& callback) { | |
463 DVLOG(2) << "GetPresentationReceiverSession"; | |
464 DCHECK(receiver_session_callback_.is_null()); | |
465 if (!delegate_) { | |
466 callback.Run(presentation::PresentationSessionInfoPtr()); | |
467 return; | |
468 } | |
469 | |
470 receiver_session_callback_ = callback; | |
miu
2015/10/07 21:51:46
Can there only be one call to GetPresentationRecei
imcheng
2015/10/10 04:39:43
It does need to be run before it is destroyed (see
| |
471 delegate_->GetPresentationReceiverSession( | |
472 render_process_id_, render_frame_id_, | |
473 base::Bind(&PresentationServiceImpl::OnGetPresentationReceiverSession, | |
474 weak_factory_.GetWeakPtr())); | |
475 } | |
476 | |
477 void PresentationServiceImpl::OnGetPresentationReceiverSession( | |
478 const content::PresentationSessionInfo* session_info) { | |
479 if (!receiver_session_callback_.is_null()) { | |
480 receiver_session_callback_.Run( | |
481 session_info | |
482 ? presentation::PresentationSessionInfo::From(*session_info) | |
483 : presentation::PresentationSessionInfoPtr()); | |
484 receiver_session_callback_.reset(); | |
485 } | |
486 } | |
487 | |
460 void PresentationServiceImpl::OnSessionMessages( | 488 void PresentationServiceImpl::OnSessionMessages( |
461 const PresentationSessionInfo& session, | 489 const PresentationSessionInfo& session, |
462 const ScopedVector<PresentationSessionMessage>& messages, | 490 const ScopedVector<PresentationSessionMessage>& messages, |
463 bool pass_ownership) { | 491 bool pass_ownership) { |
464 DCHECK(client_); | 492 DCHECK(client_); |
465 | 493 |
466 DVLOG(2) << "OnSessionMessages"; | 494 DVLOG(2) << "OnSessionMessages"; |
467 mojo::Array<presentation::SessionMessagePtr> mojoMessages(messages.size()); | 495 mojo::Array<presentation::SessionMessagePtr> mojoMessages(messages.size()); |
468 for (size_t i = 0; i < messages.size(); ++i) | 496 for (size_t i = 0; i < messages.size(); ++i) |
469 mojoMessages[i] = ToMojoSessionMessage(messages[i], pass_ownership); | 497 mojoMessages[i] = ToMojoSessionMessage(messages[i], pass_ownership); |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
518 screen_availability_listeners_.clear(); | 546 screen_availability_listeners_.clear(); |
519 session_state_listeners_.clear(); | 547 session_state_listeners_.clear(); |
520 | 548 |
521 start_session_request_id_ = kInvalidRequestSessionId; | 549 start_session_request_id_ = kInvalidRequestSessionId; |
522 pending_start_session_cb_.reset(); | 550 pending_start_session_cb_.reset(); |
523 | 551 |
524 pending_join_session_cbs_.clear(); | 552 pending_join_session_cbs_.clear(); |
525 | 553 |
526 default_session_start_context_.reset(); | 554 default_session_start_context_.reset(); |
527 | 555 |
528 if (on_session_messages_callback_.get()) { | 556 if (on_session_messages_callback_) { |
529 on_session_messages_callback_->Run( | 557 on_session_messages_callback_->Run( |
530 mojo::Array<presentation::SessionMessagePtr>()); | 558 mojo::Array<presentation::SessionMessagePtr>()); |
531 on_session_messages_callback_.reset(); | 559 on_session_messages_callback_.reset(); |
532 } | 560 } |
533 | 561 |
534 if (send_message_callback_) { | 562 if (send_message_callback_) { |
535 // Run the callback with false, indicating the renderer to stop sending | 563 // Run the callback with false, indicating the renderer to stop sending |
536 // the requests and invalidate all pending requests. | 564 // the requests and invalidate all pending requests. |
537 send_message_callback_->Run(false); | 565 send_message_callback_->Run(false); |
538 send_message_callback_.reset(); | 566 send_message_callback_.reset(); |
539 } | 567 } |
568 | |
569 if (!receiver_session_callback_.is_null()) { | |
570 receiver_session_callback_.Run(presentation::PresentationSessionInfoPtr()); | |
571 receiver_session_callback_.reset(); | |
572 } | |
540 } | 573 } |
541 | 574 |
542 void PresentationServiceImpl::OnDelegateDestroyed() { | 575 void PresentationServiceImpl::OnDelegateDestroyed() { |
543 DVLOG(2) << "PresentationServiceImpl::OnDelegateDestroyed"; | 576 DVLOG(2) << "PresentationServiceImpl::OnDelegateDestroyed"; |
544 delegate_ = nullptr; | 577 delegate_ = nullptr; |
545 Reset(); | 578 Reset(); |
546 } | 579 } |
547 | 580 |
548 void PresentationServiceImpl::OnDefaultPresentationStarted( | 581 void PresentationServiceImpl::OnDefaultPresentationStarted( |
549 const PresentationSessionInfo& session) { | 582 const PresentationSessionInfo& session) { |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
625 PresentationServiceImpl::DefaultSessionStartContext | 658 PresentationServiceImpl::DefaultSessionStartContext |
626 ::DefaultSessionStartContext() { | 659 ::DefaultSessionStartContext() { |
627 } | 660 } |
628 | 661 |
629 PresentationServiceImpl::DefaultSessionStartContext | 662 PresentationServiceImpl::DefaultSessionStartContext |
630 ::~DefaultSessionStartContext() { | 663 ::~DefaultSessionStartContext() { |
631 Reset(); | 664 Reset(); |
632 } | 665 } |
633 | 666 |
634 void PresentationServiceImpl::DefaultSessionStartContext::AddCallback( | 667 void PresentationServiceImpl::DefaultSessionStartContext::AddCallback( |
635 const DefaultSessionMojoCallback& callback) { | 668 const PresentationSessionMojoCallback& callback) { |
636 if (session_.get()) { | 669 if (session_.get()) { |
637 DCHECK(callbacks_.empty()); | 670 DCHECK(callbacks_.empty()); |
638 callback.Run(presentation::PresentationSessionInfo::From(*session_)); | 671 callback.Run(presentation::PresentationSessionInfo::From(*session_)); |
639 session_.reset(); | 672 session_.reset(); |
640 } else { | 673 } else { |
641 callbacks_.push_back(new DefaultSessionMojoCallback(callback)); | 674 callbacks_.push_back(new PresentationSessionMojoCallback(callback)); |
642 } | 675 } |
643 } | 676 } |
644 | 677 |
645 void PresentationServiceImpl::DefaultSessionStartContext::set_session( | 678 void PresentationServiceImpl::DefaultSessionStartContext::set_session( |
646 const PresentationSessionInfo& session) { | 679 const PresentationSessionInfo& session) { |
647 if (callbacks_.empty()) { | 680 if (callbacks_.empty()) { |
648 session_.reset(new PresentationSessionInfo(session)); | 681 session_.reset(new PresentationSessionInfo(session)); |
649 } else { | 682 } else { |
650 DCHECK(!session_.get()); | 683 DCHECK(!session_.get()); |
651 ScopedVector<DefaultSessionMojoCallback> callbacks; | 684 ScopedVector<PresentationSessionMojoCallback> callbacks; |
652 callbacks.swap(callbacks_); | 685 callbacks.swap(callbacks_); |
653 for (const auto& callback : callbacks) | 686 for (const auto& callback : callbacks) |
654 callback->Run(presentation::PresentationSessionInfo::From(session)); | 687 callback->Run(presentation::PresentationSessionInfo::From(session)); |
655 } | 688 } |
656 } | 689 } |
657 | 690 |
658 void PresentationServiceImpl::DefaultSessionStartContext::Reset() { | 691 void PresentationServiceImpl::DefaultSessionStartContext::Reset() { |
659 ScopedVector<DefaultSessionMojoCallback> callbacks; | 692 ScopedVector<PresentationSessionMojoCallback> callbacks; |
660 callbacks.swap(callbacks_); | 693 callbacks.swap(callbacks_); |
661 for (const auto& callback : callbacks) | 694 for (const auto& callback : callbacks) |
662 callback->Run(presentation::PresentationSessionInfoPtr()); | 695 callback->Run(presentation::PresentationSessionInfoPtr()); |
663 session_.reset(); | 696 session_.reset(); |
664 } | 697 } |
665 | 698 |
666 } // namespace content | 699 } // namespace content |
OLD | NEW |