summaryrefslogtreecommitdiff
path: root/core/java
diff options
context:
space:
mode:
authorLeon Scroggins <scroggo@google.com>2010-04-14 06:42:20 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2010-04-14 06:42:20 -0700
commitb2212464a3bc4103a9e5e88602d1097c835d7949 (patch)
tree394dcfba1e2faa5276c3b38152dc2940a884c7ea /core/java
parentd503a1524acfcaa85c658240ff88f54d174cbb9e (diff)
parent3fcf4863595f18be0691e19e530b1c0c8e79995e (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.java7
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();
}