| 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 |