Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(7072)

Unified Diff: chrome/browser/geolocation/location_provider_pool.cc

Issue 555148: Add more gears geolocaiton files into chromium: locaiton provider, network lo... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 10 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/geolocation/location_provider_pool.cc
===================================================================
--- chrome/browser/geolocation/location_provider_pool.cc (revision 0)
+++ chrome/browser/geolocation/location_provider_pool.cc (revision 0)
@@ -0,0 +1,182 @@
+// Copyright 2008, Google Inc.
+//
+// Redistribution and use in source and binary forms, with or without
+// modification, are permitted provided that the following conditions are met:
+//
+// 1. Redistributions of source code must retain the above copyright notice,
+// this list of conditions and the following disclaimer.
+// 2. Redistributions in binary form must reproduce the above copyright notice,
+// this list of conditions and the following disclaimer in the documentation
+// and/or other materials provided with the distribution.
+// 3. Neither the name of Google Inc. nor the names of its contributors may be
+// used to endorse or promote products derived from this software without
+// specific prior written permission.
+//
+// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
+// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+// TODO(joth): port to chromium
+#if 0
+
+#include "gears/geolocation/location_provider_pool.h"
+
+#include <assert.h>
+
+static const char16 *kMockString = STRING16(L"MOCK");
+static const char16 *kGpsString = STRING16(L"GPS");
+static const char16 *kNetworkString = STRING16(L"NETWORK");
+
+// Local functions
+static std::string16 MakeKey(const std::string16 &type,
+ const std::string16 &url,
+ const std::string16 &host,
+ const std::string16 &language);
+
+// static member variables
+LocationProviderPool LocationProviderPool::instance_;
+
+LocationProviderPool::LocationProviderPool()
+ : use_mock_location_provider_(false) {
+}
+
+LocationProviderPool::~LocationProviderPool() {
+#if BROWSER_IEMOBILE
+ // The lack of unload monitoring on IE Mobile on WinCE means that we may leak
+ // providers.
+#else
+ assert(providers_.empty());
+#endif // BROWSER_IEMOBILE
+}
+
+// static
+LocationProviderPool *LocationProviderPool::GetInstance() {
+ return &instance_;
+}
+
+LocationProviderBase *LocationProviderPool::Register(
+ BrowsingContext *browsing_context,
+ const std::string16 &type,
+ const std::string16 &url,
+ const std::string16 &host,
+ bool request_address,
+ const std::string16 &language,
+ LocationProviderBase::ListenerInterface *listener) {
+ assert(listener);
+ MutexLock lock(&providers_mutex_);
+ std::string16 key = MakeKey(type, url, host, language);
+ ProviderMap::iterator iter = providers_.find(key);
+ if (iter == providers_.end()) {
+ LocationProviderBase *provider = NewProvider(browsing_context, type, url,
+ host, language);
+ if (!provider) {
+ return NULL;
+ }
+ std::pair<ProviderMap::iterator, bool> result =
+ providers_.insert(
+ std::make_pair(key,
+ std::make_pair(provider, new RefCount())));
+ assert(result.second);
+ iter = result.first;
+ }
+ LocationProviderBase *provider = iter->second.first;
+ assert(provider);
+ provider->RegisterListener(listener, request_address);
+ RefCount *count = iter->second.second;
+ assert(count);
+ count->Ref();
+ return provider;
+}
+
+bool LocationProviderPool::Unregister(
+ LocationProviderBase *provider,
+ LocationProviderBase::ListenerInterface *listener) {
+ assert(provider);
+ assert(listener);
+ MutexLock lock(&providers_mutex_);
+ for (ProviderMap::iterator iter = providers_.begin();
+ iter != providers_.end();
+ ++iter) {
+ LocationProviderBase *current_provider = iter->second.first;
+ if (current_provider == provider) {
+ current_provider->UnregisterListener(listener);
+ RefCount *count = iter->second.second;
+ assert(count);
+ if (count->Unref()) {
+ delete current_provider;
+ delete count;
+ providers_.erase(iter);
+ }
+ return true;
+ }
+ }
+ return false;
+}
+
+void LocationProviderPool::UseMockLocationProvider(
+ bool use_mock_location_provider) {
+ use_mock_location_provider_ = use_mock_location_provider;
+}
+
+LocationProviderBase *LocationProviderPool::NewProvider(
+ BrowsingContext *browsing_context,
+ const std::string16 &type,
+ const std::string16 &url,
+ const std::string16 &host,
+ const std::string16 &language) {
+ if (type == kMockString) {
+ // use_mock_location_provider_ can only be set to true in a build that uses
+ // USING_CCTESTS.
+#if USING_CCTESTS
+ if (use_mock_location_provider_) {
+ return NewMockLocationProvider();
+ } else {
+ return NULL;
+ }
+#else
+ return NULL;
+#endif // USING_CCTESTS
+ } else if (type == kGpsString) {
+ return NewGpsLocationProvider(browsing_context, url, host, language);
+ } else if (type == kNetworkString) {
+ return NewNetworkLocationProvider(browsing_context, url, host, language);
+ }
+ assert(false);
+ return NULL;
+}
+
+// Local function
+static std::string16 MakeKey(const std::string16 &type,
+ const std::string16 &url,
+ const std::string16 &host,
+ const std::string16 &language) {
+ // Network requests are made from a specific host and use a specific language.
+ // Therefore we must key network and GPS providers on server URL, host and
+ // language.
+ if (type == kMockString) {
+ return type;
+ } else if (type == kGpsString || type == kNetworkString) {
+ std::string16 key = type;
+ if (!url.empty()) {
+ key += STRING16(L" url=") + url;
+ }
+ if (!host.empty()) {
+ key += STRING16(L" host=") + host;
+ }
+ if (!language.empty()) {
+ key += STRING16(L" language=") + language;
+ }
+ return key;
+ }
+ assert(false);
+ return STRING16(L"");
+}
+
+#endif // if 0
Property changes on: chrome\browser\geolocation\location_provider_pool.cc
___________________________________________________________________
Added: svn:eol-style
+ LF
« no previous file with comments | « chrome/browser/geolocation/location_provider_pool.h ('k') | chrome/browser/geolocation/network_location_provider.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698