Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(226)

Unified Diff: content/browser/android/web_contents_observer_proxy.cc

Issue 786933005: [Android] Add proxy for Java-based WebContentsObservers (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/browser/android/web_contents_observer_proxy.h ('k') | content/content_browser.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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
« no previous file with comments | « content/browser/android/web_contents_observer_proxy.h ('k') | content/content_browser.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698