summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author Gilles Debunne <debunne@google.com> 2011-12-12 15:53:25 -0800
committer Android (Google) Code Review <android-gerrit@google.com> 2011-12-12 15:53:25 -0800
commita1277de3c393fb0861d26ec5551ae4247e32dee4 (patch)
tree77d2e5695a8b3f5ddc3e1b05087407b065324fde
parent1fb90497b73b1560c55f1cb73cd394c3b8714212 (diff)
parentc3fb7a11ad72c5e51ff93e1ad6958f843af0d5b1 (diff)
Merge "Prevent a memory leak in TextLine." into ics-mr1
-rw-r--r--core/java/android/text/TextLine.java11
1 files changed, 11 insertions, 0 deletions
diff --git a/core/java/android/text/TextLine.java b/core/java/android/text/TextLine.java
index b3df8ff5fbbc..303a30e13df7 100644
--- a/core/java/android/text/TextLine.java
+++ b/core/java/android/text/TextLine.java
@@ -102,6 +102,11 @@ class TextLine {
tl.mText = null;
tl.mPaint = null;
tl.mDirections = null;
+
+ tl.mMetricAffectingSpanSpanSet.recycle();
+ tl.mCharacterStyleSpanSet.recycle();
+ tl.mReplacementSpanSpanSet.recycle();
+
synchronized(sCached) {
for (int i = 0; i < sCached.length; ++i) {
if (sCached[i] == null) {
@@ -919,6 +924,12 @@ class TextLine {
}
return limit;
}
+
+ public void recycle() {
+ for (int i = 0; i < numberOfSpans; i++) {
+ spans[i] = null; // prevent a leak: no reference kept when TextLine is recycled
+ }
+ }
}
/**