Left: | ||
Right: |
LEFT | RIGHT |
---|---|
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 293 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
304 | 304 |
305 try | 305 try |
306 { | 306 { |
307 AdblockPlus::FilterPtr filter = engine->Matches(url, contentType, documentUr l); | 307 AdblockPlus::FilterPtr filter = engine->Matches(url, contentType, documentUr l); |
308 | 308 |
309 return NewJniFilter(env, filter); | 309 return NewJniFilter(env, filter); |
310 } | 310 } |
311 CATCH_THROW_AND_RETURN(env, 0) | 311 CATCH_THROW_AND_RETURN(env, 0) |
312 } | 312 } |
313 | 313 |
314 static void JavaStringArrayIntoStringVector(JNIEnv* env, jobjectArray jArray, | 314 static void JavaStringArrayToStringVector(JNIEnv* env, jobjectArray jArray, |
Felix Dahlke
2015/12/04 15:43:20
Nit: Seems like the name is inconsistent with the
René Jeschke
2015/12/04 15:55:59
Yes, this is because this is not a function that i
Felix Dahlke
2015/12/04 16:37:36
I'd personally prefer "To" but I don't care that m
René Jeschke
2015/12/04 16:54:47
Done.
| |
315 std::vector<std::string>& out) | 315 std::vector<std::string>& out) |
316 { | 316 { |
317 if (jArray) | 317 if (jArray) |
318 { | 318 { |
319 jsize len = env->GetArrayLength(jArray); | 319 jsize len = env->GetArrayLength(jArray); |
320 | 320 |
321 for (jsize i = 0; i < len; i++) | 321 for (jsize i = 0; i < len; i++) |
322 { | 322 { |
323 out.push_back( | 323 out.push_back( |
324 JniJavaToStdString(env, | 324 JniJavaToStdString(env, |
325 *JniLocalReference<jstring>(env, | 325 *JniLocalReference<jstring>(env, |
326 static_cast<jstring>( | 326 static_cast<jstring>( |
327 env->GetObjectArrayElement(jArray, i))))); | 327 env->GetObjectArrayElement(jArray, i))))); |
328 } | 328 } |
329 } | 329 } |
330 } | 330 } |
331 | 331 |
332 static jobject JNICALL JniMatchesMany(JNIEnv* env, jclass clazz, jlong ptr, | 332 static jobject JNICALL JniMatchesMany(JNIEnv* env, jclass clazz, jlong ptr, |
333 jstring jUrl, jobject jContentType, jobjectArray jDocumentUrls) | 333 jstring jUrl, jobject jContentType, jobjectArray jDocumentUrls) |
334 { | 334 { |
335 AdblockPlus::FilterEngine* engine = | 335 AdblockPlus::FilterEngine* engine = |
336 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); | 336 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); |
337 | 337 |
338 std::string url = JniJavaToStdString(env, jUrl); | 338 std::string url = JniJavaToStdString(env, jUrl); |
339 AdblockPlus::FilterEngine::ContentType contentType = | 339 AdblockPlus::FilterEngine::ContentType contentType = |
340 ConvertContentType(env, jContentType); | 340 ConvertContentType(env, jContentType); |
341 | 341 |
342 std::vector<std::string> documentUrls; | 342 std::vector<std::string> documentUrls; |
343 JavaStringArrayIntoStringVector(env, jDocumentUrls, documentUrls); | 343 JavaStringArrayToStringVector(env, jDocumentUrls, documentUrls); |
344 | 344 |
345 try | 345 try |
346 { | 346 { |
347 AdblockPlus::FilterPtr filter = engine->Matches(url, contentType, | 347 AdblockPlus::FilterPtr filter = engine->Matches(url, contentType, |
348 documentUrls); | 348 documentUrls); |
349 | 349 |
350 return NewJniFilter(env, filter); | 350 return NewJniFilter(env, filter); |
351 } | 351 } |
352 CATCH_THROW_AND_RETURN(env, 0) | 352 CATCH_THROW_AND_RETURN(env, 0) |
353 } | 353 } |
354 | 354 |
355 static jboolean JNICALL JniIsDocumentWhitelisted(JNIEnv* env, jclass clazz, jlon g ptr, | 355 static jboolean JNICALL JniIsDocumentWhitelisted(JNIEnv* env, jclass clazz, jlon g ptr, |
356 jstring jUrl, jobjectArray jDocumentUrls) | 356 jstring jUrl, jobjectArray jDocumentUrls) |
357 { | 357 { |
358 AdblockPlus::FilterEngine* engine = | 358 AdblockPlus::FilterEngine* engine = |
359 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); | 359 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); |
360 | 360 |
361 std::string url = JniJavaToStdString(env, jUrl); | 361 std::string url = JniJavaToStdString(env, jUrl); |
362 std::vector<std::string> documentUrls; | 362 std::vector<std::string> documentUrls; |
363 JavaStringArrayIntoStringVector(env, jDocumentUrls, documentUrls); | 363 JavaStringArrayToStringVector(env, jDocumentUrls, documentUrls); |
364 try | 364 try |
365 { | 365 { |
366 return engine->IsDocumentWhitelisted(url, documentUrls) ? | 366 return engine->IsDocumentWhitelisted(url, documentUrls) ? |
367 JNI_TRUE : JNI_FALSE; | 367 JNI_TRUE : JNI_FALSE; |
368 } | 368 } |
369 CATCH_THROW_AND_RETURN(env, JNI_FALSE) | 369 CATCH_THROW_AND_RETURN(env, JNI_FALSE) |
370 } | 370 } |
371 | 371 |
372 static jboolean JNICALL JniIsElemhideWhitelisted(JNIEnv* env, jclass clazz, jlon g ptr, | 372 static jboolean JNICALL JniIsElemhideWhitelisted(JNIEnv* env, jclass clazz, jlon g ptr, |
373 jstring jUrl, jobjectArray jDocumentUrls) | 373 jstring jUrl, jobjectArray jDocumentUrls) |
374 { | 374 { |
375 AdblockPlus::FilterEngine* engine = | 375 AdblockPlus::FilterEngine* engine = |
376 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); | 376 JniLongToTypePtr<AdblockPlus::FilterEngine>(ptr); |
377 | 377 |
378 std::string url = JniJavaToStdString(env, jUrl); | 378 std::string url = JniJavaToStdString(env, jUrl); |
379 std::vector<std::string> documentUrls; | 379 std::vector<std::string> documentUrls; |
380 JavaStringArrayIntoStringVector(env, jDocumentUrls, documentUrls); | 380 JavaStringArrayToStringVector(env, jDocumentUrls, documentUrls); |
381 try | 381 try |
382 { | 382 { |
383 return engine->IsElemhideWhitelisted(url, documentUrls) ? | 383 return engine->IsElemhideWhitelisted(url, documentUrls) ? |
384 JNI_TRUE : JNI_FALSE; | 384 JNI_TRUE : JNI_FALSE; |
385 } | 385 } |
386 CATCH_THROW_AND_RETURN(env, JNI_FALSE) | 386 CATCH_THROW_AND_RETURN(env, JNI_FALSE) |
387 } | 387 } |
388 | 388 |
389 static jobject JNICALL JniGetPref(JNIEnv* env, jclass clazz, jlong ptr, jstring jPref) | 389 static jobject JNICALL JniGetPref(JNIEnv* env, jclass clazz, jlong ptr, jstring jPref) |
390 { | 390 { |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
439 { (char*)"isElemhideWhitelisted", (char*)"(JLjava/lang/String;[Ljava/lang/Stri ng;)Z", (void*)JniIsElemhideWhitelisted }, | 439 { (char*)"isElemhideWhitelisted", (char*)"(JLjava/lang/String;[Ljava/lang/Stri ng;)Z", (void*)JniIsElemhideWhitelisted }, |
440 { (char*)"getPref", (char*)"(JLjava/lang/String;)" TYP("JsValue"), (void*)JniG etPref }, | 440 { (char*)"getPref", (char*)"(JLjava/lang/String;)" TYP("JsValue"), (void*)JniG etPref }, |
441 { (char*)"setPref", (char*)"(JLjava/lang/String;J)V", (void*)JniSetPref }, | 441 { (char*)"setPref", (char*)"(JLjava/lang/String;J)V", (void*)JniSetPref }, |
442 { (char*)"dtor", (char*)"(J)V", (void*)JniDtor } | 442 { (char*)"dtor", (char*)"(J)V", (void*)JniDtor } |
443 }; | 443 }; |
444 | 444 |
445 extern "C" JNIEXPORT void JNICALL Java_org_adblockplus_libadblockplus_FilterEngi ne_registerNatives(JNIEnv *env, jclass clazz) | 445 extern "C" JNIEXPORT void JNICALL Java_org_adblockplus_libadblockplus_FilterEngi ne_registerNatives(JNIEnv *env, jclass clazz) |
446 { | 446 { |
447 env->RegisterNatives(clazz, methods, sizeof(methods) / sizeof(methods[0])); | 447 env->RegisterNatives(clazz, methods, sizeof(methods) / sizeof(methods[0])); |
448 } | 448 } |
LEFT | RIGHT |