| 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 "extensions/browser/guest_view/mime_handler_view/mime_handler_view_gues
t.h" | 5 #include "extensions/browser/guest_view/mime_handler_view/mime_handler_view_gues
t.h" |
| 6 | 6 |
| 7 #include "base/strings/stringprintf.h" | 7 #include "base/strings/stringprintf.h" |
| 8 #include "content/public/browser/browser_thread.h" | 8 #include "content/public/browser/browser_thread.h" |
| 9 #include "content/public/browser/render_process_host.h" | 9 #include "content/public/browser/render_process_host.h" |
| 10 #include "content/public/common/url_constants.h" | 10 #include "content/public/common/url_constants.h" |
| (...skipping 13 matching lines...) Expand all Loading... |
| 24 namespace extensions { | 24 namespace extensions { |
| 25 | 25 |
| 26 // static | 26 // static |
| 27 const char MimeHandlerViewGuest::Type[] = "mimehandler"; | 27 const char MimeHandlerViewGuest::Type[] = "mimehandler"; |
| 28 | 28 |
| 29 // static | 29 // static |
| 30 GuestViewBase* MimeHandlerViewGuest::Create( | 30 GuestViewBase* MimeHandlerViewGuest::Create( |
| 31 content::BrowserContext* browser_context, | 31 content::BrowserContext* browser_context, |
| 32 int guest_instance_id) { | 32 int guest_instance_id) { |
| 33 if (!extensions::FeatureSwitch::mime_handler_view()->IsEnabled()) | 33 if (!extensions::FeatureSwitch::mime_handler_view()->IsEnabled()) |
| 34 return NULL; | 34 return nullptr; |
| 35 | 35 |
| 36 return new MimeHandlerViewGuest(browser_context, guest_instance_id); | 36 return new MimeHandlerViewGuest(browser_context, guest_instance_id); |
| 37 } | 37 } |
| 38 | 38 |
| 39 MimeHandlerViewGuest::MimeHandlerViewGuest( | 39 MimeHandlerViewGuest::MimeHandlerViewGuest( |
| 40 content::BrowserContext* browser_context, | 40 content::BrowserContext* browser_context, |
| 41 int guest_instance_id) | 41 int guest_instance_id) |
| 42 : GuestView<MimeHandlerViewGuest>(browser_context, guest_instance_id), | 42 : GuestView<MimeHandlerViewGuest>(browser_context, guest_instance_id), |
| 43 delegate_(ExtensionsAPIClient::Get()->CreateMimeHandlerViewGuestDelegate( | 43 delegate_(ExtensionsAPIClient::Get()->CreateMimeHandlerViewGuestDelegate( |
| 44 this)) { | 44 this)) { |
| (...skipping 19 matching lines...) Expand all Loading... |
| 64 std::string orig_mime_type; | 64 std::string orig_mime_type; |
| 65 create_params.GetString(mime_handler_view::kMimeType, &orig_mime_type); | 65 create_params.GetString(mime_handler_view::kMimeType, &orig_mime_type); |
| 66 DCHECK(!orig_mime_type.empty()); | 66 DCHECK(!orig_mime_type.empty()); |
| 67 | 67 |
| 68 std::string extension_src; | 68 std::string extension_src; |
| 69 create_params.GetString(mime_handler_view::kSrc, &extension_src); | 69 create_params.GetString(mime_handler_view::kSrc, &extension_src); |
| 70 DCHECK(!extension_src.empty()); | 70 DCHECK(!extension_src.empty()); |
| 71 | 71 |
| 72 GURL mime_handler_extension_url(extension_src); | 72 GURL mime_handler_extension_url(extension_src); |
| 73 if (!mime_handler_extension_url.is_valid()) { | 73 if (!mime_handler_extension_url.is_valid()) { |
| 74 callback.Run(NULL); | 74 callback.Run(nullptr); |
| 75 return; | 75 return; |
| 76 } | 76 } |
| 77 | 77 |
| 78 const Extension* mime_handler_extension = | 78 const Extension* mime_handler_extension = |
| 79 // TODO(lazyboy): Do we need handle the case where the extension is | 79 // TODO(lazyboy): Do we need handle the case where the extension is |
| 80 // terminated (ExtensionRegistry::TERMINATED)? | 80 // terminated (ExtensionRegistry::TERMINATED)? |
| 81 ExtensionRegistry::Get(browser_context())->enabled_extensions().GetByID( | 81 ExtensionRegistry::Get(browser_context())->enabled_extensions().GetByID( |
| 82 mime_handler_extension_url.host()); | 82 mime_handler_extension_url.host()); |
| 83 if (!mime_handler_extension) { | 83 if (!mime_handler_extension) { |
| 84 LOG(ERROR) << "Extension for mime_type not found, mime_type = " | 84 LOG(ERROR) << "Extension for mime_type not found, mime_type = " |
| 85 << orig_mime_type; | 85 << orig_mime_type; |
| 86 callback.Run(NULL); | 86 callback.Run(nullptr); |
| 87 return; | 87 return; |
| 88 } | 88 } |
| 89 | 89 |
| 90 ProcessManager* process_manager = | 90 ProcessManager* process_manager = |
| 91 ExtensionSystem::Get(browser_context())->process_manager(); | 91 ExtensionSystem::Get(browser_context())->process_manager(); |
| 92 DCHECK(process_manager); | 92 DCHECK(process_manager); |
| 93 | 93 |
| 94 // Use the mime handler extension's SiteInstance to create the guest so it | 94 // Use the mime handler extension's SiteInstance to create the guest so it |
| 95 // goes under the same process as the extension. | 95 // goes under the same process as the extension. |
| 96 content::SiteInstance* guest_site_instance = | 96 content::SiteInstance* guest_site_instance = |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 128 // TODO(fsamuel): This introduces the possibility of out-of-order keyboard | 128 // TODO(fsamuel): This introduces the possibility of out-of-order keyboard |
| 129 // events because the guest may be arbitrarily delayed when responding to | 129 // events because the guest may be arbitrarily delayed when responding to |
| 130 // keyboard events. In that time, the embedder may have received and processed | 130 // keyboard events. In that time, the embedder may have received and processed |
| 131 // additional key events. This needs to be fixed as soon as possible. | 131 // additional key events. This needs to be fixed as soon as possible. |
| 132 // See http://crbug.com/229882. | 132 // See http://crbug.com/229882. |
| 133 embedder_web_contents()->GetDelegate()->HandleKeyboardEvent(web_contents(), | 133 embedder_web_contents()->GetDelegate()->HandleKeyboardEvent(web_contents(), |
| 134 event); | 134 event); |
| 135 } | 135 } |
| 136 | 136 |
| 137 } // namespace extensions | 137 } // namespace extensions |
| OLD | NEW |