Chromium Code Reviews

Side by Side Diff: chrome/browser/geolocation/core_location_provider_mac.mm

Issue 6037016: Fix incorrect assertion following the move of Geolocation provider in to its own thread. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix nits. Created 9 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | | Annotate | Revision Log
« no previous file with comments | « chrome/browser/geolocation/core_location_provider_mac.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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 "chrome/browser/geolocation/core_location_provider_mac.h" 5 #include "chrome/browser/geolocation/core_location_provider_mac.h"
6 #include "chrome/browser/geolocation/core_location_data_provider_mac.h" 6 #include "chrome/browser/geolocation/core_location_data_provider_mac.h"
7 7
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/command_line.h" 9 #include "base/command_line.h"
10 #include "chrome/common/chrome_switches.h" 10 #include "chrome/common/chrome_switches.h"
11 11
12 CoreLocationProviderMac::CoreLocationProviderMac() { 12 CoreLocationProviderMac::CoreLocationProviderMac()
13 : is_updating_(false) {
13 data_provider_ = new CoreLocationDataProviderMac(); 14 data_provider_ = new CoreLocationDataProviderMac();
14 data_provider_->AddRef(); 15 data_provider_->AddRef();
15 } 16 }
16 17
17 CoreLocationProviderMac::~CoreLocationProviderMac() { 18 CoreLocationProviderMac::~CoreLocationProviderMac() {
18 data_provider_->StopUpdating(); 19 data_provider_->StopUpdating();
19 data_provider_->Release(); 20 data_provider_->Release();
20 } 21 }
21 22
22 bool CoreLocationProviderMac::StartProvider(bool high_accuracy) { 23 bool CoreLocationProviderMac::StartProvider(bool high_accuracy) {
23 data_provider_->StartUpdating(this); 24 // StartProvider maybe called multiple times. For example, to update the high
25 // accuracy hint.
26 // TODO(jknotten): Support high_accuracy hint in underlying data provider.
27 if (is_updating_)
28 return true;
29
30 is_updating_ = data_provider_->StartUpdating(this);
24 return true; 31 return true;
25 } 32 }
26 33
27 void CoreLocationProviderMac::StopProvider() { 34 void CoreLocationProviderMac::StopProvider() {
28 data_provider_->StopUpdating(); 35 data_provider_->StopUpdating();
36 is_updating_ = false;
29 } 37 }
30 38
31 void CoreLocationProviderMac::GetPosition(Geoposition* position) { 39 void CoreLocationProviderMac::GetPosition(Geoposition* position) {
32 DCHECK(position); 40 DCHECK(position);
33 *position = position_; 41 *position = position_;
34 DCHECK(position->IsInitialized()); 42 DCHECK(position->IsInitialized());
35 } 43 }
36 44
37 void CoreLocationProviderMac::SetPosition(Geoposition* position) { 45 void CoreLocationProviderMac::SetPosition(Geoposition* position) {
38 DCHECK(position); 46 DCHECK(position);
39 position_ = *position; 47 position_ = *position;
40 DCHECK(position->IsInitialized()); 48 DCHECK(position->IsInitialized());
41 49
42 UpdateListeners(); 50 UpdateListeners();
43 } 51 }
44 52
45 LocationProviderBase* NewSystemLocationProvider() { 53 LocationProviderBase* NewSystemLocationProvider() {
46 if(CommandLine::ForCurrentProcess() 54 if (CommandLine::ForCurrentProcess()->HasSwitch(
47 ->HasSwitch(switches::kExperimentalLocationFeatures)) { 55 switches::kExperimentalLocationFeatures)) {
48 return new CoreLocationProviderMac; 56 return new CoreLocationProviderMac;
49 } 57 }
50 return NULL; 58 return NULL;
51 } 59 }
OLDNEW
« no previous file with comments | « chrome/browser/geolocation/core_location_provider_mac.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine