Index: libadblockplus-android/src/org/adblockplus/libadblockplus/Platform.java |
diff --git a/libadblockplus-android/src/org/adblockplus/libadblockplus/Platform.java b/libadblockplus-android/src/org/adblockplus/libadblockplus/Platform.java |
new file mode 100644 |
index 0000000000000000000000000000000000000000..2534ced55a0c369ed65d17409d0e55b63e6cc62f |
--- /dev/null |
+++ b/libadblockplus-android/src/org/adblockplus/libadblockplus/Platform.java |
@@ -0,0 +1,108 @@ |
+/* |
+ * 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/>. |
+ */ |
+ |
+package org.adblockplus.libadblockplus; |
+ |
+public class Platform implements Disposable |
+{ |
+ private final Disposer disposer; |
+ protected final long ptr; |
+ |
+ static |
+ { |
+ System.loadLibrary("adblockplus-jni"); |
+ registerNatives(); |
+ } |
+ |
+ public Platform(final LogSystem logSystem, final WebRequest webRequest, final String basePath) |
+ { |
+ this(ctor(logSystem, webRequest, basePath)); |
+ } |
+ |
+ public Platform(final WebRequest webRequest, final String basePath) |
+ { |
+ this(null, webRequest, basePath); |
+ } |
+ |
+ public Platform() |
+ { |
+ this(null, null, null); |
anton
2017/09/06 06:21:28
it would be great to have some comment, how it wor
sergei
2017/09/08 09:45:02
I have added the comment to the constructor above
|
+ } |
+ |
+ protected Platform(final long ptr) |
+ { |
+ this.ptr = ptr; |
+ this.disposer = new Disposer(this, new DisposeWrapper(ptr)); |
+ } |
+ |
+ public void setUpJsEngine(final AppInfo appInfo) |
+ { |
+ setUpJsEngine(this.ptr, appInfo); |
+ } |
+ |
+ public JsEngine getJsEngine() |
+ { |
+ return new JsEngine(getJsEnginePtr(this.ptr)); |
anton
2017/09/06 06:21:27
why JsEngine accepts js engine ptr, but filter eng
anton
2017/09/06 06:21:28
what's the purpose of creating new instance every
sergei
2017/09/08 09:45:02
Short story is to keep it simple.
The main thing
sergei
2017/09/08 09:45:02
I think that generally corresponding Java classes
anton
2017/09/08 10:19:19
I'd say `getter` task is to `get`, not `create`. O
sergei
2017/09/08 12:25:30
getXXX methods create the corresponding entities o
|
+ } |
+ |
+ public void setUpFilterEngine(final IsAllowedConnectionCallback isSubscriptionDownloadAllowedCallback) |
+ { |
+ setUpFilterEngine(this.ptr, isSubscriptionDownloadAllowedCallback); |
+ } |
+ |
+ public FilterEngine getFilterEngine() |
+ { |
+ ensureFilterEngine(this.ptr); |
anton
2017/09/06 06:21:28
what does `ensure..` do? it's absolutely unclear w
sergei
2017/09/08 09:45:02
Done.
BTW, I expect that the interface of Platform
|
+ return new FilterEngine(this.ptr); |
anton
2017/09/06 06:21:28
same here - what's the purpose of creating new ins
sergei
2017/09/08 09:45:02
see comment for getJsEngine
|
+ } |
+ |
+ @Override |
+ public void dispose() |
+ { |
+ this.disposer.dispose(); |
+ } |
+ |
+ private final static class DisposeWrapper implements Disposable |
+ { |
+ private final long ptr; |
+ |
+ public DisposeWrapper(final long ptr) |
+ { |
+ this.ptr = ptr; |
+ } |
+ |
+ @Override |
+ public void dispose() |
+ { |
+ dtor(this.ptr); |
+ } |
+ } |
+ |
+ private final static native void registerNatives(); |
+ |
+ private final static native long ctor(LogSystem logSystem, WebRequest webRequest, String basePath); |
+ |
+ private final static native void setUpJsEngine(long ptr, AppInfo appInfo); |
+ |
+ private final static native long getJsEnginePtr(long ptr); |
+ |
+ private final static native void setUpFilterEngine(long ptr, IsAllowedConnectionCallback isSubscriptionDownloadAllowedCallback); |
+ |
+ private final static native void ensureFilterEngine(long ptr); |
+ |
+ private final static native void dtor(long ptr); |
+} |