diff options
| author | Leon Scroggins <scroggo@google.com> | 2010-04-14 06:42:20 -0700 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2010-04-14 06:42:20 -0700 |
| commit | b2212464a3bc4103a9e5e88602d1097c835d7949 (patch) | |
| tree | 394dcfba1e2faa5276c3b38152dc2940a884c7ea /core/java | |
| parent | d503a1524acfcaa85c658240ff88f54d174cbb9e (diff) | |
| parent | 3fcf4863595f18be0691e19e530b1c0c8e79995e (diff) | |
Merge "Ensure the selection does not change in setTextAndKeepSelection." into froyo
Diffstat (limited to 'core/java')
| -rw-r--r-- | core/java/android/webkit/WebTextView.java | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/core/java/android/webkit/WebTextView.java b/core/java/android/webkit/WebTextView.java index 870f512c8b36..dc952e6408af 100644 --- a/core/java/android/webkit/WebTextView.java +++ b/core/java/android/webkit/WebTextView.java @@ -343,6 +343,7 @@ import java.util.ArrayList; @Override protected void onSelectionChanged(int selStart, int selEnd) { + if (mInSetTextAndKeepSelection) return; // This code is copied from TextView.onDraw(). That code does not get // executed, however, because the WebTextView does not draw, allowing // webkit's drawing to show through. @@ -799,8 +800,14 @@ import java.util.ArrayList; /* package */ void setTextAndKeepSelection(String text) { mPreChange = text.toString(); Editable edit = (Editable) getText(); + int selStart = Selection.getSelectionStart(edit); + int selEnd = Selection.getSelectionEnd(edit); mInSetTextAndKeepSelection = true; edit.replace(0, edit.length(), text); + int newLength = edit.length(); + if (selStart > newLength) selStart = newLength; + if (selEnd > newLength) selEnd = newLength; + Selection.setSelection(edit, selStart, selEnd); mInSetTextAndKeepSelection = false; updateCachedTextfield(); } |
