diff options
author | Raph Levien <raph@google.com> | 2015-03-30 14:18:32 -0700 |
---|---|---|
committer | Raph Levien <raph@google.com> | 2015-03-30 15:13:50 -0700 |
commit | 26d443aee4ee5a8791417b4ca09e8c78ba8dc78b (patch) | |
tree | ae9c40c4e7e31415a8cfb3028e5a30f66cf70c70 /tools/layoutlib/bridge/src/android | |
parent | dc0078b7947e0b035dce6c61108a48a276b11034 (diff) | |
download | frameworks_base-26d443aee4ee5a8791417b4ca09e8c78ba8dc78b.zip frameworks_base-26d443aee4ee5a8791417b4ca09e8c78ba8dc78b.tar.gz frameworks_base-26d443aee4ee5a8791417b4ca09e8c78ba8dc78b.tar.bz2 |
Revert "Fix build: Revert "Record hyphens from Minikin and draw them""
This reverts commit 5a6eeb3cbe0896ddf4bdccc0b1a81d7aac49821e and
fixes the underlying issue (needed to @hide getHyphen() for subclasses
of Layout, not just the base class), and layoutlib changes for
checkbuild.
Change-Id: I7a2b5f20ae014ea8e224d8c4079cf9131e17e1c1
Diffstat (limited to 'tools/layoutlib/bridge/src/android')
3 files changed, 7 insertions, 5 deletions
diff --git a/tools/layoutlib/bridge/src/android/text/GreedyLineBreaker.java b/tools/layoutlib/bridge/src/android/text/GreedyLineBreaker.java index 24e4b54..c72efc2 100644 --- a/tools/layoutlib/bridge/src/android/text/GreedyLineBreaker.java +++ b/tools/layoutlib/bridge/src/android/text/GreedyLineBreaker.java @@ -166,7 +166,7 @@ public class GreedyLineBreaker extends LineBreaker { if (lineBreaks.breaks.length != mBreaksList.size()) { lineBreaks.breaks = new int[mBreaksList.size()]; lineBreaks.widths = new float[mWidthsList.size()]; - lineBreaks.flags = new boolean[mFlagsList.size()]; + lineBreaks.flags = new int[mFlagsList.size()]; } int i = 0; @@ -181,7 +181,7 @@ public class GreedyLineBreaker extends LineBreaker { } i = 0; for (boolean b : mFlagsList) { - lineBreaks.flags[i] = b; + lineBreaks.flags[i] = b ? TAB_MASK : 0; i++; } diff --git a/tools/layoutlib/bridge/src/android/text/LineBreaker.java b/tools/layoutlib/bridge/src/android/text/LineBreaker.java index 8be3635..54445a4 100644 --- a/tools/layoutlib/bridge/src/android/text/LineBreaker.java +++ b/tools/layoutlib/bridge/src/android/text/LineBreaker.java @@ -26,6 +26,8 @@ import java.util.List; // frameworks/base/core/jni/android_text_StaticLayout.cpp revision b808260 public abstract class LineBreaker { + protected static final int TAB_MASK = 0x20000000; // keep in sync with StaticLayout + protected final @NonNull List<Primitive> mPrimitives; protected final @NonNull LineWidth mLineWidth; protected final @NonNull TabStops mTabStops; diff --git a/tools/layoutlib/bridge/src/android/text/OptimizingLineBreaker.java b/tools/layoutlib/bridge/src/android/text/OptimizingLineBreaker.java index d5d7798..cd92581 100644 --- a/tools/layoutlib/bridge/src/android/text/OptimizingLineBreaker.java +++ b/tools/layoutlib/bridge/src/android/text/OptimizingLineBreaker.java @@ -51,7 +51,7 @@ public class OptimizingLineBreaker extends LineBreaker { assert p.type == PrimitiveType.PENALTY; breakInfo.breaks = new int[]{0}; breakInfo.widths = new float[]{p.width}; - breakInfo.flags = new boolean[]{false}; + breakInfo.flags = new int[]{0}; return; } Node[] opt = new Node[numBreaks]; @@ -129,7 +129,7 @@ public class OptimizingLineBreaker extends LineBreaker { breakInfo.breaks[count] = mPrimitives.get(idx).location; breakInfo.widths[count] = opt[idx].mWidth; - breakInfo.flags [count] = opt[idx].mHasTabs; + breakInfo.flags [count] = opt[idx].mHasTabs ? TAB_MASK : 0; idx = opt[idx].mPrev; } } @@ -140,7 +140,7 @@ public class OptimizingLineBreaker extends LineBreaker { } int[] breaks = new int[size]; float[] widths = new float[size]; - boolean[] flags = new boolean[size]; + int[] flags = new int[size]; int toCopy = Math.min(size, lineBreaks.breaks.length); System.arraycopy(lineBreaks.breaks, 0, breaks, 0, toCopy); |