Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(644)

Unified Diff: content/public/android/java/src/org/chromium/content/browser/AppWebMessagePortService.java

Issue 2422793002: HTML MessagePort as mojo::MessagePipeHandle (Closed)
Patch Set: Rebase Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/public/android/java/src/org/chromium/content/browser/AppWebMessagePortService.java
diff --git a/content/public/android/java/src/org/chromium/content/browser/AppWebMessagePortService.java b/content/public/android/java/src/org/chromium/content/browser/AppWebMessagePortService.java
index b908901c253ca0a07d067c4951ebb0b2f1ed75f1..612e5321d445cfc97c9c2394c0392a504d037253 100644
--- a/content/public/android/java/src/org/chromium/content/browser/AppWebMessagePortService.java
+++ b/content/public/android/java/src/org/chromium/content/browser/AppWebMessagePortService.java
@@ -4,10 +4,6 @@
package org.chromium.content.browser;
-import android.util.SparseArray;
-
-import org.chromium.base.ObserverList;
-import org.chromium.base.ThreadUtils;
import org.chromium.base.annotations.CalledByNative;
import org.chromium.base.annotations.JNINamespace;
import org.chromium.content_public.browser.MessagePortService;
@@ -37,120 +33,15 @@ import org.chromium.content_public.browser.MessagePortService;
public class AppWebMessagePortService implements MessagePortService {
private static final String TAG = "AppWebMessagePortService";
- /**
- * Observer for MessageChannel events.
- */
- public static interface MessageChannelObserver { void onMessageChannelCreated(); }
-
- // A thread safe storage for Message Ports.
- private static class MessagePortStorage {
- private SparseArray<AppWebMessagePort> mMessagePorts = new SparseArray<AppWebMessagePort>();
- private final Object mLock = new Object();
-
- public void remove(int portId) {
- synchronized (mLock) {
- mMessagePorts.remove(portId);
- }
- }
-
- public void put(int portId, AppWebMessagePort m) {
- synchronized (mLock) {
- mMessagePorts.put(portId, m);
- }
- }
- public AppWebMessagePort get(int portId) {
- synchronized (mLock) {
- return mMessagePorts.get(portId);
- }
- }
- }
-
private long mNativeMessagePortService;
- private MessagePortStorage mPortStorage = new MessagePortStorage();
- private ObserverList<MessageChannelObserver> mObserverList =
- new ObserverList<MessageChannelObserver>();
public AppWebMessagePortService() {
mNativeMessagePortService = nativeInitAppWebMessagePortService();
}
- public void addObserver(MessageChannelObserver observer) {
- mObserverList.addObserver(observer);
- }
-
- public void removeObserver(MessageChannelObserver observer) {
- mObserverList.removeObserver(observer);
- }
-
- public void closePort(int messagePortId) {
- mPortStorage.remove(messagePortId);
- if (mNativeMessagePortService == 0) return;
- nativeClosePort(mNativeMessagePortService, messagePortId);
- }
-
- public void postMessage(int senderId, String message, int[] sentPorts) {
- // verify that the port is owned by service still (not transferred).
- if (mPortStorage.get(senderId) == null) {
- throw new IllegalStateException("Cannot post to unknown port " + senderId);
- }
- if (mNativeMessagePortService == 0) return;
- nativePostAppToWebMessage(mNativeMessagePortService, senderId, message, sentPorts);
- }
-
- public void removeSentPorts(int[] sentPorts) {
- // verify that this service still owns all the ports that are transferred
- if (sentPorts != null) {
- for (int port : sentPorts) {
- AppWebMessagePort p = mPortStorage.get(port);
- if (p == null) {
- throw new IllegalStateException("Cannot transfer unknown port " + port);
- }
- mPortStorage.remove(port);
- }
- }
- }
-
@Override
public AppWebMessagePort[] createMessageChannel() {
- return new AppWebMessagePort[] {new AppWebMessagePort(this), new AppWebMessagePort(this)};
- }
-
- // Called on UI thread.
- public void releaseMessages(int portId) {
- if (mNativeMessagePortService == 0) return;
- nativeReleaseMessages(mNativeMessagePortService, portId);
- }
-
- private AppWebMessagePort addPort(AppWebMessagePort m, int portId) {
- if (mPortStorage.get(portId) != null) {
- throw new IllegalStateException("Port already exists");
- }
- m.setPortId(portId);
- mPortStorage.put(portId, m);
- return m;
- }
-
- @CalledByNative
- private void onMessageChannelCreated(int portId1, int portId2, AppWebMessagePort[] ports) {
- ThreadUtils.assertOnUiThread();
- addPort(ports[0], portId1);
- addPort(ports[1], portId2);
- for (MessageChannelObserver observer : mObserverList) {
- observer.onMessageChannelCreated();
- }
- }
-
- // Called on IO thread.
- @CalledByNative
- private void onReceivedMessage(int portId, String message, int[] ports) {
- AppWebMessagePort[] messagePorts = null;
- for (int i = 0; i < ports.length; i++) {
- if (messagePorts == null) {
- messagePorts = new AppWebMessagePort[ports.length];
- }
- messagePorts[i] = addPort(new AppWebMessagePort(this), ports[i]);
- }
- mPortStorage.get(portId).onReceivedMessage(message, messagePorts);
+ return new AppWebMessagePort[] {new AppWebMessagePort(), new AppWebMessagePort()};
Yusuf 2017/01/26 22:53:54 does this mean, we maybe don't need this class to
sgurun-gerrit only 2017/01/27 01:16:37 yes, that is what I noticed too. please get rid o
}
@CalledByNative
@@ -159,9 +50,4 @@ public class AppWebMessagePortService implements MessagePortService {
}
private native long nativeInitAppWebMessagePortService();
- private native void nativePostAppToWebMessage(
- long nativeAppWebMessagePortServiceImpl, int senderId, String message, int[] portIds);
- private native void nativeClosePort(long nativeAppWebMessagePortServiceImpl, int messagePortId);
- private native void nativeReleaseMessages(
- long nativeAppWebMessagePortServiceImpl, int messagePortId);
}

Powered by Google App Engine
This is Rietveld 408576698