Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / chrome / browser / renderer_context_menu / context_menu_content_type_factory.cc
index 5641a00..b94f3da 100644 (file)
@@ -4,18 +4,32 @@
 
 #include "chrome/browser/renderer_context_menu/context_menu_content_type_factory.h"
 
+#include "base/bind.h"
+#include "chrome/common/url_constants.h"
+#include "components/renderer_context_menu/context_menu_content_type.h"
+#include "content/public/browser/web_contents.h"
+#include "content/public/common/url_constants.h"
+
+#if defined(ENABLE_EXTENSIONS)
 #include "chrome/browser/app_mode/app_mode_utils.h"
 #include "chrome/browser/guest_view/web_view/context_menu_content_type_web_view.h"
 #include "chrome/browser/guest_view/web_view/web_view_guest.h"
-#include "chrome/browser/renderer_context_menu/context_menu_content_type.h"
 #include "chrome/browser/renderer_context_menu/context_menu_content_type_app_mode.h"
 #include "chrome/browser/renderer_context_menu/context_menu_content_type_extension_popup.h"
 #include "chrome/browser/renderer_context_menu/context_menu_content_type_panel.h"
 #include "chrome/browser/renderer_context_menu/context_menu_content_type_platform_app.h"
-#include "content/public/browser/render_frame_host.h"
-#include "content/public/browser/web_contents.h"
 #include "extensions/browser/view_type_utils.h"
 #include "extensions/common/extension.h"
+#endif
+
+namespace {
+
+bool CheckInternalResourcesURL(const GURL& url) {
+  return url.SchemeIs(content::kChromeUIScheme) &&
+      (url.host() == chrome::kChromeUISyncResourcesHost);
+}
+
+}  // namespace
 
 ContextMenuContentTypeFactory::ContextMenuContentTypeFactory() {
 }
@@ -27,7 +41,24 @@ ContextMenuContentTypeFactory::~ContextMenuContentTypeFactory() {
 ContextMenuContentType* ContextMenuContentTypeFactory::Create(
     content::WebContents* web_contents,
     const content::ContextMenuParams& params) {
-  if (WebViewGuest::FromWebContents(web_contents))
+  return SetInternalResourcesURLChecker(CreateInternal(web_contents, params));
+}
+
+// static.
+ContextMenuContentType*
+ContextMenuContentTypeFactory::SetInternalResourcesURLChecker(
+    ContextMenuContentType* content_type) {
+  content_type->set_internal_resources_url_checker(
+      base::Bind(&CheckInternalResourcesURL));
+  return content_type;
+}
+
+// static
+ContextMenuContentType* ContextMenuContentTypeFactory::CreateInternal(
+    content::WebContents* web_contents,
+    const content::ContextMenuParams& params) {
+#if defined(ENABLE_EXTENSIONS)
+  if (extensions::WebViewGuest::FromWebContents(web_contents))
     return new ContextMenuContentTypeWebView(web_contents, params);
 
   if (chrome::IsRunningInForcedAppMode())
@@ -35,7 +66,8 @@ ContextMenuContentType* ContextMenuContentTypeFactory::Create(
 
   const extensions::ViewType view_type = extensions::GetViewType(web_contents);
 
-  if (view_type == extensions::VIEW_TYPE_APP_WINDOW)
+  if (view_type == extensions::VIEW_TYPE_APP_WINDOW ||
+      view_type == extensions::VIEW_TYPE_LAUNCHER_PAGE)
     return new ContextMenuContentTypePlatformApp(web_contents, params);
 
   if (view_type == extensions::VIEW_TYPE_EXTENSION_POPUP)
@@ -43,6 +75,7 @@ ContextMenuContentType* ContextMenuContentTypeFactory::Create(
 
   if (view_type == extensions::VIEW_TYPE_PANEL)
     return new ContextMenuContentTypePanel(web_contents, params);
+#endif
 
   return new ContextMenuContentType(web_contents, params, true);
 }