| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 #include "chrome/browser/media/router/discovery/media_sink_service_base.h" | 4 #include "chrome/browser/media/router/discovery/media_sink_service_base.h" |
| 5 | 5 |
| 6 #include <vector> | 6 #include <vector> |
| 7 | 7 |
| 8 namespace { | 8 namespace { |
| 9 // Time interval when media sink service sends sinks to MRP. | 9 // Time interval when media sink service sends sinks to MRP. |
| 10 const int kFetchCompleteTimeoutSecs = 3; | 10 const int kFetchCompleteTimeoutSecs = 3; |
| (...skipping 19 matching lines...) Expand all Loading... |
| 30 | 30 |
| 31 if (current_sinks_ == mrp_sinks_) { | 31 if (current_sinks_ == mrp_sinks_) { |
| 32 DVLOG(2) << "No update to sink list."; | 32 DVLOG(2) << "No update to sink list."; |
| 33 return; | 33 return; |
| 34 } | 34 } |
| 35 | 35 |
| 36 DVLOG(2) << "Send sinks to media router, [size]: " << current_sinks_.size(); | 36 DVLOG(2) << "Send sinks to media router, [size]: " << current_sinks_.size(); |
| 37 sink_discovery_callback_.Run(std::vector<MediaSinkInternal>( | 37 sink_discovery_callback_.Run(std::vector<MediaSinkInternal>( |
| 38 current_sinks_.begin(), current_sinks_.end())); | 38 current_sinks_.begin(), current_sinks_.end())); |
| 39 mrp_sinks_ = current_sinks_; | 39 mrp_sinks_ = current_sinks_; |
| 40 |
| 41 RecordDeviceCounts(); |
| 40 } | 42 } |
| 41 | 43 |
| 42 void MediaSinkServiceBase::StartTimer() { | 44 void MediaSinkServiceBase::StartTimer() { |
| 43 // Create a finish timer. | 45 // Create a finish timer. |
| 44 if (!finish_timer_) | 46 if (!finish_timer_) |
| 45 finish_timer_.reset(new base::OneShotTimer()); | 47 finish_timer_.reset(new base::OneShotTimer()); |
| 46 | 48 |
| 47 base::TimeDelta finish_delay = | 49 base::TimeDelta finish_delay = |
| 48 base::TimeDelta::FromSeconds(fetch_complete_timeout_secs_); | 50 base::TimeDelta::FromSeconds(fetch_complete_timeout_secs_); |
| 49 finish_timer_->Start(FROM_HERE, finish_delay, | 51 finish_timer_->Start(FROM_HERE, finish_delay, |
| 50 base::Bind(&MediaSinkServiceBase::OnFetchCompleted, | 52 base::Bind(&MediaSinkServiceBase::OnFetchCompleted, |
| 51 base::Unretained(this))); | 53 base::Unretained(this))); |
| 52 } | 54 } |
| 53 | 55 |
| 54 void MediaSinkServiceBase::StopTimer() { | 56 void MediaSinkServiceBase::StopTimer() { |
| 55 finish_timer_.reset(); | 57 finish_timer_.reset(); |
| 56 } | 58 } |
| 57 | 59 |
| 58 void MediaSinkServiceBase::RestartTimer() { | 60 void MediaSinkServiceBase::RestartTimer() { |
| 59 if (!finish_timer_ || finish_timer_->IsRunning()) | 61 if (!finish_timer_ || finish_timer_->IsRunning()) |
| 60 return; | 62 return; |
| 61 StartTimer(); | 63 StartTimer(); |
| 62 } | 64 } |
| 63 | 65 |
| 64 } // namespace media_router | 66 } // namespace media_router |
| OLD | NEW |