Index: libadblockplus-android/jni/JniFilterEngine.cpp |
diff --git a/libadblockplus-android/jni/JniFilterEngine.cpp b/libadblockplus-android/jni/JniFilterEngine.cpp |
deleted file mode 100644 |
index 25134f429cc65efe97f2b100390df51bb1f6737e..0000000000000000000000000000000000000000 |
--- a/libadblockplus-android/jni/JniFilterEngine.cpp |
+++ /dev/null |
@@ -1,548 +0,0 @@ |
-/* |
- * This file is part of Adblock Plus <https://adblockplus.org/>, |
- * Copyright (C) 2006-present eyeo GmbH |
- * |
- * Adblock Plus is free software: you can redistribute it and/or modify |
- * it under the terms of the GNU General Public License version 3 as |
- * published by the Free Software Foundation. |
- * |
- * Adblock Plus is distributed in the hope that it will be useful, |
- * but WITHOUT ANY WARRANTY; without even the implied warranty of |
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
- * GNU General Public License for more details. |
- * |
- * You should have received a copy of the GNU General Public License |
- * along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>. |
- */ |
- |
-#include <AdblockPlus.h> |
-#include "Utils.h" |
-#include "JniCallbacks.h" |
-#include <thread> |
-#include "JniPlatform.h" |
- |
-static jobject SubscriptionsToArrayList(JNIEnv* env, std::vector<AdblockPlus::Subscription>&& subscriptions) |
-{ |
- jobject list = NewJniArrayList(env); |
- |
- for (std::vector<AdblockPlus::Subscription>::iterator it = subscriptions.begin(), end = subscriptions.end(); it != end; it++) |
- { |
- JniAddObjectToList(env, list, NewJniSubscription(env, std::move(*it))); |
- } |
- |
- return list; |
-} |
- |
-static AdblockPlus::FilterEngine::ContentType ConvertContentType(JNIEnv *env, |
- jobject jContentType) |
-{ |
- JniLocalReference<jclass> contentTypeClass(env, |
- env->GetObjectClass(jContentType)); |
- jmethodID nameMethod = env->GetMethodID(*contentTypeClass, "name", |
- "()Ljava/lang/String;"); |
- JniLocalReference<jstring> jValue(env, |
- (jstring) env->CallObjectMethod(jContentType, nameMethod)); |
- const std::string value = JniJavaToStdString(env, *jValue); |
- return AdblockPlus::FilterEngine::StringToContentType(value); |
-} |
- |
-namespace |
-{ |
- AdblockPlus::FilterEngine& GetFilterEngineRef(jlong jniPlatformPtr) |
- { |
- return JniLongToTypePtr<JniPlatform>(jniPlatformPtr)->platform->GetFilterEngine(); |
- } |
-} |
- |
-static jboolean JNICALL JniIsFirstRun(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- try |
- { |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- return engine.IsFirstRun() ? JNI_TRUE : JNI_FALSE; |
- } |
- CATCH_THROW_AND_RETURN(env, JNI_FALSE); |
-} |
- |
-static jobject JNICALL JniGetFilter(JNIEnv* env, jclass clazz, jlong ptr, jstring jText) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- std::string text = JniJavaToStdString(env, jText); |
- |
- try |
- { |
- return NewJniFilter(env, engine.GetFilter(text)); |
- } |
- CATCH_THROW_AND_RETURN(env, 0); |
-} |
- |
-static jobject JNICALL JniGetListedFilters(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- try |
- { |
- std::vector<AdblockPlus::Filter> filters = engine.GetListedFilters(); |
- |
- jobject list = NewJniArrayList(env); |
- |
- for (std::vector<AdblockPlus::Filter>::iterator it = filters.begin(), end = filters.end(); it != end; it++) |
- { |
- JniAddObjectToList(env, list, *JniLocalReference<jobject>(env, NewJniFilter(env, std::move(*it)))); |
- } |
- |
- return list; |
- } |
- CATCH_THROW_AND_RETURN(env, 0); |
-} |
- |
-static jobject JNICALL JniGetSubscription(JNIEnv* env, jclass clazz, jlong ptr, jstring jUrl) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- std::string url = JniJavaToStdString(env, jUrl); |
- |
- try |
- { |
- return NewJniSubscription(env, engine.GetSubscription(url)); |
- } |
- CATCH_THROW_AND_RETURN(env, 0); |
-} |
- |
-static void JNICALL JniShowNextNotification(JNIEnv* env, jclass clazz, jlong ptr, jstring jUrl) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- std::string url = JniJavaToStdString(env, jUrl); |
- |
- try |
- { |
- engine.ShowNextNotification(url); |
- } |
- CATCH_AND_THROW(env); |
-} |
- |
-static void JNICALL JniSetShowNotificationCallback(JNIEnv* env, jclass clazz, |
- jlong ptr, jlong callbackPtr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- JniShowNotificationCallback* const callback = |
- JniLongToTypePtr<JniShowNotificationCallback>(callbackPtr); |
- |
- auto showNotificationCallback = [callback](AdblockPlus::Notification&& notification) |
- { |
- callback->Callback(std::move(notification)); |
- }; |
- |
- try |
- { |
- engine.SetShowNotificationCallback(showNotificationCallback); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static void JNICALL JniRemoveShowNotificationCallback(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- try |
- { |
- engine.RemoveShowNotificationCallback(); |
- } |
- CATCH_AND_THROW(env); |
-} |
- |
-static jobject JNICALL JniGetListedSubscriptions(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- try |
- { |
- return SubscriptionsToArrayList(env, engine.GetListedSubscriptions()); |
- } |
- CATCH_THROW_AND_RETURN(env, 0); |
-} |
- |
-static jobject JNICALL JniFetchAvailableSubscriptions(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- try |
- { |
- return SubscriptionsToArrayList(env, engine.FetchAvailableSubscriptions()); |
- } |
- CATCH_THROW_AND_RETURN(env, 0); |
-} |
- |
-static void JNICALL JniRemoveUpdateAvailableCallback(JNIEnv* env, jclass clazz, |
- jlong ptr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- try |
- { |
- engine.RemoveUpdateAvailableCallback(); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static void JNICALL JniSetUpdateAvailableCallback(JNIEnv* env, jclass clazz, |
- jlong ptr, jlong callbackPtr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- JniUpdateAvailableCallback* const callback = |
- JniLongToTypePtr<JniUpdateAvailableCallback>(callbackPtr); |
- |
- const AdblockPlus::FilterEngine::UpdateAvailableCallback updateAvailableCallback = |
- std::bind(&JniUpdateAvailableCallback::Callback, callback, |
- std::placeholders::_1); |
- try |
- { |
- engine.SetUpdateAvailableCallback(updateAvailableCallback); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static void JNICALL JniRemoveFilterChangeCallback(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- try |
- { |
- engine.RemoveFilterChangeCallback(); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static void JNICALL JniSetFilterChangeCallback(JNIEnv* env, jclass clazz, |
- jlong ptr, jlong filterPtr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- JniFilterChangeCallback* callback = JniLongToTypePtr<JniFilterChangeCallback>( |
- filterPtr); |
- |
- auto filterCallback = [callback](const std::string& arg, AdblockPlus::JsValue&& jsValue) |
- { |
- callback->Callback(arg, std::move(jsValue)); |
- }; |
- |
- try |
- { |
- engine.SetFilterChangeCallback(filterCallback); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static void JNICALL JniForceUpdateCheck(JNIEnv* env, jclass clazz, jlong ptr, jlong updaterPtr) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- JniUpdateCheckDoneCallback* callback = |
- JniLongToTypePtr<JniUpdateCheckDoneCallback>(updaterPtr); |
- |
- AdblockPlus::FilterEngine::UpdateCheckDoneCallback |
- updateCheckDoneCallback = 0; |
- |
- if (updaterPtr) |
- { |
- updateCheckDoneCallback = |
- std::bind(&JniUpdateCheckDoneCallback::Callback, callback, |
- std::placeholders::_1); |
- } |
- |
- try |
- { |
- engine.ForceUpdateCheck(updateCheckDoneCallback); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static jobject JNICALL JniGetElementHidingSelectors(JNIEnv* env, jclass clazz, |
- jlong ptr, jstring jDomain) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string domain = JniJavaToStdString(env, jDomain); |
- |
- try |
- { |
- std::vector<std::string> selectors = engine.GetElementHidingSelectors( |
- domain); |
- |
- jobject list = NewJniArrayList(env); |
- |
- for (std::vector<std::string>::iterator it = selectors.begin(), end = |
- selectors.end(); it != end; it++) |
- { |
- JniAddObjectToList(env, list, |
- *JniLocalReference<jstring>(env, env->NewStringUTF(it->c_str()))); |
- } |
- |
- return list; |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static jobject JNICALL JniMatches(JNIEnv* env, jclass clazz, jlong ptr, jstring jUrl, jobject jContentType, jstring jDocumentUrl) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string url = JniJavaToStdString(env, jUrl); |
- AdblockPlus::FilterEngine::ContentType contentType = |
- ConvertContentType(env, jContentType); |
- std::string documentUrl = JniJavaToStdString(env, jDocumentUrl); |
- |
- try |
- { |
- AdblockPlus::FilterPtr filterPtr = engine.Matches(url, contentType, documentUrl); |
- |
- return filterPtr.get() ? NewJniFilter(env, std::move(*filterPtr)) : 0; |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static void JavaStringArrayToStringVector(JNIEnv* env, jobjectArray jArray, |
- std::vector<std::string>& out) |
-{ |
- if (jArray) |
- { |
- jsize len = env->GetArrayLength(jArray); |
- |
- for (jsize i = 0; i < len; i++) |
- { |
- out.push_back( |
- JniJavaToStdString(env, |
- *JniLocalReference<jstring>(env, |
- static_cast<jstring>( |
- env->GetObjectArrayElement(jArray, i))))); |
- } |
- } |
-} |
- |
-static jobject JNICALL JniMatchesMany(JNIEnv* env, jclass clazz, jlong ptr, |
- jstring jUrl, jobject jContentType, jobjectArray jDocumentUrls) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string url = JniJavaToStdString(env, jUrl); |
- AdblockPlus::FilterEngine::ContentType contentType = |
- ConvertContentType(env, jContentType); |
- |
- std::vector<std::string> documentUrls; |
- JavaStringArrayToStringVector(env, jDocumentUrls, documentUrls); |
- |
- try |
- { |
- AdblockPlus::FilterPtr filterPtr = engine.Matches(url, contentType, documentUrls); |
- |
- return (filterPtr.get() ? NewJniFilter(env, std::move(*filterPtr)) : 0); |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static jboolean JNICALL JniIsDocumentWhitelisted(JNIEnv* env, jclass clazz, jlong ptr, |
- jstring jUrl, jobjectArray jDocumentUrls) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string url = JniJavaToStdString(env, jUrl); |
- std::vector<std::string> documentUrls; |
- JavaStringArrayToStringVector(env, jDocumentUrls, documentUrls); |
- try |
- { |
- return engine.IsDocumentWhitelisted(url, documentUrls) ? |
- JNI_TRUE : JNI_FALSE; |
- } |
- CATCH_THROW_AND_RETURN(env, JNI_FALSE) |
-} |
- |
-static jboolean JNICALL JniIsElemhideWhitelisted(JNIEnv* env, jclass clazz, jlong ptr, |
- jstring jUrl, jobjectArray jDocumentUrls) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string url = JniJavaToStdString(env, jUrl); |
- std::vector<std::string> documentUrls; |
- JavaStringArrayToStringVector(env, jDocumentUrls, documentUrls); |
- try |
- { |
- return engine.IsElemhideWhitelisted(url, documentUrls) ? |
- JNI_TRUE : JNI_FALSE; |
- } |
- CATCH_THROW_AND_RETURN(env, JNI_FALSE) |
-} |
- |
-static jobject JNICALL JniGetPref(JNIEnv* env, jclass clazz, jlong ptr, jstring jPref) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string pref = JniJavaToStdString(env, jPref); |
- |
- try |
- { |
- return NewJniJsValue(env, engine.GetPref(pref)); |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static void JNICALL JniSetPref(JNIEnv* env, jclass clazz, jlong ptr, jstring jPref, jlong jsValue) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string pref = JniJavaToStdString(env, jPref); |
- const AdblockPlus::JsValue& value = JniGetJsValue(jsValue); |
- |
- try |
- { |
- engine.SetPref(pref, value); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static jstring JNICALL JniGetHostFromURL(JNIEnv* env, jclass clazz, jlong ptr, jstring jurl) |
-{ |
- if (jurl == NULL) |
- { |
- return NULL; |
- } |
- |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string url = JniJavaToStdString(env, jurl); |
- try |
- { |
- std::string host = engine.GetHostFromURL(url); |
- |
- return JniStdStringToJava(env, host); |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static void JNICALL JniSetAllowedConnectionType(JNIEnv* env, jclass clazz, jlong ptr, jstring jvalue) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- std::string stdValue; |
- const std::string* value = (jvalue != NULL |
- ? &(stdValue = JniJavaToStdString(env, jvalue)) |
- : NULL); |
- |
- try |
- { |
- engine.SetAllowedConnectionType(value); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static jstring JNICALL JniGetAllowedConnectionType(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- try |
- { |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- std::unique_ptr<std::string> value = engine.GetAllowedConnectionType(); |
- |
- if (value == NULL) |
- { |
- return NULL; |
- } |
- |
- return JniStdStringToJava(env, *value.get()); |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static void JNICALL JniSetAcceptableAdsEnabled(JNIEnv* env, jclass clazz, jlong ptr, jboolean jvalue) |
-{ |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- |
- try |
- { |
- engine.SetAAEnabled(jvalue == JNI_TRUE); |
- } |
- CATCH_AND_THROW(env) |
-} |
- |
-static jboolean JNICALL JniIsAcceptableAdsEnabled(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- try |
- { |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- return engine.IsAAEnabled() ? JNI_TRUE : JNI_FALSE; |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static jstring JNICALL JniGetAcceptableAdsSubscriptionURL(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- try |
- { |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- std::string url = engine.GetAAUrl(); |
- return JniStdStringToJava(env, url); |
- } |
- CATCH_THROW_AND_RETURN(env, 0) |
-} |
- |
-static void JNICALL JniUpdateFiltersAsync(JNIEnv* env, jclass clazz, jlong jniPlatformPtr, jstring jSubscriptionUrl) |
-{ |
- std::string subscriptionUrl = JniJavaToStdString(env, jSubscriptionUrl); |
- auto jniPlatform = JniLongToTypePtr<JniPlatform>(jniPlatformPtr); |
- jniPlatform->scheduler([jniPlatform, subscriptionUrl] |
- { |
- auto& filterEngine = jniPlatform->platform->GetFilterEngine(); |
- for (auto& subscription : filterEngine.GetListedSubscriptions()) |
- { |
- if (stringBeginsWith(subscriptionUrl, subscription.GetProperty("url").AsString())) |
- { |
- subscription.UpdateFilters(); |
- return; |
- } |
- } |
- }); |
-} |
- |
-static jlong JNICALL JniGetFilterEngineNativePtr(JNIEnv* env, jclass clazz, jlong ptr) |
-{ |
- try |
- { |
- AdblockPlus::FilterEngine& engine = GetFilterEngineRef(ptr); |
- return (jlong)&engine; |
- } |
- CATCH_THROW_AND_RETURN(env, 0); |
-} |
- |
-static JNINativeMethod methods[] = |
-{ |
- { (char*)"isFirstRun", (char*)"(J)Z", (void*)JniIsFirstRun }, |
- { (char*)"getFilter", (char*)"(JLjava/lang/String;)" TYP("Filter"), (void*)JniGetFilter }, |
- { (char*)"getListedFilters", (char*)"(J)Ljava/util/List;", (void*)JniGetListedFilters }, |
- { (char*)"getSubscription", (char*)"(JLjava/lang/String;)" TYP("Subscription"), (void*)JniGetSubscription }, |
- { (char*)"showNextNotification", (char*)"(JLjava/lang/String;)V", (void*)JniShowNextNotification }, |
- { (char*)"setShowNotificationCallback", (char*)"(JJ)V", (void*)JniSetShowNotificationCallback }, |
- { (char*)"removeShowNotificationCallback", (char*)"(J)V", (void*)JniRemoveShowNotificationCallback }, |
- { (char*)"getListedSubscriptions", (char*)"(J)Ljava/util/List;", (void*)JniGetListedSubscriptions }, |
- { (char*)"fetchAvailableSubscriptions", (char*)"(J)Ljava/util/List;", (void*)JniFetchAvailableSubscriptions }, |
- { (char*)"setUpdateAvailableCallback", (char*)"(JJ)V", (void*)JniSetUpdateAvailableCallback }, |
- { (char*)"removeUpdateAvailableCallback", (char*)"(J)V", (void*)JniRemoveUpdateAvailableCallback }, |
- { (char*)"setFilterChangeCallback", (char*)"(JJ)V", (void*)JniSetFilterChangeCallback }, |
- { (char*)"removeFilterChangeCallback", (char*)"(J)V", (void*)JniRemoveFilterChangeCallback }, |
- { (char*)"forceUpdateCheck", (char*)"(JJ)V", (void*)JniForceUpdateCheck }, |
- { (char*)"getElementHidingSelectors", (char*)"(JLjava/lang/String;)Ljava/util/List;", (void*)JniGetElementHidingSelectors }, |
- { (char*)"matches", (char*)"(JLjava/lang/String;" TYP("FilterEngine$ContentType") "Ljava/lang/String;)" TYP("Filter"), (void*)JniMatches }, |
- { (char*)"matches", (char*)"(JLjava/lang/String;" TYP("FilterEngine$ContentType") "[Ljava/lang/String;)" TYP("Filter"), (void*)JniMatchesMany }, |
- { (char*)"isDocumentWhitelisted", (char*)"(JLjava/lang/String;[Ljava/lang/String;)Z", (void*)JniIsDocumentWhitelisted }, |
- { (char*)"isElemhideWhitelisted", (char*)"(JLjava/lang/String;[Ljava/lang/String;)Z", (void*)JniIsElemhideWhitelisted }, |
- { (char*)"getPref", (char*)"(JLjava/lang/String;)" TYP("JsValue"), (void*)JniGetPref }, |
- { (char*)"setPref", (char*)"(JLjava/lang/String;J)V", (void*)JniSetPref }, |
- { (char*)"getHostFromURL", (char*)"(JLjava/lang/String;)Ljava/lang/String;", (void*)JniGetHostFromURL }, |
- { (char*)"setAllowedConnectionType", (char*)"(JLjava/lang/String;)V", (void*)JniSetAllowedConnectionType }, |
- { (char*)"getAllowedConnectionType", (char*)"(J)Ljava/lang/String;", (void*)JniGetAllowedConnectionType }, |
- { (char*)"setAcceptableAdsEnabled", (char*)"(JZ)V", (void*)JniSetAcceptableAdsEnabled }, |
- { (char*)"isAcceptableAdsEnabled", (char*)"(J)Z", (void*)JniIsAcceptableAdsEnabled }, |
- { (char*)"getAcceptableAdsSubscriptionURL", (char*)"(J)Ljava/lang/String;", (void*)JniGetAcceptableAdsSubscriptionURL }, |
- { (char*)"updateFiltersAsync", (char*)"(JLjava/lang/String;)V", (void*)JniUpdateFiltersAsync }, |
- { (char*)"getNativePtr", (char*)"(J)J", (void*)JniGetFilterEngineNativePtr } |
-}; |
- |
-extern "C" JNIEXPORT void JNICALL Java_org_adblockplus_libadblockplus_FilterEngine_registerNatives(JNIEnv *env, jclass clazz) |
-{ |
- env->RegisterNatives(clazz, methods, sizeof(methods) / sizeof(methods[0])); |
-} |