| Index: chrome/browser/android/bottombar/contextualsearch/contextual_search_panel.cc
|
| diff --git a/chrome/browser/android/bottombar/contextualsearch/contextual_search_panel.cc b/chrome/browser/android/bottombar/contextualsearch/contextual_search_panel.cc
|
| deleted file mode 100644
|
| index 223c7425b63983093ca153a4921c264e59de707b..0000000000000000000000000000000000000000
|
| --- a/chrome/browser/android/bottombar/contextualsearch/contextual_search_panel.cc
|
| +++ /dev/null
|
| @@ -1,141 +0,0 @@
|
| -// Copyright 2015 The Chromium Authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#include "chrome/browser/android/bottombar/contextualsearch/contextual_search_panel.h"
|
| -
|
| -#include <set>
|
| -
|
| -#include "base/android/jni_string.h"
|
| -#include "base/callback.h"
|
| -#include "base/memory/weak_ptr.h"
|
| -#include "base/time/time.h"
|
| -#include "chrome/browser/android/contextualsearch/contextual_search_delegate.h"
|
| -#include "chrome/browser/android/tab_android.h"
|
| -#include "chrome/browser/history/history_service_factory.h"
|
| -#include "chrome/browser/profiles/profile_manager.h"
|
| -#include "chrome/browser/search_engines/template_url_service_factory.h"
|
| -#include "chrome/browser/ui/android/window_android_helper.h"
|
| -#include "components/history/core/browser/history_service.h"
|
| -#include "components/navigation_interception/intercept_navigation_delegate.h"
|
| -#include "components/variations/variations_associated_data.h"
|
| -#include "components/web_contents_delegate_android/web_contents_delegate_android.h"
|
| -#include "content/public/browser/android/content_view_core.h"
|
| -#include "content/public/browser/web_contents.h"
|
| -#include "jni/ContextualSearchPanel_jni.h"
|
| -#include "net/url_request/url_fetcher_impl.h"
|
| -
|
| -using content::ContentViewCore;
|
| -
|
| -namespace {
|
| -
|
| -const int kHistoryDeletionWindowSeconds = 2;
|
| -
|
| -// Because we need a callback, this needs to exist.
|
| -void OnHistoryDeletionDone() {
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -// This class manages the native behavior of the Contextual Search feature.
|
| -// Instances of this class are owned by the Java ContextualSearchPanel.
|
| -ContextualSearchPanel::ContextualSearchPanel(JNIEnv* env, jobject obj) {
|
| - java_manager_.Reset(env, obj);
|
| - Java_ContextualSearchPanel_setNativePanelContentPtr(
|
| - env, obj, reinterpret_cast<intptr_t>(this));
|
| -}
|
| -
|
| -ContextualSearchPanel::~ContextualSearchPanel() {
|
| - JNIEnv* env = base::android::AttachCurrentThread();
|
| - Java_ContextualSearchPanel_clearNativePanelContentPtr(
|
| - env, java_manager_.obj());
|
| -}
|
| -
|
| -void ContextualSearchPanel::Destroy(JNIEnv* env, jobject obj) { delete this; }
|
| -
|
| -void ContextualSearchPanel::RemoveLastHistoryEntry(
|
| - JNIEnv* env,
|
| - jobject obj,
|
| - jstring search_url,
|
| - jlong search_start_time_ms) {
|
| - // The deletion window is from the time a search URL was put in history, up
|
| - // to a short amount of time later.
|
| - base::Time begin_time = base::Time::FromJsTime(search_start_time_ms);
|
| - base::Time end_time = begin_time +
|
| - base::TimeDelta::FromSeconds(kHistoryDeletionWindowSeconds);
|
| -
|
| - history::HistoryService* service = HistoryServiceFactory::GetForProfile(
|
| - ProfileManager::GetActiveUserProfile(),
|
| - ServiceAccessType::EXPLICIT_ACCESS);
|
| - if (service) {
|
| - // NOTE(mathp): We are only removing |search_url| from the local history
|
| - // because search results that are not promoted to a Tab do not make it to
|
| - // the web history, only local.
|
| - std::set<GURL> restrict_set;
|
| - restrict_set.insert(
|
| - GURL(base::android::ConvertJavaStringToUTF8(env, search_url)));
|
| - service->ExpireHistoryBetween(
|
| - restrict_set,
|
| - begin_time,
|
| - end_time,
|
| - base::Bind(&OnHistoryDeletionDone),
|
| - &history_task_tracker_);
|
| - }
|
| -}
|
| -
|
| -void ContextualSearchPanel::SetWebContents(JNIEnv* env,
|
| - jobject obj,
|
| - jobject jcontent_view_core,
|
| - jobject jweb_contents_delegate) {
|
| - content::ContentViewCore* content_view_core =
|
| - content::ContentViewCore::GetNativeContentViewCore(env,
|
| - jcontent_view_core);
|
| - DCHECK(content_view_core);
|
| - DCHECK(content_view_core->GetWebContents());
|
| -
|
| - // NOTE(pedrosimonetti): Takes ownership of the WebContents associated
|
| - // with the ContentViewCore. This is to make sure that the WebContens
|
| - // and the Compositor are in the same process.
|
| - // TODO(pedrosimonetti): Confirm with dtrainor@ if the comment above
|
| - // is accurate.
|
| - web_contents_.reset(content_view_core->GetWebContents());
|
| - // TODO(pedrosimonetti): confirm if we need this after promoting it
|
| - // to a real tab.
|
| - TabAndroid::AttachTabHelpers(web_contents_.get());
|
| - WindowAndroidHelper::FromWebContents(web_contents_.get())
|
| - ->SetWindowAndroid(content_view_core->GetWindowAndroid());
|
| - web_contents_delegate_.reset(
|
| - new web_contents_delegate_android::WebContentsDelegateAndroid(
|
| - env, jweb_contents_delegate));
|
| - web_contents_->SetDelegate(web_contents_delegate_.get());
|
| -}
|
| -
|
| -void ContextualSearchPanel::DestroyWebContents(JNIEnv* env, jobject jobj) {
|
| - DCHECK(web_contents_.get());
|
| - web_contents_.reset();
|
| - // |web_contents_delegate_| may already be NULL at this point.
|
| - web_contents_delegate_.reset();
|
| -}
|
| -
|
| -void ContextualSearchPanel::SetInterceptNavigationDelegate(
|
| - JNIEnv* env,
|
| - jobject obj,
|
| - jobject delegate,
|
| - jobject jweb_contents) {
|
| - content::WebContents* web_contents =
|
| - content::WebContents::FromJavaWebContents(jweb_contents);
|
| - DCHECK(web_contents);
|
| - navigation_interception::InterceptNavigationDelegate::Associate(
|
| - web_contents,
|
| - make_scoped_ptr(new navigation_interception::InterceptNavigationDelegate(
|
| - env, delegate)));
|
| -}
|
| -
|
| -bool RegisterContextualSearchPanel(JNIEnv* env) {
|
| - return RegisterNativesImpl(env);
|
| -}
|
| -
|
| -jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) {
|
| - ContextualSearchPanel* manager = new ContextualSearchPanel(env, obj);
|
| - return reinterpret_cast<intptr_t>(manager);
|
| -}
|
|
|