Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(201)

Side by Side Diff: content/browser/presentation/presentation_service_impl.cc

Issue 1314413005: [Presentation API] 1-UA presentation support + presenter APIs. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase again to pick up Yuri's cl Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698