summaryrefslogtreecommitdiffstats
path: root/WebKit
diff options
context:
space:
mode:
authorSteve Block <steveblock@google.com>2009-07-28 18:14:26 +0100
committerSteve Block <steveblock@google.com>2009-07-29 16:14:24 +0100
commitda03bd066d796453c369a98de10fe2cd09bc4280 (patch)
tree646463d774c996ba2981b3819a429be221757f38 /WebKit
parent0deb5796f1ccc4ea91903fec3eda2c18ea5b3e37 (diff)
downloadexternal_webkit-da03bd066d796453c369a98de10fe2cd09bc4280.zip
external_webkit-da03bd066d796453c369a98de10fe2cd09bc4280.tar.gz
external_webkit-da03bd066d796453c369a98de10fe2cd09bc4280.tar.bz2
Adds GeolocationPermissionsBridge.
Diffstat (limited to 'WebKit')
-rw-r--r--WebKit/Android.mk1
-rwxr-xr-xWebKit/android/jni/GeolocationPermissionsBridge.cpp101
-rw-r--r--WebKit/android/jni/WebCoreJniOnLoad.cpp5
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)