OLD | NEW |
---|---|
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 2012 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/browser/android/tab_android.h" | 5 #include "chrome/browser/android/tab_android.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 | 8 |
9 #include "base/android/jni_android.h" | 9 #include "base/android/jni_android.h" |
10 #include "base/android/jni_string.h" | 10 #include "base/android/jni_string.h" |
11 #include "base/memory/ptr_util.h" | 11 #include "base/memory/ptr_util.h" |
12 #include "base/metrics/histogram.h" | 12 #include "base/metrics/histogram.h" |
13 #include "base/trace_event/trace_event.h" | 13 #include "base/trace_event/trace_event.h" |
14 #include "blimp/client/public/blimp_client_context.h" | |
15 #include "blimp/client/public/contents/blimp_contents.h" | |
16 #include "blimp/client/public/contents/blimp_navigation_controller.h" | |
14 #include "cc/layers/layer.h" | 17 #include "cc/layers/layer.h" |
18 #include "chrome/browser/android/blimp/blimp_client_context_factory.h" | |
15 #include "chrome/browser/android/compositor/tab_content_manager.h" | 19 #include "chrome/browser/android/compositor/tab_content_manager.h" |
16 #include "chrome/browser/android/metrics/uma_utils.h" | 20 #include "chrome/browser/android/metrics/uma_utils.h" |
17 #include "chrome/browser/android/offline_pages/offline_page_model_factory.h" | 21 #include "chrome/browser/android/offline_pages/offline_page_model_factory.h" |
18 #include "chrome/browser/android/offline_pages/offline_page_utils.h" | 22 #include "chrome/browser/android/offline_pages/offline_page_utils.h" |
19 #include "chrome/browser/android/tab_web_contents_delegate_android.h" | 23 #include "chrome/browser/android/tab_web_contents_delegate_android.h" |
20 #include "chrome/browser/bookmarks/bookmark_model_factory.h" | 24 #include "chrome/browser/bookmarks/bookmark_model_factory.h" |
21 #include "chrome/browser/bookmarks/managed_bookmark_service_factory.h" | 25 #include "chrome/browser/bookmarks/managed_bookmark_service_factory.h" |
22 #include "chrome/browser/browser_about_handler.h" | 26 #include "chrome/browser/browser_about_handler.h" |
23 #include "chrome/browser/chrome_notification_types.h" | 27 #include "chrome/browser/chrome_notification_types.h" |
24 #include "chrome/browser/content_settings/tab_specific_content_settings.h" | 28 #include "chrome/browser/content_settings/tab_specific_content_settings.h" |
25 #include "chrome/browser/infobars/infobar_service.h" | 29 #include "chrome/browser/infobars/infobar_service.h" |
26 #include "chrome/browser/prerender/prerender_contents.h" | 30 #include "chrome/browser/prerender/prerender_contents.h" |
27 #include "chrome/browser/prerender/prerender_manager.h" | 31 #include "chrome/browser/prerender/prerender_manager.h" |
28 #include "chrome/browser/prerender/prerender_manager_factory.h" | 32 #include "chrome/browser/prerender/prerender_manager_factory.h" |
29 #include "chrome/browser/printing/print_view_manager_basic.h" | 33 #include "chrome/browser/printing/print_view_manager_basic.h" |
30 #include "chrome/browser/profiles/profile.h" | 34 #include "chrome/browser/profiles/profile.h" |
31 #include "chrome/browser/profiles/profile_android.h" | 35 #include "chrome/browser/profiles/profile_android.h" |
36 #include "chrome/browser/profiles/profile_manager.h" | |
32 #include "chrome/browser/search/instant_service.h" | 37 #include "chrome/browser/search/instant_service.h" |
33 #include "chrome/browser/search/instant_service_factory.h" | 38 #include "chrome/browser/search/instant_service_factory.h" |
34 #include "chrome/browser/search/search.h" | 39 #include "chrome/browser/search/search.h" |
35 #include "chrome/browser/sessions/session_tab_helper.h" | 40 #include "chrome/browser/sessions/session_tab_helper.h" |
36 #include "chrome/browser/sessions/tab_restore_service_factory.h" | 41 #include "chrome/browser/sessions/tab_restore_service_factory.h" |
37 #include "chrome/browser/sync/glue/synced_tab_delegate_android.h" | 42 #include "chrome/browser/sync/glue/synced_tab_delegate_android.h" |
38 #include "chrome/browser/tab_contents/tab_util.h" | 43 #include "chrome/browser/tab_contents/tab_util.h" |
39 #include "chrome/browser/ui/android/content_settings/popup_blocked_infobar_deleg ate.h" | 44 #include "chrome/browser/ui/android/content_settings/popup_blocked_infobar_deleg ate.h" |
40 #include "chrome/browser/ui/android/context_menu_helper.h" | 45 #include "chrome/browser/ui/android/context_menu_helper.h" |
41 #include "chrome/browser/ui/android/infobars/infobar_container_android.h" | 46 #include "chrome/browser/ui/android/infobars/infobar_container_android.h" |
(...skipping 373 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
415 CHECK_EQ(GetProfile()->IsOffTheRecord(), incognito); | 420 CHECK_EQ(GetProfile()->IsOffTheRecord(), incognito); |
416 | 421 |
417 InstantService* instant_service = | 422 InstantService* instant_service = |
418 InstantServiceFactory::GetForProfile(GetProfile()); | 423 InstantServiceFactory::GetForProfile(GetProfile()); |
419 if (instant_service) | 424 if (instant_service) |
420 instant_service->AddObserver(this); | 425 instant_service->AddObserver(this); |
421 | 426 |
422 content_layer_->InsertChild(web_contents_->GetNativeView()->GetLayer(), 0); | 427 content_layer_->InsertChild(web_contents_->GetNativeView()->GetLayer(), 0); |
423 } | 428 } |
424 | 429 |
430 void TabAndroid::InitBlimpContents(JNIEnv* env, | |
431 const JavaParamRef<jobject>& obj) { | |
432 blimp::client::BlimpClientContext* context = | |
433 BlimpClientContextFactory::GetForBrowserContext( | |
434 ProfileManager::GetLastUsedProfile()->GetOriginalProfile()); | |
David Trainor- moved to gerrit
2016/08/11 21:40:19
Should we fail if this is an incognito tab (for no
shaktisahu
2016/08/12 22:11:49
I discussed with Tommy about this. I added a check
| |
435 blimp_contents_ = context->CreateBlimpContents(); | |
436 } | |
437 | |
425 void TabAndroid::UpdateDelegates( | 438 void TabAndroid::UpdateDelegates( |
426 JNIEnv* env, | 439 JNIEnv* env, |
427 const JavaParamRef<jobject>& obj, | 440 const JavaParamRef<jobject>& obj, |
428 const JavaParamRef<jobject>& jweb_contents_delegate, | 441 const JavaParamRef<jobject>& jweb_contents_delegate, |
429 const JavaParamRef<jobject>& jcontext_menu_populator) { | 442 const JavaParamRef<jobject>& jcontext_menu_populator) { |
430 ContextMenuHelper::FromWebContents(web_contents())->SetPopulator( | 443 ContextMenuHelper::FromWebContents(web_contents())->SetPopulator( |
431 jcontext_menu_populator); | 444 jcontext_menu_populator); |
432 web_contents_delegate_.reset( | 445 web_contents_delegate_.reset( |
433 new chrome::android::TabWebContentsDelegateAndroid( | 446 new chrome::android::TabWebContentsDelegateAndroid( |
434 env, jweb_contents_delegate)); | 447 env, jweb_contents_delegate)); |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
493 Profile* profile = GetProfile(); | 506 Profile* profile = GetProfile(); |
494 if (!profile) | 507 if (!profile) |
495 return base::android::ScopedJavaLocalRef<jobject>(); | 508 return base::android::ScopedJavaLocalRef<jobject>(); |
496 ProfileAndroid* profile_android = ProfileAndroid::FromProfile(profile); | 509 ProfileAndroid* profile_android = ProfileAndroid::FromProfile(profile); |
497 if (!profile_android) | 510 if (!profile_android) |
498 return base::android::ScopedJavaLocalRef<jobject>(); | 511 return base::android::ScopedJavaLocalRef<jobject>(); |
499 | 512 |
500 return profile_android->GetJavaObject(); | 513 return profile_android->GetJavaObject(); |
501 } | 514 } |
502 | 515 |
516 base::android::ScopedJavaLocalRef<jobject> TabAndroid::GetBlimpContents( | |
517 JNIEnv* env, | |
518 const base::android::JavaParamRef<jobject>& obj) { | |
519 if (!blimp_contents_.get()) | |
520 return base::android::ScopedJavaLocalRef<jobject>(); | |
521 | |
522 return blimp_contents_->GetJavaObject(); | |
523 } | |
524 | |
503 TabAndroid::TabLoadStatus TabAndroid::LoadUrl( | 525 TabAndroid::TabLoadStatus TabAndroid::LoadUrl( |
504 JNIEnv* env, | 526 JNIEnv* env, |
505 const JavaParamRef<jobject>& obj, | 527 const JavaParamRef<jobject>& obj, |
506 const JavaParamRef<jstring>& url, | 528 const JavaParamRef<jstring>& url, |
507 const JavaParamRef<jstring>& j_extra_headers, | 529 const JavaParamRef<jstring>& j_extra_headers, |
508 const JavaParamRef<jobject>& j_post_data, | 530 const JavaParamRef<jobject>& j_post_data, |
509 jint page_transition, | 531 jint page_transition, |
510 const JavaParamRef<jstring>& j_referrer_url, | 532 const JavaParamRef<jstring>& j_referrer_url, |
511 jint referrer_policy, | 533 jint referrer_policy, |
512 jboolean is_renderer_initiated, | 534 jboolean is_renderer_initiated, |
(...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
577 load_params.post_data = | 599 load_params.post_data = |
578 content::ResourceRequestBody::FromJavaObject(env, j_post_data); | 600 content::ResourceRequestBody::FromJavaObject(env, j_post_data); |
579 } | 601 } |
580 load_params.transition_type = | 602 load_params.transition_type = |
581 ui::PageTransitionFromInt(page_transition); | 603 ui::PageTransitionFromInt(page_transition); |
582 if (j_referrer_url) { | 604 if (j_referrer_url) { |
583 load_params.referrer = content::Referrer( | 605 load_params.referrer = content::Referrer( |
584 GURL(base::android::ConvertJavaStringToUTF8(env, j_referrer_url)), | 606 GURL(base::android::ConvertJavaStringToUTF8(env, j_referrer_url)), |
585 static_cast<blink::WebReferrerPolicy>(referrer_policy)); | 607 static_cast<blink::WebReferrerPolicy>(referrer_policy)); |
586 } | 608 } |
609 | |
610 if (blimp_contents()) { | |
David Trainor- moved to gerrit
2016/08/11 21:40:19
Can we do this before we build the LoadURLParams?
shaktisahu
2016/08/12 22:11:49
Done.
| |
611 blimp_contents()->GetNavigationController().LoadURL(fixed_url); | |
612 return DEFAULT_PAGE_LOAD; | |
613 } | |
614 | |
587 const base::string16 search_terms = | 615 const base::string16 search_terms = |
588 search::ExtractSearchTermsFromURL(GetProfile(), gurl); | 616 search::ExtractSearchTermsFromURL(GetProfile(), gurl); |
589 SearchTabHelper* search_tab_helper = | 617 SearchTabHelper* search_tab_helper = |
590 SearchTabHelper::FromWebContents(web_contents_.get()); | 618 SearchTabHelper::FromWebContents(web_contents_.get()); |
591 if (!search_terms.empty() && search_tab_helper && | 619 if (!search_terms.empty() && search_tab_helper && |
592 search_tab_helper->SupportsInstant()) { | 620 search_tab_helper->SupportsInstant()) { |
593 EmbeddedSearchRequestParams request_params(gurl); | 621 EmbeddedSearchRequestParams request_params(gurl); |
594 search_tab_helper->Submit(search_terms, request_params); | 622 search_tab_helper->Submit(search_terms, request_params); |
595 return DEFAULT_PAGE_LOAD; | 623 return DEFAULT_PAGE_LOAD; |
596 } | 624 } |
(...skipping 297 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
894 static void Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { | 922 static void Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { |
895 TRACE_EVENT0("native", "TabAndroid::Init"); | 923 TRACE_EVENT0("native", "TabAndroid::Init"); |
896 // This will automatically bind to the Java object and pass ownership there. | 924 // This will automatically bind to the Java object and pass ownership there. |
897 new TabAndroid(env, obj); | 925 new TabAndroid(env, obj); |
898 } | 926 } |
899 | 927 |
900 // static | 928 // static |
901 bool TabAndroid::RegisterTabAndroid(JNIEnv* env) { | 929 bool TabAndroid::RegisterTabAndroid(JNIEnv* env) { |
902 return RegisterNativesImpl(env); | 930 return RegisterNativesImpl(env); |
903 } | 931 } |
OLD | NEW |