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..4be6dc445ca304045ea702ca6d4f5af6b14a01f2 |
--- /dev/null |
+++ b/libadblockplus-android/src/org/adblockplus/libadblockplus/Platform.java |
@@ -0,0 +1,106 @@ |
+/* |
+ * 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(); |
+ } |
+ |
+ // If an interface parameter value is null then a default implementation is |
anton
2017/09/08 10:54:22
it would be better to have javadoc (/**, not just
sergei
2017/09/08 12:25:30
Done.
|
+ // chosen. |
+ // If basePath is null then paths are not resolved to a full path, thus |
+ // current working directory is used. |
+ public Platform(final LogSystem logSystem, final WebRequest webRequest, final String basePath) |
+ { |
+ this(ctor(logSystem, webRequest, basePath)); |
+ } |
+ |
+ 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)); |
+ } |
+ |
+ public void setUpFilterEngine(final IsAllowedConnectionCallback isSubscriptionDownloadAllowedCallback) |
+ { |
+ setUpFilterEngine(this.ptr, isSubscriptionDownloadAllowedCallback); |
+ } |
+ |
+ public FilterEngine getFilterEngine() |
+ { |
+ // Initially FilterEngine is not constructed when Platform is instantiated |
+ // and in addition FilterEngine is being created asynchronously, the call |
+ // of `ensureFilterEngine` causes a construction of FilterEngine if it's |
+ // not created yet and waits for it. |
+ ensureFilterEngine(this.ptr); |
+ return new FilterEngine(this.ptr); |
+ } |
+ |
+ @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); |
+} |