Home | History | Annotate | Download | only in java
      1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #include "content/renderer/java/java_bridge_channel.h"
      6 
      7 #include "content/child/child_process.h"
      8 #include "content/child/plugin_messages.h"
      9 #include "content/common/java_bridge_messages.h"
     10 #include "third_party/WebKit/public/web/WebBindings.h"
     11 
     12 namespace content {
     13 
     14 JavaBridgeChannel* JavaBridgeChannel::GetJavaBridgeChannel(
     15     const IPC::ChannelHandle& channel_handle,
     16     base::MessageLoopProxy* ipc_message_loop) {
     17   return static_cast<JavaBridgeChannel*>(NPChannelBase::GetChannel(
     18       channel_handle,
     19       IPC::Channel::MODE_CLIENT,
     20       ClassFactory,
     21       ipc_message_loop,
     22       true,
     23       ChildProcess::current()->GetShutDownEvent()));
     24 }
     25 
     26 JavaBridgeChannel::JavaBridgeChannel()
     27     : peer_owner_id_(new struct _NPP) {
     28   // Register the dummy owner Id for our peer (the Browser process) as an object
     29   // owner, and have all objects received from the peer owned by it.
     30   blink::WebBindings::registerObjectOwner(peer_owner_id_.get());
     31   SetDefaultNPObjectOwner(peer_owner_id_.get());
     32 }
     33 
     34 JavaBridgeChannel::~JavaBridgeChannel() {
     35   blink::WebBindings::unregisterObjectOwner(peer_owner_id_.get());
     36 }
     37 
     38 int JavaBridgeChannel::GenerateRouteID() {
     39   // Use a control message as this going to the JavaBridgeChannelHost, not an
     40   // injected object.
     41   int route_id = MSG_ROUTING_NONE;
     42   Send(new JavaBridgeMsg_GenerateRouteID(&route_id));
     43   // This should never fail, as the JavaBridgeChannelHost should always outlive
     44   // us.
     45   DCHECK_NE(MSG_ROUTING_NONE, route_id);
     46   return route_id;
     47 }
     48 
     49 bool JavaBridgeChannel::OnControlMessageReceived(const IPC::Message& msg) {
     50   // We need to intercept these two message types because the default
     51   // implementation of NPChannelBase::OnControlMessageReceived() is to
     52   // DCHECK(false). However, we don't need to do anything, as we don't need to
     53   // worry about the window system hanging when a modal dialog is displayed.
     54   // This is because, unlike in the case of plugins, the host does not need to
     55   // pump the message queue to avoid hangs.
     56   if (msg.type() == PluginMsg_SignalModalDialogEvent::ID ||
     57       msg.type() == PluginMsg_ResetModalDialogEvent::ID) {
     58     return true;
     59   }
     60   return NPChannelBase::OnControlMessageReceived(msg);
     61 }
     62 
     63 }  // namespace content
     64