OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/renderer/browser_plugin/chrome_browser_plugin_delegate.h" | 5 #include "extensions/renderer/guest_view/guest_view_container.h" |
6 | 6 |
7 #include "content/public/renderer/browser_plugin_delegate.h" | 7 #include "content/public/renderer/browser_plugin_delegate.h" |
8 #include "content/public/renderer/render_frame.h" | 8 #include "content/public/renderer/render_frame.h" |
9 #include "extensions/common/extension_messages.h" | 9 #include "extensions/common/extension_messages.h" |
10 #include "extensions/common/guest_view/guest_view_constants.h" | |
10 | 11 |
11 ChromeBrowserPluginDelegate::ChromeBrowserPluginDelegate( | 12 GuestViewContainer::GuestViewContainer( |
12 content::RenderFrame* render_frame, | 13 content::RenderFrame* render_frame, |
13 const std::string& mime_type) | 14 const std::string& mime_type) |
14 : content::BrowserPluginDelegate(render_frame, mime_type), | 15 : content::BrowserPluginDelegate(render_frame, mime_type), |
15 content::RenderFrameObserver(render_frame), | 16 content::RenderFrameObserver(render_frame), |
16 mime_type_(mime_type), | 17 mime_type_(mime_type), |
17 // TODO(lazyboy): Use browser_plugin::kInstanceIDNone. | 18 element_instance_id_(guestview::kInstanceIDNone) { |
18 element_instance_id_(0) { | |
19 } | 19 } |
20 | 20 |
21 ChromeBrowserPluginDelegate::~ChromeBrowserPluginDelegate() { | 21 GuestViewContainer::~GuestViewContainer() { |
22 } | 22 } |
23 | 23 |
24 void ChromeBrowserPluginDelegate::SetElementInstanceID( | 24 void GuestViewContainer::SetElementInstanceID( |
25 int element_instance_id) { | 25 int element_instance_id) { |
26 element_instance_id_ = element_instance_id; | 26 element_instance_id_ = element_instance_id; |
27 } | 27 } |
28 | 28 |
29 void ChromeBrowserPluginDelegate::DidFinishLoading() { | 29 void GuestViewContainer::DidFinishLoading() { |
30 DCHECK_NE(element_instance_id_, 0); | 30 if (mime_type_.empty()) |
31 return; | |
32 | |
33 DCHECK_NE(element_instance_id_, guestview::kInstanceIDNone); | |
31 render_frame()->Send(new ExtensionHostMsg_CreateMimeHandlerViewGuest( | 34 render_frame()->Send(new ExtensionHostMsg_CreateMimeHandlerViewGuest( |
32 routing_id(), html_string_, mime_type_, element_instance_id_)); | 35 routing_id(), html_string_, mime_type_, element_instance_id_)); |
33 } | 36 } |
34 | 37 |
35 void ChromeBrowserPluginDelegate::DidReceiveData(const char* data, | 38 void GuestViewContainer::DidReceiveData(const char* data, int data_length) { |
36 int data_length) { | |
37 std::string value(data, data_length); | 39 std::string value(data, data_length); |
38 html_string_ += value; | 40 html_string_ += value; |
39 } | 41 } |
40 | 42 |
41 bool ChromeBrowserPluginDelegate::OnMessageReceived( | 43 bool GuestViewContainer::OnMessageReceived(const IPC::Message& message) { |
42 const IPC::Message& message) { | |
43 if (message.type() != ExtensionMsg_CreateMimeHandlerViewGuestACK::ID) | 44 if (message.type() != ExtensionMsg_CreateMimeHandlerViewGuestACK::ID) |
44 return false; | 45 return false; |
45 | 46 |
46 DCHECK_NE(element_instance_id_, 0); | 47 DCHECK_NE(element_instance_id_, guestview::kInstanceIDNone); |
47 int element_instance_id = 0; | 48 int element_instance_id = guestview::kInstanceIDNone; |
48 PickleIterator iter(message); | 49 PickleIterator iter(message); |
49 bool success = iter.ReadInt(&element_instance_id); | 50 bool success = iter.ReadInt(&element_instance_id); |
50 DCHECK(success); | 51 DCHECK(success); |
51 if (element_instance_id != element_instance_id_) | 52 if (element_instance_id != element_instance_id_) |
52 return false; | 53 return false; |
53 | 54 |
54 bool handled = true; | 55 bool handled = true; |
55 IPC_BEGIN_MESSAGE_MAP(ChromeBrowserPluginDelegate, message) | 56 IPC_BEGIN_MESSAGE_MAP(GuestViewContainer, message) |
56 IPC_MESSAGE_HANDLER(ExtensionMsg_CreateMimeHandlerViewGuestACK, | 57 IPC_MESSAGE_HANDLER(ExtensionMsg_CreateMimeHandlerViewGuestACK, |
57 OnCreateMimeHandlerViewGuestACK) | 58 OnCreateMimeHandlerViewGuestACK) |
58 IPC_MESSAGE_UNHANDLED(handled = false) | 59 IPC_MESSAGE_UNHANDLED(handled = false) |
59 IPC_END_MESSAGE_MAP() | 60 IPC_END_MESSAGE_MAP() |
60 return handled; | 61 return handled; |
61 } | 62 } |
62 | 63 |
63 void ChromeBrowserPluginDelegate::OnCreateMimeHandlerViewGuestACK( | 64 void GuestViewContainer::OnCreateMimeHandlerViewGuestACK( |
64 int element_instance_id) { | 65 int element_instance_id) { |
65 DCHECK_NE(element_instance_id_, 0); | 66 DCHECK_NE(element_instance_id_, guestview::kInstanceIDNone); |
lazyboy
2014/09/15 21:33:47
Also DCHECK(!mime_type_.empty());
Fady Samuel
2014/09/15 21:54:37
Done.
| |
66 DCHECK_EQ(element_instance_id_, element_instance_id); | 67 DCHECK_EQ(element_instance_id_, element_instance_id); |
67 render_frame()->AttachGuest(element_instance_id); | 68 render_frame()->AttachGuest(element_instance_id); |
68 } | 69 } |
OLD | NEW |