Chromium Code Reviews| Index: chrome/browser/net/nqe/ui_network_quality_estimator_service.cc |
| diff --git a/chrome/browser/net/nqe/ui_network_quality_estimator_service.cc b/chrome/browser/net/nqe/ui_network_quality_estimator_service.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..810c769caaa93545098829419e0bade10fd418ae |
| --- /dev/null |
| +++ b/chrome/browser/net/nqe/ui_network_quality_estimator_service.cc |
| @@ -0,0 +1,102 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/net/nqe/ui_network_quality_estimator_service.h" |
| + |
| +#include "base/bind.h" |
| +#include "base/message_loop/message_loop.h" |
| +#include "base/task_runner.h" |
| +#include "chrome/browser/browser_process.h" |
| +#include "chrome/browser/io_thread.h" |
| + |
| +namespace chrome_browser_net { |
| + |
| +class UINetworkQualityEstimatorService::IONetworkQualityObserver |
|
tbansal1
2016/07/13 00:07:27
Add class comments. Something along the lines of:
RyanSturm
2016/07/13 17:28:14
Done.
|
| + : public net::NetworkQualityEstimator::EffectiveConnectionTypeObserver { |
| + public: |
| + IONetworkQualityObserver( |
| + scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner, |
| + base::WeakPtr<UINetworkQualityEstimatorService> service) |
| + : ui_task_runner_(ui_task_runner), service_(service) { |
| + // This is created on the UI thread, but used only on the UI thread. |
| + thread_checker_.DetachFromThread(); |
|
tbansal1
2016/07/13 00:07:28
DCHECK(ui_task_runner_);
RyanSturm
2016/07/13 17:28:14
Done.
|
| + } |
| + |
| + ~IONetworkQualityObserver() override { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + if (network_quality_estimator_) |
| + network_quality_estimator_->RemoveEffectiveConnectionTypeObserver(this); |
| + } |
| + |
| + void InitializeOnIOThread(IOThread* io_thread) { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + if (!io_thread->globals()->network_quality_estimator) |
| + return; |
| + network_quality_estimator_ = |
| + io_thread->globals()->network_quality_estimator->GetWeakPtr(); |
|
tbansal1
2016/07/13 00:07:28
Just use the raw pointer.
RyanSturm
2016/07/13 17:28:14
I'm not sure that the network_quality_estimator_->
tbansal1
2016/07/13 17:56:11
The IOThread::globals are destroyed in IOThread::C
tbansal1
2016/07/13 18:08:13
Because of the above, you can remove the WeakPtr,
|
| + network_quality_estimator_->AddEffectiveConnectionTypeObserver(this); |
|
tbansal1
2016/07/13 00:07:28
Check if network_quality_estimator_ is non-null be
RyanSturm
2016/07/13 17:28:14
Done.
|
| + ui_task_runner_->PostTask( |
| + FROM_HERE, |
| + base::Bind( |
| + &UINetworkQualityEstimatorService::EffectiveConnectionTypeChanged, |
| + service_, |
| + network_quality_estimator_->GetEffectiveConnectionType())); |
| + } |
| + |
| + protected: |
| + void OnEffectiveConnectionTypeChanged( |
|
tbansal1
2016/07/13 00:07:28
Why protected?
Also, add comment:
// net::Network
RyanSturm
2016/07/13 17:28:14
Done.
|
| + net::NetworkQualityEstimator::EffectiveConnectionType type) override { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + ui_task_runner_->PostTask( |
| + FROM_HERE, |
| + base::Bind( |
| + &UINetworkQualityEstimatorService::EffectiveConnectionTypeChanged, |
| + service_, type)); |
| + } |
| + |
| + private: |
| + scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner_; |
| + base::WeakPtr<UINetworkQualityEstimatorService> service_; |
| + base::WeakPtr<net::NetworkQualityEstimator> network_quality_estimator_; |
| + base::ThreadChecker thread_checker_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(IONetworkQualityObserver); |
| +}; |
| + |
| +UINetworkQualityEstimatorService::UINetworkQualityEstimatorService( |
| + Profile* profile) |
| + : type_(net::NetworkQualityEstimator::EFFECTIVE_CONNECTION_TYPE_UNKNOWN), |
| + io_observer_(nullptr), |
| + weak_factory_(this) {} |
| + |
| +UINetworkQualityEstimatorService::~UINetworkQualityEstimatorService() { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + DCHECK(io_task_runner_->DeleteSoon(FROM_HERE, io_observer_)); |
| +} |
| + |
| +void UINetworkQualityEstimatorService::Initialize( |
| + scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner, |
| + scoped_refptr<base::SingleThreadTaskRunner> io_task_runner) { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + io_task_runner_ = io_task_runner; |
| + io_observer_ = |
| + new IONetworkQualityObserver(ui_task_runner, weak_factory_.GetWeakPtr()); |
| + io_task_runner_->PostTask( |
| + FROM_HERE, base::Bind(&IONetworkQualityObserver::InitializeOnIOThread, |
| + base::Unretained(io_observer_), |
| + g_browser_process->io_thread())); |
| +} |
| + |
| +void UINetworkQualityEstimatorService::Shutdown() { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + weak_factory_.InvalidateWeakPtrs(); |
| +} |
| + |
| +void UINetworkQualityEstimatorService::EffectiveConnectionTypeChanged( |
| + net::NetworkQualityEstimator::EffectiveConnectionType type) { |
| + DCHECK(thread_checker_.CalledOnValidThread()); |
| + type_ = type; |
| +} |
| + |
| +} // namespace chrome_browser_net |