Merge "Enforce consistent sizes for arrays in SpannableStringInternal" into nyc-mr1-dev
This commit is contained in:
@@ -33,6 +33,7 @@ import java.lang.reflect.Array;
|
|||||||
mText = source.toString().substring(start, end);
|
mText = source.toString().substring(start, end);
|
||||||
|
|
||||||
mSpans = EmptyArray.OBJECT;
|
mSpans = EmptyArray.OBJECT;
|
||||||
|
// Invariant: mSpanData.length = mSpans.length * COLUMNS
|
||||||
mSpanData = EmptyArray.INT;
|
mSpanData = EmptyArray.INT;
|
||||||
|
|
||||||
if (source instanceof Spanned) {
|
if (source instanceof Spanned) {
|
||||||
@@ -99,7 +100,7 @@ import java.lang.reflect.Array;
|
|||||||
Object[] srcSpans = src.mSpans;
|
Object[] srcSpans = src.mSpans;
|
||||||
mSpanCount = count;
|
mSpanCount = count;
|
||||||
mSpans = ArrayUtils.newUnpaddedObjectArray(mSpanCount);
|
mSpans = ArrayUtils.newUnpaddedObjectArray(mSpanCount);
|
||||||
mSpanData = new int[mSpanCount * COLUMNS];
|
mSpanData = new int[mSpans.length * COLUMNS];
|
||||||
for (int i = 0, j = 0; i < limit; i++) {
|
for (int i = 0, j = 0; i < limit; i++) {
|
||||||
int spanStart = srcData[i * COLUMNS + START];
|
int spanStart = srcData[i * COLUMNS + START];
|
||||||
int spanEnd = srcData[i * COLUMNS + END];
|
int spanEnd = srcData[i * COLUMNS + END];
|
||||||
|
|||||||
Reference in New Issue
Block a user