summaryrefslogtreecommitdiff
path: root/dom/system
diff options
context:
space:
mode:
authorMoonchild <moonchild@palemoon.org>2021-05-08 20:59:55 +0000
committerMoonchild <moonchild@palemoon.org>2021-05-08 20:59:55 +0000
commitca35efb84ebae522f9ab7803d8e017f721e03207 (patch)
tree007a31b1f12259cb1940456d8b3717e71a2ddc7d /dom/system
parente7e63565ee4635198cc51ec3dd6f7a41e554b930 (diff)
downloaduxp-ca35efb84ebae522f9ab7803d8e017f721e03207.tar.gz
Issue #1751 -- Remove cocoa support code from /dom
Diffstat (limited to 'dom/system')
-rw-r--r--dom/system/mac/CoreLocationLocationProvider.h59
-rw-r--r--dom/system/mac/CoreLocationLocationProvider.mm268
-rw-r--r--dom/system/mac/moz.build14
-rw-r--r--dom/system/moz.build2
4 files changed, 0 insertions, 343 deletions
diff --git a/dom/system/mac/CoreLocationLocationProvider.h b/dom/system/mac/CoreLocationLocationProvider.h
deleted file mode 100644
index 979bc916d8..0000000000
--- a/dom/system/mac/CoreLocationLocationProvider.h
+++ /dev/null
@@ -1,59 +0,0 @@
-/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-
-#include "nsCOMPtr.h"
-#include "nsIGeolocationProvider.h"
-
-
-/*
- * The CoreLocationObjects class contains the CoreLocation objects
- * we'll need.
- *
- * Declaring them directly in CoreLocationLocationProvider
- * would require Objective-C++ syntax, which would contaminate all
- * files that include this header and require them to be Objective-C++
- * as well.
- *
- * The solution then is to forward-declare CoreLocationObjects here and
- * hold a pointer to it in CoreLocationLocationProvider, and only actually
- * define it in CoreLocationLocationProvider.mm, thus making it safe
- * for nsGeolocation.cpp, which is C++-only, to include this header.
- */
-class CoreLocationObjects;
-class MLSFallback;
-
-class CoreLocationLocationProvider
- : public nsIGeolocationProvider
-{
-public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIGEOLOCATIONPROVIDER
-
- CoreLocationLocationProvider();
- void NotifyError(uint16_t aErrorCode);
- void Update(nsIDOMGeoPosition* aSomewhere);
- void CreateMLSFallbackProvider();
- void CancelMLSFallbackProvider();
-
-private:
- virtual ~CoreLocationLocationProvider();
-
- CoreLocationObjects* mCLObjects;
- nsCOMPtr<nsIGeolocationUpdate> mCallback;
- RefPtr<MLSFallback> mMLSFallbackProvider;
-
- class MLSUpdate : public nsIGeolocationUpdate
- {
- public:
- NS_DECL_ISUPPORTS
- NS_DECL_NSIGEOLOCATIONUPDATE
-
- explicit MLSUpdate(CoreLocationLocationProvider& parentProvider);
-
- private:
- CoreLocationLocationProvider& mParentLocationProvider;
- virtual ~MLSUpdate();
- };
-};
diff --git a/dom/system/mac/CoreLocationLocationProvider.mm b/dom/system/mac/CoreLocationLocationProvider.mm
deleted file mode 100644
index 7a3feba97b..0000000000
--- a/dom/system/mac/CoreLocationLocationProvider.mm
+++ /dev/null
@@ -1,268 +0,0 @@
-/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
-/* vim:set ts=2 sw=2 sts=2 et cindent: */
-/* This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-
-#include "nsAutoPtr.h"
-#include "nsCOMPtr.h"
-#include "nsGeoPosition.h"
-#include "nsIConsoleService.h"
-#include "nsServiceManagerUtils.h"
-#include "nsIDOMGeoPositionError.h"
-#include "CoreLocationLocationProvider.h"
-#include "nsCocoaFeatures.h"
-#include "prtime.h"
-#include "MLSFallback.h"
-
-#include <CoreLocation/CLError.h>
-#include <CoreLocation/CLLocation.h>
-#include <CoreLocation/CLLocationManager.h>
-#include <CoreLocation/CLLocationManagerDelegate.h>
-
-#include <objc/objc.h>
-#include <objc/objc-runtime.h>
-
-#include "nsObjCExceptions.h"
-
-using namespace mozilla;
-
-static const CLLocationAccuracy kHIGH_ACCURACY = kCLLocationAccuracyBest;
-static const CLLocationAccuracy kDEFAULT_ACCURACY = kCLLocationAccuracyNearestTenMeters;
-
-@interface LocationDelegate : NSObject <CLLocationManagerDelegate>
-{
- CoreLocationLocationProvider* mProvider;
-}
-
-- (id)init:(CoreLocationLocationProvider*)aProvider;
-- (void)locationManager:(CLLocationManager*)aManager
- didFailWithError:(NSError *)aError;
-- (void)locationManager:(CLLocationManager*)aManager didUpdateLocations:(NSArray*)locations;
-
-@end
-
-@implementation LocationDelegate
-- (id) init:(CoreLocationLocationProvider*) aProvider
-{
- if ((self = [super init])) {
- mProvider = aProvider;
- }
-
- return self;
-}
-
-- (void)locationManager:(CLLocationManager*)aManager
- didFailWithError:(NSError *)aError
-{
- nsCOMPtr<nsIConsoleService> console =
- do_GetService(NS_CONSOLESERVICE_CONTRACTID);
-
- NS_ENSURE_TRUE_VOID(console);
-
- NSString* message =
- [@"Failed to acquire position: " stringByAppendingString: [aError localizedDescription]];
-
- console->LogStringMessage(NS_ConvertUTF8toUTF16([message UTF8String]).get());
-
- if ([aError code] == kCLErrorDenied) {
- mProvider->NotifyError(nsIDOMGeoPositionError::PERMISSION_DENIED);
- return;
- }
-
- // The CL provider does not fallback to GeoIP, so use NetworkGeolocationProvider for this.
- // The concept here is: on error, hand off geolocation to MLS, which will then report
- // back a location or error. We can't call this with no delay however, as this method
- // is called with an error code of 0 in both failed geolocation cases, and also when
- // geolocation is not immediately available.
- // The 2 sec delay is arbitrarily large enough that CL has a reasonable head start and
- // if it is likely to succeed, it should complete before the MLS provider.
- // Take note that in locationManager:didUpdateLocations: the handoff to MLS is stopped.
- mProvider->CreateMLSFallbackProvider();
-}
-
-- (void)locationManager:(CLLocationManager*)aManager didUpdateLocations:(NSArray*)aLocations
-{
- if (aLocations.count < 1) {
- return;
- }
-
- mProvider->CancelMLSFallbackProvider();
-
- CLLocation* location = [aLocations objectAtIndex:0];
-
- nsCOMPtr<nsIDOMGeoPosition> geoPosition =
- new nsGeoPosition(location.coordinate.latitude,
- location.coordinate.longitude,
- location.altitude,
- location.horizontalAccuracy,
- location.verticalAccuracy,
- location.course,
- location.speed,
- PR_Now() / PR_USEC_PER_MSEC);
-
- mProvider->Update(geoPosition);
-}
-@end
-
-NS_IMPL_ISUPPORTS(CoreLocationLocationProvider::MLSUpdate, nsIGeolocationUpdate);
-
-CoreLocationLocationProvider::MLSUpdate::MLSUpdate(CoreLocationLocationProvider& parentProvider)
- : mParentLocationProvider(parentProvider)
-{
-}
-
-CoreLocationLocationProvider::MLSUpdate::~MLSUpdate()
-{
-}
-
-NS_IMETHODIMP
-CoreLocationLocationProvider::MLSUpdate::Update(nsIDOMGeoPosition *position)
-{
- nsCOMPtr<nsIDOMGeoPositionCoords> coords;
- position->GetCoords(getter_AddRefs(coords));
- if (!coords) {
- return NS_ERROR_FAILURE;
- }
- mParentLocationProvider.Update(position);
- return NS_OK;
-}
-NS_IMETHODIMP
-CoreLocationLocationProvider::MLSUpdate::NotifyError(uint16_t error)
-{
- mParentLocationProvider.NotifyError(error);
- return NS_OK;
-}
-class CoreLocationObjects {
-public:
- nsresult Init(CoreLocationLocationProvider* aProvider) {
- mLocationManager = [[CLLocationManager alloc] init];
- NS_ENSURE_TRUE(mLocationManager, NS_ERROR_NOT_AVAILABLE);
-
- mLocationDelegate = [[LocationDelegate alloc] init:aProvider];
- NS_ENSURE_TRUE(mLocationDelegate, NS_ERROR_NOT_AVAILABLE);
-
- mLocationManager.desiredAccuracy = kDEFAULT_ACCURACY;
- mLocationManager.delegate = mLocationDelegate;
-
- return NS_OK;
- }
-
- ~CoreLocationObjects() {
- if (mLocationManager) {
- [mLocationManager release];
- }
-
- if (mLocationDelegate) {
- [mLocationDelegate release];
- }
- }
-
- LocationDelegate* mLocationDelegate;
- CLLocationManager* mLocationManager;
-};
-
-NS_IMPL_ISUPPORTS(CoreLocationLocationProvider, nsIGeolocationProvider)
-
-CoreLocationLocationProvider::CoreLocationLocationProvider()
- : mCLObjects(nullptr), mMLSFallbackProvider(nullptr)
-{
-}
-
-CoreLocationLocationProvider::~CoreLocationLocationProvider()
-{
-}
-
-NS_IMETHODIMP
-CoreLocationLocationProvider::Startup()
-{
- if (!mCLObjects) {
- nsAutoPtr<CoreLocationObjects> clObjs(new CoreLocationObjects());
-
- nsresult rv = clObjs->Init(this);
- NS_ENSURE_SUCCESS(rv, rv);
-
- mCLObjects = clObjs.forget();
- }
-
- // Must be stopped before starting or response (success or failure) is not guaranteed
- [mCLObjects->mLocationManager stopUpdatingLocation];
- [mCLObjects->mLocationManager startUpdatingLocation];
- return NS_OK;
-}
-
-NS_IMETHODIMP
-CoreLocationLocationProvider::Watch(nsIGeolocationUpdate* aCallback)
-{
- if (mCallback) {
- return NS_OK;
- }
-
- mCallback = aCallback;
- return NS_OK;
-}
-
-NS_IMETHODIMP
-CoreLocationLocationProvider::Shutdown()
-{
- NS_ENSURE_STATE(mCLObjects);
-
- [mCLObjects->mLocationManager stopUpdatingLocation];
-
- delete mCLObjects;
- mCLObjects = nullptr;
-
- if (mMLSFallbackProvider) {
- mMLSFallbackProvider->Shutdown();
- mMLSFallbackProvider = nullptr;
- }
-
- return NS_OK;
-}
-
-NS_IMETHODIMP
-CoreLocationLocationProvider::SetHighAccuracy(bool aEnable)
-{
- NS_ENSURE_STATE(mCLObjects);
-
- mCLObjects->mLocationManager.desiredAccuracy =
- (aEnable ? kHIGH_ACCURACY : kDEFAULT_ACCURACY);
-
- return NS_OK;
-}
-
-void
-CoreLocationLocationProvider::Update(nsIDOMGeoPosition* aSomewhere)
-{
- if (aSomewhere && mCallback) {
- mCallback->Update(aSomewhere);
- }
-}
-
-void
-CoreLocationLocationProvider::NotifyError(uint16_t aErrorCode)
-{
- mCallback->NotifyError(aErrorCode);
-}
-
-void
-CoreLocationLocationProvider::CreateMLSFallbackProvider()
-{
- if (mMLSFallbackProvider) {
- return;
- }
-
- mMLSFallbackProvider = new MLSFallback();
- mMLSFallbackProvider->Startup(new MLSUpdate(*this));
-}
-
-void
-CoreLocationLocationProvider::CancelMLSFallbackProvider()
-{
- if (!mMLSFallbackProvider) {
- return;
- }
-
- mMLSFallbackProvider->Shutdown();
- mMLSFallbackProvider = nullptr;
-}
diff --git a/dom/system/mac/moz.build b/dom/system/mac/moz.build
deleted file mode 100644
index 08b7c2151e..0000000000
--- a/dom/system/mac/moz.build
+++ /dev/null
@@ -1,14 +0,0 @@
-# -*- Mode: python; indent-tabs-mode: nil; tab-width: 40 -*-
-# This Source Code Form is subject to the terms of the Mozilla Public
-# License, v. 2.0. If a copy of the MPL was not distributed with this
-# file, You can obtain one at http://mozilla.org/MPL/2.0/.
-
-SOURCES += ['CoreLocationLocationProvider.mm']
-
-include('/ipc/chromium/chromium-config.mozbuild')
-
-FINAL_LIBRARY = 'xul'
-LOCAL_INCLUDES += [
- '/dom/geolocation',
-]
-
diff --git a/dom/system/moz.build b/dom/system/moz.build
index bde685e4fc..fb41fd4f2d 100644
--- a/dom/system/moz.build
+++ b/dom/system/moz.build
@@ -7,8 +7,6 @@ toolkit = CONFIG['MOZ_WIDGET_TOOLKIT']
if toolkit == 'windows':
DIRS += ['windows']
-elif toolkit == 'cocoa':
- DIRS += ['mac']
elif toolkit == 'android':
DIRS += ['android']
elif toolkit in ('gtk2', 'gtk3'):