OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "media/filters/renderer_impl.h" | 5 #include "media/filters/renderer_impl.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/callback.h" | 8 #include "base/callback.h" |
9 #include "base/callback_helpers.h" | 9 #include "base/callback_helpers.h" |
10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
(...skipping 485 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
496 void RendererImpl::OnAudioRendererEnded() { | 496 void RendererImpl::OnAudioRendererEnded() { |
497 DVLOG(1) << __FUNCTION__; | 497 DVLOG(1) << __FUNCTION__; |
498 DCHECK(task_runner_->BelongsToCurrentThread()); | 498 DCHECK(task_runner_->BelongsToCurrentThread()); |
499 | 499 |
500 if (state_ != STATE_PLAYING) | 500 if (state_ != STATE_PLAYING) |
501 return; | 501 return; |
502 | 502 |
503 DCHECK(!audio_ended_); | 503 DCHECK(!audio_ended_); |
504 audio_ended_ = true; | 504 audio_ended_ = true; |
505 | 505 |
506 // Start clock since there is no more audio to trigger clock updates. | |
507 { | |
508 base::TimeDelta duration = get_duration_cb_.Run(); | |
509 base::AutoLock auto_lock(interpolator_lock_); | |
510 interpolator_->SetUpperBound(duration); | |
511 StartClockIfWaitingForTimeUpdate_Locked(); | |
512 } | |
513 | |
514 RunEndedCallbackIfNeeded(); | 506 RunEndedCallbackIfNeeded(); |
515 } | 507 } |
516 | 508 |
517 void RendererImpl::OnVideoRendererEnded() { | 509 void RendererImpl::OnVideoRendererEnded() { |
518 DVLOG(1) << __FUNCTION__; | 510 DVLOG(1) << __FUNCTION__; |
519 DCHECK(task_runner_->BelongsToCurrentThread()); | 511 DCHECK(task_runner_->BelongsToCurrentThread()); |
520 | 512 |
521 if (state_ != STATE_PLAYING) | 513 if (state_ != STATE_PLAYING) |
522 return; | 514 return; |
523 | 515 |
524 DCHECK(!video_ended_); | 516 DCHECK(!video_ended_); |
525 video_ended_ = true; | 517 video_ended_ = true; |
526 | 518 |
527 RunEndedCallbackIfNeeded(); | 519 RunEndedCallbackIfNeeded(); |
528 } | 520 } |
529 | 521 |
530 void RendererImpl::RunEndedCallbackIfNeeded() { | 522 void RendererImpl::RunEndedCallbackIfNeeded() { |
531 DVLOG(1) << __FUNCTION__; | 523 DVLOG(1) << __FUNCTION__; |
532 DCHECK(task_runner_->BelongsToCurrentThread()); | 524 DCHECK(task_runner_->BelongsToCurrentThread()); |
533 | 525 |
534 if (audio_renderer_ && !audio_ended_) | 526 if (audio_renderer_ && !audio_ended_) |
535 return; | 527 return; |
536 | 528 |
537 if (video_renderer_ && !video_ended_) | 529 if (video_renderer_ && !video_ended_) |
538 return; | 530 return; |
539 | 531 |
540 { | 532 { |
541 base::TimeDelta duration = get_duration_cb_.Run(); | |
542 base::AutoLock auto_lock(interpolator_lock_); | 533 base::AutoLock auto_lock(interpolator_lock_); |
543 PauseClockAndStopTicking_Locked(); | 534 PauseClockAndStopTicking_Locked(); |
544 interpolator_->SetBounds(duration, duration); | |
545 } | 535 } |
546 | 536 |
547 ended_cb_.Run(); | 537 ended_cb_.Run(); |
548 } | 538 } |
549 | 539 |
550 void RendererImpl::OnError(PipelineStatus error) { | 540 void RendererImpl::OnError(PipelineStatus error) { |
551 DVLOG(1) << __FUNCTION__ << "(" << error << ")"; | 541 DVLOG(1) << __FUNCTION__ << "(" << error << ")"; |
552 DCHECK(task_runner_->BelongsToCurrentThread()); | 542 DCHECK(task_runner_->BelongsToCurrentThread()); |
553 DCHECK_NE(PIPELINE_OK, error) << "PIPELINE_OK isn't an error!"; | 543 DCHECK_NE(PIPELINE_OK, error) << "PIPELINE_OK isn't an error!"; |
554 | 544 |
555 state_ = STATE_ERROR; | 545 state_ = STATE_ERROR; |
556 | 546 |
557 // Pipeline will destroy |this| as the result of error. | 547 // Pipeline will destroy |this| as the result of error. |
558 base::ResetAndReturn(&error_cb_).Run(error); | 548 base::ResetAndReturn(&error_cb_).Run(error); |
559 | 549 |
560 FireAllPendingCallbacks(); | 550 FireAllPendingCallbacks(); |
561 } | 551 } |
562 | 552 |
563 void RendererImpl::FireAllPendingCallbacks() { | 553 void RendererImpl::FireAllPendingCallbacks() { |
564 DCHECK(task_runner_->BelongsToCurrentThread()); | 554 DCHECK(task_runner_->BelongsToCurrentThread()); |
565 | 555 |
566 if (!init_cb_.is_null()) | 556 if (!init_cb_.is_null()) |
567 base::ResetAndReturn(&init_cb_).Run(PIPELINE_ERROR_ABORT); | 557 base::ResetAndReturn(&init_cb_).Run(PIPELINE_ERROR_ABORT); |
568 | 558 |
569 if (!flush_cb_.is_null()) | 559 if (!flush_cb_.is_null()) |
570 base::ResetAndReturn(&flush_cb_).Run(); | 560 base::ResetAndReturn(&flush_cb_).Run(); |
571 } | 561 } |
572 | 562 |
573 } // namespace media | 563 } // namespace media |
OLD | NEW |