| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 1 /* | 1 /* |
| 2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
| 3 * Copyright (C) 2006-2015 Eyeo GmbH | 3 * Copyright (C) 2006-2015 Eyeo GmbH |
| 4 * | 4 * |
| 5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
| 6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
| 7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
| 8 * | 8 * |
| 9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
| 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| (...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 111 | 111 |
| 112 try | 112 try |
| 113 { | 113 { |
| 114 AdblockPlus::SubscriptionPtr subscription = engine->GetSubscription(url); | 114 AdblockPlus::SubscriptionPtr subscription = engine->GetSubscription(url); |
| 115 | 115 |
| 116 return NewJniSubscription(env, subscription); | 116 return NewJniSubscription(env, subscription); |
| 117 } | 117 } |
| 118 CATCH_THROW_AND_RETURN(env, 0); | 118 CATCH_THROW_AND_RETURN(env, 0); |
| 119 } | 119 } |
| 120 | 120 |
| 121 static jobject JNICALL JniGetNextNotificationToShow(JNIEnv* env, jclass clazz, j long ptr, jstring jUrl) | 121 /** |
|
Felix Dahlke
2015/11/20 07:53:52
I don't really get this part - this is the first t
René Jeschke
2015/11/20 12:19:15
Argh, sry, left-over from copy'n'paste for impleme
| |
| 122 * Sets the callback invoked when a notification should be shown. | |
| 123 * @param callback Callback to invoke. | |
| 124 */ | |
| 125 //void SetShowNotificationCallback(const ShowNotificationCallback& value); | |
| 126 | |
| 127 static void JNICALL JniShowNextNotification(JNIEnv* env, jclass clazz, jlong ptr , jstring jUrl) | |
| 122 { | 128 { |
| 123 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); | 129 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); |
| 124 std::string url = JniJavaToStdString(env, jUrl); | 130 std::string url = JniJavaToStdString(env, jUrl); |
| 125 | 131 |
| 126 try | 132 try |
| 127 { | 133 { |
| 128 AdblockPlus::NotificationPtr notification = engine->GetNextNotificationToSho w(url); | 134 engine->ShowNextNotification(url); |
| 135 } | |
| 136 CATCH_AND_THROW(env); | |
| 137 } | |
| 129 | 138 |
| 130 return NewJniNotification(env, notification); | 139 static void JNICALL JniSetShowNotificationCallback(JNIEnv* env, jclass clazz, |
| 140 jlong ptr, jlong callbackPtr) | |
| 141 { | |
| 142 AdblockPlus::FilterEngine* const engine = | |
| 143 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); | |
| 144 JniShowNotificationCallback* const callback = | |
| 145 JniLongToTypePtr<JniShowNotificationCallback>(callbackPtr); | |
| 146 AdblockPlus::FilterEngine::ShowNotificationCallback showNotificationCallback = | |
| 147 std::bind(&JniShowNotificationCallback::Callback, callback, | |
| 148 std::placeholders::_1); | |
| 149 try | |
| 150 { | |
| 151 engine->SetShowNotificationCallback(showNotificationCallback); | |
| 131 } | 152 } |
| 132 CATCH_THROW_AND_RETURN(env, 0); | 153 CATCH_AND_THROW(env) |
| 154 } | |
| 155 | |
| 156 static void JNICALL JniRemoveShowNotificationCallback(JNIEnv* env, jclass clazz, jlong ptr) | |
| 157 { | |
| 158 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); | |
| 159 | |
| 160 try | |
| 161 { | |
| 162 engine->RemoveShowNotificationCallback(); | |
| 163 } | |
| 164 CATCH_AND_THROW(env); | |
| 133 } | 165 } |
| 134 | 166 |
| 135 static jobject JNICALL JniGetListedSubscriptions(JNIEnv* env, jclass clazz, jlon g ptr) | 167 static jobject JNICALL JniGetListedSubscriptions(JNIEnv* env, jclass clazz, jlon g ptr) |
| 136 { | 168 { |
| 137 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); | 169 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); |
| 138 | 170 |
| 139 try | 171 try |
| 140 { | 172 { |
| 141 std::vector<AdblockPlus::SubscriptionPtr> subscriptions = engine->GetListedS ubscriptions(); | 173 std::vector<AdblockPlus::SubscriptionPtr> subscriptions = engine->GetListedS ubscriptions(); |
| 142 | 174 |
| (...skipping 28 matching lines...) Expand all Loading... | |
| 171 } | 203 } |
| 172 | 204 |
| 173 static void JNICALL JniSetUpdateAvailableCallback(JNIEnv* env, jclass clazz, | 205 static void JNICALL JniSetUpdateAvailableCallback(JNIEnv* env, jclass clazz, |
| 174 jlong ptr, jlong callbackPtr) | 206 jlong ptr, jlong callbackPtr) |
| 175 { | 207 { |
| 176 AdblockPlus::FilterEngine* const engine = | 208 AdblockPlus::FilterEngine* const engine = |
| 177 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); | 209 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); |
| 178 JniUpdateAvailableCallback* const callback = | 210 JniUpdateAvailableCallback* const callback = |
| 179 JniLongToTypePtr<JniUpdateAvailableCallback>(callbackPtr); | 211 JniLongToTypePtr<JniUpdateAvailableCallback>(callbackPtr); |
| 180 AdblockPlus::FilterEngine::UpdateAvailableCallback updateAvailableCallback = | 212 AdblockPlus::FilterEngine::UpdateAvailableCallback updateAvailableCallback = |
| 181 std::tr1::bind(&JniUpdateAvailableCallback::Callback, callback, | 213 std::bind(&JniUpdateAvailableCallback::Callback, callback, |
| 182 std::tr1::placeholders::_1); | 214 std::placeholders::_1); |
| 183 try | 215 try |
| 184 { | 216 { |
| 185 engine->SetUpdateAvailableCallback(updateAvailableCallback); | 217 engine->SetUpdateAvailableCallback(updateAvailableCallback); |
| 186 } | 218 } |
| 187 CATCH_AND_THROW(env) | 219 CATCH_AND_THROW(env) |
| 188 } | 220 } |
| 189 | 221 |
| 190 static void JNICALL JniRemoveFilterChangeCallback(JNIEnv* env, jclass clazz, jlo ng ptr) | 222 static void JNICALL JniRemoveFilterChangeCallback(JNIEnv* env, jclass clazz, jlo ng ptr) |
| 191 { | 223 { |
| 192 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); | 224 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); |
| 193 | 225 |
| 194 try | 226 try |
| 195 { | 227 { |
| 196 engine->RemoveFilterChangeCallback(); | 228 engine->RemoveFilterChangeCallback(); |
| 197 } | 229 } |
| 198 CATCH_AND_THROW(env) | 230 CATCH_AND_THROW(env) |
| 199 } | 231 } |
| 200 | 232 |
| 201 static void JNICALL JniSetFilterChangeCallback(JNIEnv* env, jclass clazz, | 233 static void JNICALL JniSetFilterChangeCallback(JNIEnv* env, jclass clazz, |
| 202 jlong ptr, jlong filterPtr) | 234 jlong ptr, jlong filterPtr) |
| 203 { | 235 { |
| 204 AdblockPlus::FilterEngine* engine = | 236 AdblockPlus::FilterEngine* engine = |
| 205 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); | 237 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); |
| 206 JniFilterChangeCallback* callback = JniLongToTypePtr<JniFilterChangeCallback>( | 238 JniFilterChangeCallback* callback = JniLongToTypePtr<JniFilterChangeCallback>( |
| 207 filterPtr); | 239 filterPtr); |
| 208 | 240 |
| 209 AdblockPlus::FilterEngine::FilterChangeCallback filterCallback = | 241 AdblockPlus::FilterEngine::FilterChangeCallback filterCallback = |
| 210 std::tr1::bind(&JniFilterChangeCallback::Callback, callback, | 242 std::bind(&JniFilterChangeCallback::Callback, callback, |
| 211 std::tr1::placeholders::_1, std::tr1::placeholders::_2); | 243 std::placeholders::_1, std::placeholders::_2); |
| 212 | 244 |
| 213 try | 245 try |
| 214 { | 246 { |
| 215 engine->SetFilterChangeCallback(filterCallback); | 247 engine->SetFilterChangeCallback(filterCallback); |
| 216 } | 248 } |
| 217 CATCH_AND_THROW(env) | 249 CATCH_AND_THROW(env) |
| 218 } | 250 } |
| 219 | 251 |
| 220 static void JNICALL JniForceUpdateCheck(JNIEnv* env, jclass clazz, jlong ptr, jl ong updaterPtr) | 252 static void JNICALL JniForceUpdateCheck(JNIEnv* env, jclass clazz, jlong ptr, jl ong updaterPtr) |
| 221 { | 253 { |
| 222 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); | 254 AdblockPlus::FilterEngine* engine = JniLongToTypePtr<AdblockPlus::FilterEngine >(ptr); |
| 223 JniUpdateCheckDoneCallback* callback = | 255 JniUpdateCheckDoneCallback* callback = |
| 224 JniLongToTypePtr<JniUpdateCheckDoneCallback>(updaterPtr); | 256 JniLongToTypePtr<JniUpdateCheckDoneCallback>(updaterPtr); |
| 225 | 257 |
| 226 AdblockPlus::FilterEngine::UpdateCheckDoneCallback | 258 AdblockPlus::FilterEngine::UpdateCheckDoneCallback |
| 227 updateCheckDoneCallback = 0; | 259 updateCheckDoneCallback = 0; |
| 228 | 260 |
| 229 if (updaterPtr) | 261 if (updaterPtr) |
| 230 { | 262 { |
| 231 updateCheckDoneCallback = | 263 updateCheckDoneCallback = |
| 232 std::tr1::bind(&JniUpdateCheckDoneCallback::Callback, callback, | 264 std::bind(&JniUpdateCheckDoneCallback::Callback, callback, |
| 233 std::tr1::placeholders::_1); | 265 std::placeholders::_1); |
| 234 } | 266 } |
| 235 | 267 |
| 236 try | 268 try |
| 237 { | 269 { |
| 238 engine->ForceUpdateCheck(updateCheckDoneCallback); | 270 engine->ForceUpdateCheck(updateCheckDoneCallback); |
| 239 } | 271 } |
| 240 CATCH_AND_THROW(env) | 272 CATCH_AND_THROW(env) |
| 241 } | 273 } |
| 242 | 274 |
| 243 static jobject JNICALL JniGetElementHidingSelectors(JNIEnv* env, jclass clazz, | 275 static jobject JNICALL JniGetElementHidingSelectors(JNIEnv* env, jclass clazz, |
| (...skipping 103 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 347 CATCH_AND_THROW(env) | 379 CATCH_AND_THROW(env) |
| 348 } | 380 } |
| 349 | 381 |
| 350 static JNINativeMethod methods[] = | 382 static JNINativeMethod methods[] = |
| 351 { | 383 { |
| 352 { (char*)"ctor", (char*)"(J)J", (void*)JniCtor }, | 384 { (char*)"ctor", (char*)"(J)J", (void*)JniCtor }, |
| 353 { (char*)"isFirstRun", (char*)"(J)Z", (void*)JniIsFirstRun }, | 385 { (char*)"isFirstRun", (char*)"(J)Z", (void*)JniIsFirstRun }, |
| 354 { (char*)"getFilter", (char*)"(JLjava/lang/String;)" TYP("Filter"), (void*)Jni GetFilter }, | 386 { (char*)"getFilter", (char*)"(JLjava/lang/String;)" TYP("Filter"), (void*)Jni GetFilter }, |
| 355 { (char*)"getListedFilters", (char*)"(J)Ljava/util/List;", (void*)JniGetListed Filters }, | 387 { (char*)"getListedFilters", (char*)"(J)Ljava/util/List;", (void*)JniGetListed Filters }, |
| 356 { (char*)"getSubscription", (char*)"(JLjava/lang/String;)" TYP("Subscription") , (void*)JniGetSubscription }, | 388 { (char*)"getSubscription", (char*)"(JLjava/lang/String;)" TYP("Subscription") , (void*)JniGetSubscription }, |
| 357 { (char*)"getNextNotificationToShow", (char*)"(JLjava/lang/String;)" TYP("Noti fication"), (void*)JniGetNextNotificationToShow }, | 389 { (char*)"showNextNotification", (char*)"(JLjava/lang/String;)V", (void*)JniSh owNextNotification }, |
| 390 { (char*)"setShowNotificationCallback", (char*)"(JJ)V", (void*)JniSetShowNotif icationCallback }, | |
| 391 { (char*)"removeShowNotificationCallback", (char*)"(J)V", (void*)JniRemoveShow NotificationCallback }, | |
| 358 { (char*)"getListedSubscriptions", (char*)"(J)Ljava/util/List;", (void*)JniGet ListedSubscriptions }, | 392 { (char*)"getListedSubscriptions", (char*)"(J)Ljava/util/List;", (void*)JniGet ListedSubscriptions }, |
| 359 { (char*)"fetchAvailableSubscriptions", (char*)"(J)Ljava/util/List;", (void*)J niFetchAvailableSubscriptions }, | 393 { (char*)"fetchAvailableSubscriptions", (char*)"(J)Ljava/util/List;", (void*)J niFetchAvailableSubscriptions }, |
| 360 { (char*)"setUpdateAvailableCallback", (char*)"(JJ)V", (void*)JniSetUpdateAvai lableCallback }, | 394 { (char*)"setUpdateAvailableCallback", (char*)"(JJ)V", (void*)JniSetUpdateAvai lableCallback }, |
| 361 { (char*)"removeUpdateAvailableCallback", (char*)"(J)V", (void*)JniRemoveUpdat eAvailableCallback }, | 395 { (char*)"removeUpdateAvailableCallback", (char*)"(J)V", (void*)JniRemoveUpdat eAvailableCallback }, |
| 362 { (char*)"setFilterChangeCallback", (char*)"(JJ)V", (void*)JniSetFilterChangeC allback }, | 396 { (char*)"setFilterChangeCallback", (char*)"(JJ)V", (void*)JniSetFilterChangeC allback }, |
| 363 { (char*)"removeFilterChangeCallback", (char*)"(J)V", (void*)JniRemoveFilterCh angeCallback }, | 397 { (char*)"removeFilterChangeCallback", (char*)"(J)V", (void*)JniRemoveFilterCh angeCallback }, |
| 364 { (char*)"forceUpdateCheck", (char*)"(JJ)V", (void*)JniForceUpdateCheck }, | 398 { (char*)"forceUpdateCheck", (char*)"(JJ)V", (void*)JniForceUpdateCheck }, |
| 365 { (char*)"getElementHidingSelectors", (char*)"(JLjava/lang/String;)Ljava/util/ List;", (void*)JniGetElementHidingSelectors }, | 399 { (char*)"getElementHidingSelectors", (char*)"(JLjava/lang/String;)Ljava/util/ List;", (void*)JniGetElementHidingSelectors }, |
| 366 { (char*)"matches", (char*)"(JLjava/lang/String;" TYP("FilterEngine$ContentTyp e") "Ljava/lang/String;)" TYP("Filter"), (void*)JniMatches }, | 400 { (char*)"matches", (char*)"(JLjava/lang/String;" TYP("FilterEngine$ContentTyp e") "Ljava/lang/String;)" TYP("Filter"), (void*)JniMatches }, |
| 367 { (char*)"matches", (char*)"(JLjava/lang/String;" TYP("FilterEngine$ContentTyp e") "[Ljava/lang/String;)" TYP("Filter"), (void*)JniMatchesMany }, | 401 { (char*)"matches", (char*)"(JLjava/lang/String;" TYP("FilterEngine$ContentTyp e") "[Ljava/lang/String;)" TYP("Filter"), (void*)JniMatchesMany }, |
| 368 { (char*)"getPref", (char*)"(JLjava/lang/String;)" TYP("JsValue"), (void*)JniG etPref }, | 402 { (char*)"getPref", (char*)"(JLjava/lang/String;)" TYP("JsValue"), (void*)JniG etPref }, |
| 369 { (char*)"setPref", (char*)"(JLjava/lang/String;J)V", (void*)JniSetPref }, | 403 { (char*)"setPref", (char*)"(JLjava/lang/String;J)V", (void*)JniSetPref }, |
| 370 { (char*)"dtor", (char*)"(J)V", (void*)JniDtor } | 404 { (char*)"dtor", (char*)"(J)V", (void*)JniDtor } |
| 371 }; | 405 }; |
| 372 | 406 |
| 373 extern "C" JNIEXPORT void JNICALL Java_org_adblockplus_libadblockplus_FilterEngi ne_registerNatives(JNIEnv *env, jclass clazz) | 407 extern "C" JNIEXPORT void JNICALL Java_org_adblockplus_libadblockplus_FilterEngi ne_registerNatives(JNIEnv *env, jclass clazz) |
| 374 { | 408 { |
| 375 env->RegisterNatives(clazz, methods, sizeof(methods) / sizeof(methods[0])); | 409 env->RegisterNatives(clazz, methods, sizeof(methods) / sizeof(methods[0])); |
| 376 } | 410 } |
| OLD | NEW |