diff options
| author | Tobias Sargeant <tobiasjs@google.com> | 2019-03-07 21:29:31 +0000 |
|---|---|---|
| committer | Toby Sargeant <tobiasjs@google.com> | 2019-03-11 15:03:03 +0000 |
| commit | 39b68efcc3c37600b4742a23ce8460bc58347e61 (patch) | |
| tree | 4d7ec621f05f92d3322f2acb51da664c1aee096f /core/java/android/webkit/WebViewRenderProcessClient.java | |
| parent | 707b4655d1cdf205d49f7cc3cfa79ade0d8d36ee (diff) | |
[webview] rename unresponsive renderer APIs
Followup from API council review:
* Rename Renderer to RenderProcess for consistency with existing APIs.
* Make WebViewRenderProcess constructor public.
* Document 5 second minimum interval between successive callbacks.
Bug: 124767616
Bug: 123629980
Test: atest 'CtsWebkitTestCases'
Change-Id: I4416a97e8bb449c4a14a3617ef72a49c92aa3a83
Diffstat (limited to 'core/java/android/webkit/WebViewRenderProcessClient.java')
| -rw-r--r-- | core/java/android/webkit/WebViewRenderProcessClient.java | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/core/java/android/webkit/WebViewRenderProcessClient.java b/core/java/android/webkit/WebViewRenderProcessClient.java new file mode 100644 index 000000000000..24b8fb5dd637 --- /dev/null +++ b/core/java/android/webkit/WebViewRenderProcessClient.java @@ -0,0 +1,80 @@ +/* + * Copyright 2019 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package android.webkit; + +import android.annotation.NonNull; +import android.annotation.Nullable; + +/** + * Used to receive callbacks on {@link WebView} renderer events. + * + * WebViewRenderProcessClient instances may be set or retrieved via {@link + * WebView#setWebViewRenderProcessClient(WebViewRenderProcessClient)} and {@link + * WebView#getWebViewRenderProcessClient()}. + * + * Instances may be attached to multiple WebViews, and thus a single renderer event may cause + * a callback to be called multiple times with different WebView parameters. + */ +public abstract class WebViewRenderProcessClient { + /** + * Called when the renderer currently associated with {@code view} becomes unresponsive as a + * result of a long running blocking task such as the execution of JavaScript. + * + * <p>If a WebView fails to process an input event, or successfully navigate to a new URL within + * a reasonable time frame, the renderer is considered to be unresponsive, and this callback + * will be called. + * + * <p>This callback will continue to be called at regular intervals as long as the renderer + * remains unresponsive. If the renderer becomes responsive again, {@link + * WebViewRenderProcessClient#onRenderProcessResponsive} will be called once, and this method + * will not subsequently be called unless another period of unresponsiveness is detected. + * + * <p>The minimum interval between successive calls to {@code onRenderProcessUnresponsive} is 5 + * seconds. + * + * <p>No action is taken by WebView as a result of this method call. Applications may + * choose to terminate the associated renderer via the object that is passed to this callback, + * if in multiprocess mode, however this must be accompanied by correctly handling + * {@link WebViewClient#onRenderProcessGone} for this WebView, and all other WebViews associated + * with the same renderer. Failure to do so will result in application termination. + * + * @param view The {@link WebView} for which unresponsiveness was detected. + * @param renderer The {@link WebViewRenderProcess} that has become unresponsive, + * or {@code null} if WebView is running in single process mode. + */ + public abstract void onRenderProcessUnresponsive( + @NonNull WebView view, @Nullable WebViewRenderProcess renderer); + + /** + * Called once when an unresponsive renderer currently associated with {@code view} becomes + * responsive. + * + * <p>After a WebView renderer becomes unresponsive, which is notified to the application by + * {@link WebViewRenderProcessClient#onRenderProcessUnresponsive}, it is possible for the + * blocking renderer task to complete, returning the renderer to a responsive state. In that + * case, this method is called once to indicate responsiveness. + * + * <p>No action is taken by WebView as a result of this method call. + * + * @param view The {@link WebView} for which responsiveness was detected. + * + * @param renderer The {@link WebViewRenderProcess} that has become responsive, or {@code null} + * if WebView is running in single process mode. + */ + public abstract void onRenderProcessResponsive( + @NonNull WebView view, @Nullable WebViewRenderProcess renderer); +} |
