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

Unified Diff: content/browser/renderer_host/java/java_bridge_dispatcher_host.cc

Issue 8890018: Update Java Bridge to use its own thread in the browser process (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Use class rather than traits Created 9 years 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
« no previous file with comments | « content/browser/renderer_host/java/java_bridge_dispatcher_host.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/browser/renderer_host/java/java_bridge_dispatcher_host.cc
diff --git a/content/browser/renderer_host/java/java_bridge_dispatcher_host.cc b/content/browser/renderer_host/java/java_bridge_dispatcher_host.cc
index 51335e092418918cef8988adc1ab8b4b3d4d4642..831a6dde1561165b9182921f0d003688f629c563 100644
--- a/content/browser/renderer_host/java/java_bridge_dispatcher_host.cc
+++ b/content/browser/renderer_host/java/java_bridge_dispatcher_host.cc
@@ -5,7 +5,8 @@
#include "content/browser/renderer_host/java/java_bridge_dispatcher_host.h"
#include "base/bind.h"
-#include "content/browser/renderer_host/browser_render_process_host.h"
+#include "base/lazy_instance.h"
+#include "base/threading/thread.h"
#include "content/browser/renderer_host/java/java_bridge_channel_host.h"
#include "content/browser/renderer_host/render_view_host.h"
#include "content/common/child_process.h"
@@ -17,6 +18,20 @@
using content::BrowserThread;
+namespace {
+class JavaBridgeThread : public base::Thread {
+ public:
+ JavaBridgeThread() : base::Thread("JavaBridge") {
+ Start();
+ }
+ virtual ~JavaBridgeThread() {
+ Stop();
+ }
+};
+base::LazyInstance<JavaBridgeThread> g_background_thread =
+ LAZY_INSTANCE_INITIALIZER;
+} // namespace
+
JavaBridgeDispatcherHost::JavaBridgeDispatcherHost(
RenderViewHost* render_view_host)
: RenderViewHostObserver(render_view_host),
@@ -62,13 +77,7 @@ bool JavaBridgeDispatcherHost::OnMessageReceived(const IPC::Message& msg) {
}
void JavaBridgeDispatcherHost::OnGetChannelHandle(IPC::Message* reply_msg) {
- if (RenderProcessHost::run_renderer_in_process()) {
- // TODO(steveblock): Fix Java Bridge with in-process renderer. See
- // http://code.google.com/p/chromium/issues/detail?id=106838
- CHECK(false) << "Java Bridge does not support in-process renderer";
- }
- BrowserThread::PostTask(
- BrowserThread::WEBKIT,
+ g_background_thread.Get().message_loop()->PostTask(
FROM_HERE,
base::Bind(&JavaBridgeDispatcherHost::GetChannelHandle, this, reply_msg));
}
@@ -85,11 +94,11 @@ void JavaBridgeDispatcherHost::GetChannelHandle(IPC::Message* reply_msg) {
void JavaBridgeDispatcherHost::CreateNPVariantParam(NPObject* object,
NPVariant_Param* param) {
- // The JavaBridgeChannelHost needs to be created on the WEBKIT thread, as
+ // The JavaBridgeChannelHost needs to be created on the background thread, as
// that is where Java objects will live, and CreateNPVariantParam() needs the
// channel to create the NPObjectStub. To avoid blocking here until the
// channel is ready, create the NPVariant_Param by hand, then post a message
- // to the WEBKIT thread to set up the channel and create the corresponding
+ // to the background thread to set up the channel and create the corresponding
// NPObjectStub. Post that message before doing any IPC, to make sure that
// the channel and object proxies are ready before responses are received
// from the renderer.
@@ -101,8 +110,7 @@ void JavaBridgeDispatcherHost::CreateNPVariantParam(NPObject* object,
param->npobject_routing_id = route_id;
WebKit::WebBindings::retainObject(object);
- BrowserThread::PostTask(
- BrowserThread::WEBKIT,
+ g_background_thread.Get().message_loop()->PostTask(
FROM_HERE,
base::Bind(&JavaBridgeDispatcherHost::CreateObjectStub, this, object,
route_id));
@@ -110,14 +118,15 @@ void JavaBridgeDispatcherHost::CreateNPVariantParam(NPObject* object,
void JavaBridgeDispatcherHost::CreateObjectStub(NPObject* object,
int route_id) {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::WEBKIT));
-
+ DCHECK_EQ(g_background_thread.Get().message_loop(), MessageLoop::current());
if (!channel_) {
channel_ = JavaBridgeChannelHost::GetJavaBridgeChannelHost(
render_view_host()->process()->id(),
BrowserThread::GetMessageLoopProxyForThread(BrowserThread::IO));
}
+ // NPObjectStub takes a ref to the NPObject. The lifetime of the NPObjectStub
+ // is governed by that of the NPObjectProxy in the renderer, via the channel.
// We don't need the containing window or the page URL, as we don't do
// re-entrant sync IPC.
new NPObjectStub(object, channel_, route_id, 0, GURL());
« no previous file with comments | « content/browser/renderer_host/java/java_bridge_dispatcher_host.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698