Index: content/browser/android/web_contents_observer_proxy.cc |
diff --git a/content/browser/android/web_contents_observer_android.cc b/content/browser/android/web_contents_observer_proxy.cc |
similarity index 64% |
rename from content/browser/android/web_contents_observer_android.cc |
rename to content/browser/android/web_contents_observer_proxy.cc |
index e056f3125106b50c009b366a48cf52293710bd7f..8566beee8315a1a60cafb699b863384b2206b076 100644 |
--- a/content/browser/android/web_contents_observer_android.cc |
+++ b/content/browser/android/web_contents_observer_proxy.cc |
@@ -1,13 +1,11 @@ |
-// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// 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 "content/browser/android/web_contents_observer_android.h" |
+#include "content/browser/android/web_contents_observer_proxy.h" |
#include <string> |
-#include <jni.h> |
- |
#include "base/android/jni_android.h" |
#include "base/android/jni_string.h" |
#include "base/android/scoped_java_ref.h" |
@@ -15,7 +13,7 @@ |
#include "content/browser/web_contents/web_contents_impl.h" |
#include "content/public/browser/navigation_details.h" |
#include "content/public/browser/navigation_entry.h" |
-#include "jni/WebContentsObserver_jni.h" |
+#include "jni/WebContentsObserverProxy_jni.h" |
using base::android::AttachCurrentThread; |
using base::android::ScopedJavaLocalRef; |
@@ -27,15 +25,13 @@ namespace content { |
// TODO(dcheng): File a bug. This class incorrectly passes just a frame ID, |
// which is not sufficient to identify a frame (since frame IDs are scoped per |
// render process, and so may collide). |
-WebContentsObserverAndroid::WebContentsObserverAndroid( |
- JNIEnv* env, |
- jobject obj, |
- WebContents* web_contents) |
- : WebContentsObserver(web_contents), |
- weak_java_observer_(env, obj){ |
+WebContentsObserverProxy::WebContentsObserverProxy(JNIEnv* env, |
+ jobject obj, |
+ WebContents* web_contents) |
+ : WebContentsObserver(web_contents), weak_java_observer_(env, obj) { |
} |
-WebContentsObserverAndroid::~WebContentsObserverAndroid() { |
+WebContentsObserverProxy::~WebContentsObserverProxy() { |
} |
jlong Init(JNIEnv* env, jobject obj, jobject java_web_contents) { |
@@ -43,35 +39,35 @@ jlong Init(JNIEnv* env, jobject obj, jobject java_web_contents) { |
WebContents::FromJavaWebContents(java_web_contents); |
CHECK(web_contents); |
- WebContentsObserverAndroid* native_observer = new WebContentsObserverAndroid( |
- env, obj, web_contents); |
+ WebContentsObserverProxy* native_observer = |
+ new WebContentsObserverProxy(env, obj, web_contents); |
return reinterpret_cast<intptr_t>(native_observer); |
} |
-void WebContentsObserverAndroid::Destroy(JNIEnv* env, jobject obj) { |
+void WebContentsObserverProxy::Destroy(JNIEnv* env, jobject obj) { |
delete this; |
} |
-void WebContentsObserverAndroid::WebContentsDestroyed() { |
+void WebContentsObserverProxy::WebContentsDestroyed() { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) { |
delete this; |
} else { |
// The java side will destroy |this| |
- Java_WebContentsObserver_detachFromWebContents(env, obj.obj()); |
+ Java_WebContentsObserverProxy_destroy(env, obj.obj()); |
} |
} |
-void WebContentsObserverAndroid::RenderViewReady() { |
+void WebContentsObserverProxy::RenderViewReady() { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_renderViewReady(env, obj.obj()); |
+ Java_WebContentsObserverProxy_renderViewReady(env, obj.obj()); |
} |
-void WebContentsObserverAndroid::RenderProcessGone( |
+void WebContentsObserverProxy::RenderProcessGone( |
base::TerminationStatus termination_status) { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
@@ -79,23 +75,23 @@ void WebContentsObserverAndroid::RenderProcessGone( |
return; |
jboolean was_oom_protected = |
termination_status == base::TERMINATION_STATUS_OOM_PROTECTED; |
- Java_WebContentsObserver_renderProcessGone( |
- env, obj.obj(), was_oom_protected); |
+ Java_WebContentsObserverProxy_renderProcessGone(env, obj.obj(), |
+ was_oom_protected); |
} |
-void WebContentsObserverAndroid::DidStartLoading( |
+void WebContentsObserverProxy::DidStartLoading( |
RenderViewHost* render_view_host) { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- ScopedJavaLocalRef<jstring> jstring_url(ConvertUTF8ToJavaString( |
- env, web_contents()->GetVisibleURL().spec())); |
- Java_WebContentsObserver_didStartLoading( |
- env, obj.obj(), jstring_url.obj()); |
+ ScopedJavaLocalRef<jstring> jstring_url( |
+ ConvertUTF8ToJavaString(env, web_contents()->GetVisibleURL().spec())); |
+ Java_WebContentsObserverProxy_didStartLoading(env, obj.obj(), |
+ jstring_url.obj()); |
} |
-void WebContentsObserverAndroid::DidStopLoading( |
+void WebContentsObserverProxy::DidStopLoading( |
RenderViewHost* render_view_host) { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
@@ -103,35 +99,29 @@ void WebContentsObserverAndroid::DidStopLoading( |
return; |
ScopedJavaLocalRef<jstring> jstring_url(ConvertUTF8ToJavaString( |
env, web_contents()->GetLastCommittedURL().spec())); |
- Java_WebContentsObserver_didStopLoading( |
- env, obj.obj(), jstring_url.obj()); |
+ Java_WebContentsObserverProxy_didStopLoading(env, obj.obj(), |
+ jstring_url.obj()); |
} |
-void WebContentsObserverAndroid::DidFailProvisionalLoad( |
+void WebContentsObserverProxy::DidFailProvisionalLoad( |
RenderFrameHost* render_frame_host, |
const GURL& validated_url, |
int error_code, |
const base::string16& error_description) { |
- DidFailLoadInternal(true, |
- !render_frame_host->GetParent(), |
- error_code, |
- error_description, |
- validated_url); |
+ DidFailLoadInternal(true, !render_frame_host->GetParent(), error_code, |
+ error_description, validated_url); |
} |
-void WebContentsObserverAndroid::DidFailLoad( |
+void WebContentsObserverProxy::DidFailLoad( |
RenderFrameHost* render_frame_host, |
const GURL& validated_url, |
int error_code, |
const base::string16& error_description) { |
- DidFailLoadInternal(false, |
- !render_frame_host->GetParent(), |
- error_code, |
- error_description, |
- validated_url); |
+ DidFailLoadInternal(false, !render_frame_host->GetParent(), error_code, |
+ error_description, validated_url); |
} |
-void WebContentsObserverAndroid::DidNavigateMainFrame( |
+void WebContentsObserverProxy::DidNavigateMainFrame( |
const LoadCommittedDetails& details, |
const FrameNavigateParams& params) { |
JNIEnv* env = AttachCurrentThread(); |
@@ -154,15 +144,16 @@ void WebContentsObserverAndroid::DidNavigateMainFrame( |
// However, there isn't sufficient information here to determine whether this |
// is actually a fragment navigation, or a history API navigation to a URL |
// that would also be valid for a fragment navigation. |
- bool is_fragment_navigation = urls_same_ignoring_fragment && |
+ bool is_fragment_navigation = |
+ urls_same_ignoring_fragment && |
(details.type == NAVIGATION_TYPE_IN_PAGE || details.is_in_page); |
- Java_WebContentsObserver_didNavigateMainFrame( |
+ Java_WebContentsObserverProxy_didNavigateMainFrame( |
env, obj.obj(), jstring_url.obj(), jstring_base_url.obj(), |
details.is_navigation_to_different_page(), is_fragment_navigation, |
details.http_status_code); |
} |
-void WebContentsObserverAndroid::DidNavigateAnyFrame( |
+void WebContentsObserverProxy::DidNavigateAnyFrame( |
RenderFrameHost* render_frame_host, |
const LoadCommittedDetails& details, |
const FrameNavigateParams& params) { |
@@ -177,20 +168,20 @@ void WebContentsObserverAndroid::DidNavigateAnyFrame( |
jboolean jboolean_is_reload = ui::PageTransitionCoreTypeIs( |
params.transition, ui::PAGE_TRANSITION_RELOAD); |
- Java_WebContentsObserver_didNavigateAnyFrame( |
+ Java_WebContentsObserverProxy_didNavigateAnyFrame( |
env, obj.obj(), jstring_url.obj(), jstring_base_url.obj(), |
jboolean_is_reload); |
} |
-void WebContentsObserverAndroid::DocumentAvailableInMainFrame() { |
+void WebContentsObserverProxy::DocumentAvailableInMainFrame() { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_documentAvailableInMainFrame(env, obj.obj()); |
+ Java_WebContentsObserverProxy_documentAvailableInMainFrame(env, obj.obj()); |
} |
-void WebContentsObserverAndroid::DidStartProvisionalLoadForFrame( |
+void WebContentsObserverProxy::DidStartProvisionalLoadForFrame( |
RenderFrameHost* render_frame_host, |
const GURL& validated_url, |
bool is_error_page, |
@@ -203,20 +194,16 @@ void WebContentsObserverAndroid::DidStartProvisionalLoadForFrame( |
ConvertUTF8ToJavaString(env, validated_url.spec())); |
// TODO(dcheng): Does Java really need the parent frame ID? It doesn't appear |
// to be used at all, and it just adds complexity here. |
- Java_WebContentsObserver_didStartProvisionalLoadForFrame( |
- env, |
- obj.obj(), |
- render_frame_host->GetRoutingID(), |
+ Java_WebContentsObserverProxy_didStartProvisionalLoadForFrame( |
+ env, obj.obj(), render_frame_host->GetRoutingID(), |
render_frame_host->GetParent() |
? render_frame_host->GetParent()->GetRoutingID() |
: -1, |
- !render_frame_host->GetParent(), |
- jstring_url.obj(), |
- is_error_page, |
+ !render_frame_host->GetParent(), jstring_url.obj(), is_error_page, |
is_iframe_srcdoc); |
} |
-void WebContentsObserverAndroid::DidCommitProvisionalLoadForFrame( |
+void WebContentsObserverProxy::DidCommitProvisionalLoadForFrame( |
RenderFrameHost* render_frame_host, |
const GURL& url, |
ui::PageTransition transition_type) { |
@@ -226,18 +213,13 @@ void WebContentsObserverAndroid::DidCommitProvisionalLoadForFrame( |
return; |
ScopedJavaLocalRef<jstring> jstring_url( |
ConvertUTF8ToJavaString(env, url.spec())); |
- Java_WebContentsObserver_didCommitProvisionalLoadForFrame( |
- env, |
- obj.obj(), |
- render_frame_host->GetRoutingID(), |
- !render_frame_host->GetParent(), |
- jstring_url.obj(), |
- transition_type); |
+ Java_WebContentsObserverProxy_didCommitProvisionalLoadForFrame( |
+ env, obj.obj(), render_frame_host->GetRoutingID(), |
+ !render_frame_host->GetParent(), jstring_url.obj(), transition_type); |
} |
-void WebContentsObserverAndroid::DidFinishLoad( |
- RenderFrameHost* render_frame_host, |
- const GURL& validated_url) { |
+void WebContentsObserverProxy::DidFinishLoad(RenderFrameHost* render_frame_host, |
+ const GURL& validated_url) { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
@@ -245,65 +227,62 @@ void WebContentsObserverAndroid::DidFinishLoad( |
std::string url_string = validated_url.spec(); |
NavigationEntry* entry = |
- web_contents()->GetController().GetLastCommittedEntry(); |
+ web_contents()->GetController().GetLastCommittedEntry(); |
// Note that GetBaseURLForDataURL is only used by the Android WebView. |
if (entry && !entry->GetBaseURLForDataURL().is_empty()) |
url_string = entry->GetBaseURLForDataURL().possibly_invalid_spec(); |
ScopedJavaLocalRef<jstring> jstring_url( |
ConvertUTF8ToJavaString(env, url_string)); |
- Java_WebContentsObserver_didFinishLoad( |
- env, |
- obj.obj(), |
- render_frame_host->GetRoutingID(), |
- jstring_url.obj(), |
+ Java_WebContentsObserverProxy_didFinishLoad( |
+ env, obj.obj(), render_frame_host->GetRoutingID(), jstring_url.obj(), |
!render_frame_host->GetParent()); |
} |
-void WebContentsObserverAndroid::DocumentLoadedInFrame( |
+void WebContentsObserverProxy::DocumentLoadedInFrame( |
RenderFrameHost* render_frame_host) { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_documentLoadedInFrame( |
+ Java_WebContentsObserverProxy_documentLoadedInFrame( |
env, obj.obj(), render_frame_host->GetRoutingID()); |
} |
-void WebContentsObserverAndroid::NavigationEntryCommitted( |
+void WebContentsObserverProxy::NavigationEntryCommitted( |
const LoadCommittedDetails& load_details) { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_navigationEntryCommitted(env, obj.obj()); |
+ Java_WebContentsObserverProxy_navigationEntryCommitted(env, obj.obj()); |
} |
-void WebContentsObserverAndroid::DidAttachInterstitialPage() { |
+void WebContentsObserverProxy::DidAttachInterstitialPage() { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_didAttachInterstitialPage(env, obj.obj()); |
+ Java_WebContentsObserverProxy_didAttachInterstitialPage(env, obj.obj()); |
} |
-void WebContentsObserverAndroid::DidDetachInterstitialPage() { |
+void WebContentsObserverProxy::DidDetachInterstitialPage() { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_didDetachInterstitialPage(env, obj.obj()); |
+ Java_WebContentsObserverProxy_didDetachInterstitialPage(env, obj.obj()); |
} |
-void WebContentsObserverAndroid::DidChangeThemeColor(SkColor color) { |
+void WebContentsObserverProxy::DidChangeThemeColor(SkColor color) { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_didChangeThemeColor(env, obj.obj(), color); |
+ Java_WebContentsObserverProxy_didChangeThemeColor(env, obj.obj(), color); |
} |
-void WebContentsObserverAndroid::DidFailLoadInternal( |
+void WebContentsObserverProxy::DidFailLoadInternal( |
bool is_provisional_load, |
bool is_main_frame, |
int error_code, |
@@ -318,24 +297,20 @@ void WebContentsObserverAndroid::DidFailLoadInternal( |
ScopedJavaLocalRef<jstring> jstring_url( |
ConvertUTF8ToJavaString(env, url.spec())); |
- Java_WebContentsObserver_didFailLoad( |
- env, obj.obj(), |
- is_provisional_load, |
- is_main_frame, |
- error_code, |
+ Java_WebContentsObserverProxy_didFailLoad( |
+ env, obj.obj(), is_provisional_load, is_main_frame, error_code, |
jstring_error_description.obj(), jstring_url.obj()); |
} |
-void WebContentsObserverAndroid::DidFirstVisuallyNonEmptyPaint() { |
+void WebContentsObserverProxy::DidFirstVisuallyNonEmptyPaint() { |
JNIEnv* env = AttachCurrentThread(); |
ScopedJavaLocalRef<jobject> obj(weak_java_observer_.get(env)); |
if (obj.is_null()) |
return; |
- Java_WebContentsObserver_didFirstVisuallyNonEmptyPaint( |
- env, obj.obj()); |
+ Java_WebContentsObserverProxy_didFirstVisuallyNonEmptyPaint(env, obj.obj()); |
} |
-void WebContentsObserverAndroid::DidStartNavigationToPendingEntry( |
+void WebContentsObserverProxy::DidStartNavigationToPendingEntry( |
const GURL& url, |
NavigationController::ReloadType reload_type) { |
JNIEnv* env = AttachCurrentThread(); |
@@ -345,11 +320,11 @@ void WebContentsObserverAndroid::DidStartNavigationToPendingEntry( |
ScopedJavaLocalRef<jstring> jstring_url( |
ConvertUTF8ToJavaString(env, url.spec())); |
- Java_WebContentsObserver_didStartNavigationToPendingEntry(env, obj.obj(), |
- jstring_url.obj()); |
+ Java_WebContentsObserverProxy_didStartNavigationToPendingEntry( |
+ env, obj.obj(), jstring_url.obj()); |
} |
-bool RegisterWebContentsObserverAndroid(JNIEnv* env) { |
+bool RegisterWebContentsObserverProxy(JNIEnv* env) { |
return RegisterNativesImpl(env); |
} |
} // namespace content |