diff options
author | Steve Block <steveblock@google.com> | 2009-07-28 18:14:26 +0100 |
---|---|---|
committer | Steve Block <steveblock@google.com> | 2009-07-29 16:14:24 +0100 |
commit | da03bd066d796453c369a98de10fe2cd09bc4280 (patch) | |
tree | 646463d774c996ba2981b3819a429be221757f38 /WebKit | |
parent | 0deb5796f1ccc4ea91903fec3eda2c18ea5b3e37 (diff) | |
download | external_webkit-da03bd066d796453c369a98de10fe2cd09bc4280.zip external_webkit-da03bd066d796453c369a98de10fe2cd09bc4280.tar.gz external_webkit-da03bd066d796453c369a98de10fe2cd09bc4280.tar.bz2 |
Adds GeolocationPermissionsBridge.
Diffstat (limited to 'WebKit')
-rw-r--r-- | WebKit/Android.mk | 1 | ||||
-rwxr-xr-x | WebKit/android/jni/GeolocationPermissionsBridge.cpp | 101 | ||||
-rw-r--r-- | WebKit/android/jni/WebCoreJniOnLoad.cpp | 5 |
3 files changed, 105 insertions, 2 deletions
diff --git a/WebKit/Android.mk b/WebKit/Android.mk index e4b739a..5e8bdbb 100644 --- a/WebKit/Android.mk +++ b/WebKit/Android.mk @@ -33,6 +33,7 @@ LOCAL_SRC_FILES := \ \ android/icu/unicode/ucnv.cpp \ \ + android/jni/GeolocationPermissionsBridge.cpp \ android/jni/JavaBridge.cpp \ android/jni/JavaSharedClient.cpp \ android/jni/PictureSet.cpp \ diff --git a/WebKit/android/jni/GeolocationPermissionsBridge.cpp b/WebKit/android/jni/GeolocationPermissionsBridge.cpp new file mode 100755 index 0000000..ddcca5d --- /dev/null +++ b/WebKit/android/jni/GeolocationPermissionsBridge.cpp @@ -0,0 +1,101 @@ +/* + * 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. + */ + +#include "config.h" + +#include <JNIHelp.h> // For jniRegisterNativeMethods +#include "GeolocationPermissions.h" +#include "WebCoreJni.h" // For to_string + + +/** + * This file provides a set of functions to bridge between the Java and C++ + * GeolocationPermissions classes. The java GeolocationPermissions object calls + * the functions provided here, which in turn call static methods on the C++ + * GeolocationPermissions class. + */ + +namespace android { + +static jobject getOrigins(JNIEnv* env, jobject obj) +{ + GeolocationPermissions::OriginSet origins = GeolocationPermissions::getOrigins(); + + jclass setClass = env->FindClass("java/util/HashSet"); + jmethodID constructor = env->GetMethodID(setClass, "<init>", "()V"); + jmethodID addMethod = env->GetMethodID(setClass, "add", "(Ljava/lang/Object;)Z"); + jobject set = env->NewObject(setClass, constructor); + + GeolocationPermissions::OriginSet::const_iterator end = origins.end(); + for (GeolocationPermissions::OriginSet::const_iterator iter = origins.begin(); iter != end; ++iter) { + jstring originString = env->NewString(iter->characters(), iter->length()); + env->CallBooleanMethod(set, addMethod, originString); + env->DeleteLocalRef(originString); + } + return set; +} + +static bool getAllowed(JNIEnv* env, jobject obj, jstring origin) +{ + WebCore::String originString = to_string(env, origin); + return GeolocationPermissions::getAllowed(originString); +} + +static void clear(JNIEnv* env, jobject obj, jstring origin) +{ + WebCore::String originString = to_string(env, origin); + GeolocationPermissions::clear(originString); +} + +static void clearAll(JNIEnv* env, jobject obj) +{ + GeolocationPermissions::clearAll(); +} + +/* + * JNI registration + */ +static JNINativeMethod gGeolocationPermissionsMethods[] = { + { "nativeGetOrigins", "()Ljava/util/Set;", + (void*) getOrigins }, + { "nativeGetAllowed", "(Ljava/lang/String;)Z", + (void*) getAllowed }, + { "nativeClear", "(Ljava/lang/String;)V", + (void*) clear }, + { "nativeClearAll", "()V", + (void*) clearAll } +}; + +int register_geolocation_permissions(JNIEnv* env) +{ + const char* kGeolocationPermissionsClass = "android/webkit/GeolocationPermissions"; + jclass geolocationPermissions = env->FindClass(kGeolocationPermissionsClass); + LOG_ASSERT(geolocationPermissions, "Unable to find class"); + + return jniRegisterNativeMethods(env, kGeolocationPermissionsClass, + gGeolocationPermissionsMethods, NELEM(gGeolocationPermissionsMethods)); +} + +} diff --git a/WebKit/android/jni/WebCoreJniOnLoad.cpp b/WebKit/android/jni/WebCoreJniOnLoad.cpp index c6b0022..3a29f43 100644 --- a/WebKit/android/jni/WebCoreJniOnLoad.cpp +++ b/WebKit/android/jni/WebCoreJniOnLoad.cpp @@ -41,10 +41,10 @@ extern int register_webicondatabase(JNIEnv*); extern int register_websettings(JNIEnv*); extern int register_webview(JNIEnv*); extern int register_webcorejni(JNIEnv*); - #if ENABLE(DATABASE) extern int register_webstorage(JNIEnv*); #endif +extern int register_geolocation_permissions(JNIEnv*); } @@ -65,7 +65,8 @@ static RegistrationMethod gWebCoreRegMethods[] = { #if ENABLE(DATABASE) { "WebStorage", android::register_webstorage }, #endif - { "WebView", android::register_webview } + { "WebView", android::register_webview }, + { "GeolocationPermissions", android::register_geolocation_permissions } }; EXPORT jint JNI_OnLoad(JavaVM* vm, void* reserved) |