diff options
| author | TreeHugger Robot <treehugger-gerrit@google.com> | 2021-05-25 18:00:58 +0000 |
|---|---|---|
| committer | Android (Google) Code Review <android-gerrit@google.com> | 2021-05-25 18:00:58 +0000 |
| commit | 7568c8cd9a058bde67f4683bbcda612351dea0e7 (patch) | |
| tree | c234193c13be16ccf4632c9fdd9ee70c5ba326c9 /core/java/android/widget/TextView.java | |
| parent | 89583c598d2a244947a85660644ab0226f84378c (diff) | |
| parent | 7f2343de99be99f27bf1d38422b199ea1a2666bf (diff) | |
Merge "Fix a bug in SpellCheckSpan update logic." into sc-dev
Diffstat (limited to 'core/java/android/widget/TextView.java')
| -rw-r--r-- | core/java/android/widget/TextView.java | 15 |
1 files changed, 9 insertions, 6 deletions
diff --git a/core/java/android/widget/TextView.java b/core/java/android/widget/TextView.java index 9959510d5ac0..3c4fd5e93580 100644 --- a/core/java/android/widget/TextView.java +++ b/core/java/android/widget/TextView.java @@ -10750,12 +10750,15 @@ public class TextView extends View implements ViewTreeObserver.OnPreDrawListener Editable text = (Editable) mText; T[] spans = text.getSpans(start, end, type); - final int length = spans.length; - for (int i = 0; i < length; i++) { - final int spanStart = text.getSpanStart(spans[i]); - final int spanEnd = text.getSpanEnd(spans[i]); - if (spanEnd == start || spanStart == end) break; - text.removeSpan(spans[i]); + ArrayList<T> spansToRemove = new ArrayList<>(); + for (T span : spans) { + final int spanStart = text.getSpanStart(span); + final int spanEnd = text.getSpanEnd(span); + if (spanEnd == start || spanStart == end) continue; + spansToRemove.add(span); + } + for (T span : spansToRemove) { + text.removeSpan(span); } } |
