| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/geolocation/geolocation_provider.h" | 5 #include "content/browser/geolocation/geolocation_provider.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/location.h" | 10 #include "base/location.h" |
| (...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 96 | 96 |
| 97 bool GeolocationProvider::OnGeolocationThread() const { | 97 bool GeolocationProvider::OnGeolocationThread() const { |
| 98 return MessageLoop::current() == message_loop(); | 98 return MessageLoop::current() == message_loop(); |
| 99 } | 99 } |
| 100 | 100 |
| 101 void GeolocationProvider::OnClientsChanged() { | 101 void GeolocationProvider::OnClientsChanged() { |
| 102 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 102 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 103 base::Closure task; | 103 base::Closure task; |
| 104 if (observers_.empty() && callbacks_.empty()) { | 104 if (observers_.empty() && callbacks_.empty()) { |
| 105 DCHECK(IsRunning()); | 105 DCHECK(IsRunning()); |
| 106 // We have no more observers, so we clear the cached geoposition so that |
| 107 // when the next observer is added we will not provide a stale position. |
| 108 position_ = Geoposition(); |
| 106 task = base::Bind(&GeolocationProvider::StopProviders, | 109 task = base::Bind(&GeolocationProvider::StopProviders, |
| 107 base::Unretained(this)); | 110 base::Unretained(this)); |
| 108 } else { | 111 } else { |
| 109 if (!IsRunning()) { | 112 if (!IsRunning()) { |
| 110 Start(); | 113 Start(); |
| 111 if (HasPermissionBeenGranted()) | 114 if (HasPermissionBeenGranted()) |
| 112 InformProvidersPermissionGranted(); | 115 InformProvidersPermissionGranted(); |
| 113 } | 116 } |
| 114 // Determine a set of options that satisfies all clients. | 117 // Determine a set of options that satisfies all clients. |
| 115 GeolocationObserverOptions options = | 118 GeolocationObserverOptions options = |
| (...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 190 DCHECK(OnGeolocationThread()); | 193 DCHECK(OnGeolocationThread()); |
| 191 delete arbitrator_; | 194 delete arbitrator_; |
| 192 arbitrator_ = NULL; | 195 arbitrator_ = NULL; |
| 193 } | 196 } |
| 194 | 197 |
| 195 GeolocationArbitrator* GeolocationProvider::CreateArbitrator() { | 198 GeolocationArbitrator* GeolocationProvider::CreateArbitrator() { |
| 196 return new GeolocationArbitratorImpl(this); | 199 return new GeolocationArbitratorImpl(this); |
| 197 } | 200 } |
| 198 | 201 |
| 199 } // namespace content | 202 } // namespace content |
| OLD | NEW |