aboutsummaryrefslogtreecommitdiffstats
path: root/java/src
diff options
context:
space:
mode:
authorJean Chalard <jchalard@google.com>2013-10-22 04:06:39 -0700
committerAndroid Git Automerger <android-git-automerger@android.com>2013-10-22 04:06:39 -0700
commitdbd87dc2f853fd0680b6b78c1b2a5bc9c084373b (patch)
treef6bc1b79e1fdc8b7b9fb84ee2f432f0877d8ee6d /java/src
parented8c086dae04d620791b6df5df0b0180e6783580 (diff)
parent787fd368c4069198111c20cdab2fe3367250c441 (diff)
downloadlatinime-dbd87dc2f853fd0680b6b78c1b2a5bc9c084373b.tar.gz
latinime-dbd87dc2f853fd0680b6b78c1b2a5bc9c084373b.tar.xz
latinime-dbd87dc2f853fd0680b6b78c1b2a5bc9c084373b.zip
am 787fd368: Merge "Stopgap solution for a crash."
* commit '787fd368c4069198111c20cdab2fe3367250c441': Stopgap solution for a crash.
Diffstat (limited to 'java/src')
-rw-r--r--java/src/com/android/inputmethod/latin/RichInputConnection.java9
1 files changed, 8 insertions, 1 deletions
diff --git a/java/src/com/android/inputmethod/latin/RichInputConnection.java b/java/src/com/android/inputmethod/latin/RichInputConnection.java
index e43cab5ca..c212f9c81 100644
--- a/java/src/com/android/inputmethod/latin/RichInputConnection.java
+++ b/java/src/com/android/inputmethod/latin/RichInputConnection.java
@@ -294,7 +294,14 @@ public final class RichInputConnection {
// the text field, then we can return the cached version right away.
if (cachedLength >= n || cachedLength >= mExpectedCursorPosition) {
final StringBuilder s = new StringBuilder(mCommittedTextBeforeComposingText);
- s.append(mComposingText);
+ // We call #toString() here to create a temporary object.
+ // In some situations, this method is called on a worker thread, and it's possible
+ // the main thread touches the contents of mComposingText while this worker thread
+ // is suspended, because mComposingText is a StringBuilder. This may lead to crashes,
+ // so we call #toString() on it. That will result in the return value being strictly
+ // speaking wrong, but since this is used for basing bigram probability off, and
+ // it's only going to matter for one getSuggestions call, it's fine in the practice.
+ s.append(mComposingText.toString());
if (s.length() > n) {
s.delete(0, s.length() - n);
}