diff options
author | Steve Block <steveblock@google.com> | 2009-08-14 12:29:38 +0100 |
---|---|---|
committer | Steve Block <steveblock@google.com> | 2009-08-14 16:49:04 +0100 |
commit | b12a01676d083061bfcdc9efe98ac9d03dd59802 (patch) | |
tree | 607b1429d2bd69f7211f2f230fec0e314435d786 /WebKit | |
parent | 5343011d8c5e322c74a78385633354ca3db92343 (diff) | |
download | external_webkit-b12a01676d083061bfcdc9efe98ac9d03dd59802.zip external_webkit-b12a01676d083061bfcdc9efe98ac9d03dd59802.tar.gz external_webkit-b12a01676d083061bfcdc9efe98ac9d03dd59802.tar.bz2 |
Adds ability to configure mock Geolocation service from DumpRenderTree on Android.
Diffstat (limited to 'WebKit')
-rw-r--r-- | WebKit/Android.mk | 1 | ||||
-rwxr-xr-x | WebKit/android/jni/MockGeolocation.cpp | 96 | ||||
-rw-r--r-- | WebKit/android/jni/WebCoreJniOnLoad.cpp | 4 |
3 files changed, 100 insertions, 1 deletions
diff --git a/WebKit/Android.mk b/WebKit/Android.mk index 784326c..c309910 100644 --- a/WebKit/Android.mk +++ b/WebKit/Android.mk @@ -36,6 +36,7 @@ LOCAL_SRC_FILES := \ android/jni/GeolocationPermissionsBridge.cpp \ android/jni/JavaBridge.cpp \ android/jni/JavaSharedClient.cpp \ + android/jni/MockGeolocation.cpp \ android/jni/PictureSet.cpp \ android/jni/WebCoreFrameBridge.cpp \ android/jni/WebCoreJni.cpp \ diff --git a/WebKit/android/jni/MockGeolocation.cpp b/WebKit/android/jni/MockGeolocation.cpp new file mode 100755 index 0000000..2f6ca60 --- /dev/null +++ b/WebKit/android/jni/MockGeolocation.cpp @@ -0,0 +1,96 @@ +/* + * Copyright 2009, The Android Open Source Project + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * * Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * * 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. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``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 APPLE COMPUTER, INC. OR + * CONTRIBUTORS 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. + */ + +// The functions in this file are used to configure the mock GeolocationService +// for the LayoutTests. + +#include "config.h" + +#include <JNIHelp.h> +#include "Coordinates.h" +#include "GeolocationService.h" +#include "Geoposition.h" +#include "JavaSharedClient.h" +#include "jni_utility.h" +#include "PositionError.h" +#include "WebCoreJni.h" +#include <wtf/CurrentTime.h> + +using namespace WebCore; + +namespace android { + +static const char* javaMockGeolocationClass = "android/webkit/MockGeolocation"; + +static void setPosition(JNIEnv* env, jobject, double latitude, double longitude, double accuracy) +{ + RefPtr<Coordinates> coordinates = Coordinates::create(latitude, + longitude, + false, 0.0, // altitude, + accuracy, + false, 0.0, // altitudeAccuracy, + false, 0.0, // heading + false, 0.0); // speed + RefPtr<Geoposition> position = Geoposition::create(coordinates.release(), WTF::currentTime()); + GeolocationService::setMockPosition(position.release()); +} + +static void setError(JNIEnv* env, jobject, int code, jstring message) +{ + PositionError::ErrorCode codeEnum; + switch (code) { + case PositionError::UNKNOWN_ERROR: + codeEnum = PositionError::UNKNOWN_ERROR; + break; + case PositionError::PERMISSION_DENIED: + codeEnum = PositionError::PERMISSION_DENIED; + break; + case PositionError::POSITION_UNAVAILABLE: + codeEnum = PositionError::POSITION_UNAVAILABLE; + break; + case PositionError::TIMEOUT: + codeEnum = PositionError::TIMEOUT; + break; + default: + ASSERT(false); + } + String messageString = to_string(env, message); + RefPtr<PositionError> error = PositionError::create(codeEnum, messageString); + GeolocationService::setMockError(error.release()); +} + +static JNINativeMethod gMockGeolocationMethods[] = { + { "nativeSetPosition", "(DDD)V", (void*) setPosition }, + { "nativeSetError", "(ILjava/lang/String;)V", (void*) setError } +}; + +int register_mock_geolocation(JNIEnv* env) +{ + jclass mockGeolocation = env->FindClass(javaMockGeolocationClass); + LOG_ASSERT(mockGeolocation, "Unable to find class"); + return jniRegisterNativeMethods(env, javaMockGeolocationClass, gMockGeolocationMethods, NELEM(gMockGeolocationMethods)); +} + +} diff --git a/WebKit/android/jni/WebCoreJniOnLoad.cpp b/WebKit/android/jni/WebCoreJniOnLoad.cpp index 3a29f43..25afc61 100644 --- a/WebKit/android/jni/WebCoreJniOnLoad.cpp +++ b/WebKit/android/jni/WebCoreJniOnLoad.cpp @@ -45,6 +45,7 @@ extern int register_webcorejni(JNIEnv*); extern int register_webstorage(JNIEnv*); #endif extern int register_geolocation_permissions(JNIEnv*); +extern int register_mock_geolocation(JNIEnv*); } @@ -66,7 +67,8 @@ static RegistrationMethod gWebCoreRegMethods[] = { { "WebStorage", android::register_webstorage }, #endif { "WebView", android::register_webview }, - { "GeolocationPermissions", android::register_geolocation_permissions } + { "GeolocationPermissions", android::register_geolocation_permissions }, + { "MockGeolocation", android::register_mock_geolocation } }; EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) |