Commit Graph

313 Commits

Author SHA1 Message Date
Raph Levien
40b492caa6 Suppress line breaks in emoji + modifier am: 7f9de429d4
am: 6a8eae727f

* commit '6a8eae727f13f503ad687b64b80da7f33948f266':
  Suppress line breaks in emoji + modifier
2016-02-26 20:19:37 +00:00
Raph Levien
6a8eae727f Suppress line breaks in emoji + modifier
am: 7f9de429d4

* commit '7f9de429d43556e288e512313421c2a54513c8c4':
  Suppress line breaks in emoji + modifier
2016-02-26 20:17:27 +00:00
Raph Levien
7f9de429d4 Suppress line breaks in emoji + modifier
An emoji base with an emoji modifier renders as a single glyph and
thus should not be a line break. Current (Unicode 8) logic does
indicate a line break, so we override the results of the ICU line
break iterator. The code references a proposal to improve Unicode
behavior; when that is adopted and we upgrade ICU accordingly, the
special-case code should be deleted, but the tests can remain.

Bug: 27343378
Change-Id: I5de9c53e9a34c503816f9131e3d894e6f7a57d13
2016-02-26 19:05:34 +00:00
Seigo Nonaka
8d0705fc82 Use color font if skin tone is specified. am: b7d66e3db0
am: 442481c200

* commit '442481c2004b90f02f546007bb881796e9c6eb4f':
  Use color font if skin tone is specified.
2016-02-26 03:23:39 +00:00
Seigo Nonaka
442481c200 Use color font if skin tone is specified.
am: b7d66e3db0

* commit 'b7d66e3db0473ace4ddfd3b553c4e9796e49c410':
  Use color font if skin tone is specified.
2016-02-26 03:22:09 +00:00
Seigo Nonaka
b7d66e3db0 Use color font if skin tone is specified.
If skin tone is specified, the base emoji should be emoji style even
if it is text presentation default emoji.

This patch also removes wrong test case which expects default emoji
presentation but it is controlled by family order in /etc/fonts.xml
and there is no special logic for default presentation in minikin.
Thus the default presentation unit test should not be in minikin.

Bug: 27342346

Change-Id: I74a2b2feab4d559535049e368cfd833063cce81c
2016-02-26 11:26:30 +09:00
Raph Levien
d96751967d Merge "Suppress grapheme cluster breaks in emoji with modifiers" into nyc-dev am: 336d826c44
am: bccbdfb377

* commit 'bccbdfb377a497c915f46067e4d898e423bf1797':
  Suppress grapheme cluster breaks in emoji with modifiers
2016-02-24 21:18:11 +00:00
Raph Levien
bccbdfb377 Merge "Suppress grapheme cluster breaks in emoji with modifiers" into nyc-dev
am: 336d826c44

* commit '336d826c44264bbca59a7ee52809a516534f9b7e':
  Suppress grapheme cluster breaks in emoji with modifiers
2016-02-24 21:07:45 +00:00
Raph Levien
336d826c44 Merge "Suppress grapheme cluster breaks in emoji with modifiers" into nyc-dev 2016-02-24 20:58:55 +00:00
Raph Levien
675933f271 Suppress grapheme cluster breaks in emoji with modifiers
An emoji with a modifier should be treated as a single grapheme, i.e.
it should not be possible to place the cursor between the base and
modifier.  This patch implements the proposed Rule GB9c from Mark
Davis's proposal entitled "Fixing breaking properties for emoji",
L2/16-011R3.

The patch also skips over variation sequences attached the to the
preceding character, for computing grapheme cluster boundaries.

Bug: 26829153
Change-Id: Iff5bc2bb8e5246223a017c7cf33acfbf63817f16
2016-02-24 12:43:36 -08:00
Seigo Nonaka
01795cc7ef Merge "Support Hanb script." into nyc-dev am: 9b2942bfe6
am: a69b250e65

* commit 'a69b250e656ffe12b99228cdc1de2a60a04756ff':
  Support Hanb script.
2016-02-23 04:11:55 +00:00
Seigo Nonaka
a69b250e65 Merge "Support Hanb script." into nyc-dev
am: 9b2942bfe6

* commit '9b2942bfe6ed152b142163fa173831674ba17464':
  Support Hanb script.
2016-02-23 04:04:44 +00:00
Seigo Nonaka
9b2942bfe6 Merge "Support Hanb script." into nyc-dev 2016-02-23 03:57:58 +00:00
Raph Levien
baa6a9671a Merge "Suppress linebreaks in emoji ZWJ sequences" into nyc-dev am: e87aac42d0
am: aca6476db8

* commit 'aca6476db8007059cac8fec33e3b96c1a10818e8':
  Suppress linebreaks in emoji ZWJ sequences
2016-02-19 18:07:11 +00:00
Raph Levien
aca6476db8 Merge "Suppress linebreaks in emoji ZWJ sequences" into nyc-dev
am: e87aac42d0

* commit 'e87aac42d0f7c80a0836d4cde29ed36e4e848003':
  Suppress linebreaks in emoji ZWJ sequences
2016-02-19 18:02:35 +00:00
Raph Levien
e87aac42d0 Merge "Suppress linebreaks in emoji ZWJ sequences" into nyc-dev 2016-02-19 17:53:48 +00:00
Keisuke Kuroyanagi
c96923b780 Optimize: Use measureText instead of doLayout. am: 761218bce9
am: d43f5022d2

* commit 'd43f5022d263c6f0d70063094b9530bec2af8869':
  Optimize: Use measureText instead of doLayout.
2016-02-18 23:37:41 +00:00
Keisuke Kuroyanagi
d43f5022d2 Optimize: Use measureText instead of doLayout.
am: 761218bce9

* commit '761218bce9059c4c73e5089ce5924913cbd5fb6f':
  Optimize: Use measureText instead of doLayout.
2016-02-18 23:30:50 +00:00
Raph Levien
a14712eaf8 Suppress linebreaks in emoji ZWJ sequences
Due to the way emoji ZWJ sequences are defined, the ICU line breaking
algorithm determines that there are valid line breaks inside the
sequence. This patch suppresses these line breaks.

This is an adaptation of I225ebebc0f4186e4b8f48fee399c4a62b3f0218a
into the nyc-dev branch.

Bug: 25433289
Change-Id: I84b50b1e6ef13d436965eab389659d02a30d100f
2016-02-18 15:00:24 -08:00
Raph Levien
7753b1c525 Disable hyphenation when word overlaps style boundary am: 72ab39455f
am: b708833cf3

* commit 'b708833cf3562f7169a8ef6c22b4a194af5d1b07':
  Disable hyphenation when word overlaps style boundary
2016-02-18 19:51:41 +00:00
Keisuke Kuroyanagi
761218bce9 Optimize: Use measureText instead of doLayout.
With this CL, measureText is used for getRunAdvance,
getOffsetForAdvance and line breaking.

Bug: 24505153
Change-Id: Ib699f6b1391b46537736fc274cdb41686586b550
2016-02-18 11:46:48 -08:00
Raph Levien
b708833cf3 Disable hyphenation when word overlaps style boundary
am: 72ab39455f

* commit '72ab39455f2fe587116066d5ec66d75cd89f0114':
  Disable hyphenation when word overlaps style boundary
2016-02-18 19:16:02 +00:00
Raph Levien
72ab39455f Disable hyphenation when word overlaps style boundary
In cases when a word (as defined by the ICU break iterator) overlaps a
style boundary, the returned wordStart can be extend before the range
currently being measured for layout. When we try to hyphenate the
resulting substrings, we get a negative range, which crashes. This
patch disables hyphenation in this case.

Bug: 27237112
Change-Id: I76d04b39dd3b4d6d267aaaf4bebc9ab361891646
2016-02-18 10:33:14 -08:00
Seigo Nonaka
77c3f8eb24 Support Hanb script.
Hanb is a union of Han and Bopomofo.

Bug: 26687969
Change-Id: Ic696bcbbc9607f3842fd0115668b8e7bd917e62b
2016-02-18 18:28:52 +09:00
Seigo Nonaka
d5ff8ab1de Merge "Improve Paint.measureText and Paint.hasGlyph for variation sequences." into nyc-dev am: 082dc16139
am: 80904b8960

* commit '80904b896025f4ad1199c783abdd8e2af8120210':
  Improve Paint.measureText and Paint.hasGlyph for variation sequences.
2016-02-18 04:42:02 +00:00
Seigo Nonaka
80904b8960 Merge "Improve Paint.measureText and Paint.hasGlyph for variation sequences." into nyc-dev
am: 082dc16139

* commit '082dc16139a239d6df3c78b9ef5542e38d6405d0':
  Improve Paint.measureText and Paint.hasGlyph for variation sequences.
2016-02-18 04:38:00 +00:00
Seigo Nonaka
082dc16139 Merge "Improve Paint.measureText and Paint.hasGlyph for variation sequences." into nyc-dev 2016-02-18 04:33:36 +00:00
Raph Levien
6f19a92b30 Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea am: 055b8c8cda -s ours am: c4ed0af154 am: 0eb5239cf5 -s ours am: 794c4d930b am: 7cfeeaeb0b am: fbf13599d9 -s ours am: 7a9fa36d3d
am: 5649913f3e  -s ours

* commit '5649913f3ef97e1295f95d075628173d76bc5e3f':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-18 00:35:28 +00:00
Raph Levien
5649913f3e Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea am: 055b8c8cda -s ours am: c4ed0af154 am: 0eb5239cf5 -s ours am: 794c4d930b am: 7cfeeaeb0b am: fbf13599d9 -s ours
am: 7a9fa36d3d

* commit '7a9fa36d3d6fa1691d6436e8c9b9e234913f140f':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-18 00:30:43 +00:00
Raph Levien
7a9fa36d3d Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea am: 055b8c8cda -s ours am: c4ed0af154 am: 0eb5239cf5 -s ours am: 794c4d930b am: 7cfeeaeb0b
am: fbf13599d9  -s ours

* commit 'fbf13599d9138547e1d56734c033d3637193a0bd':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-18 00:19:02 +00:00
Raph Levien
0f7db07b2d Add error logging on invalid cmap am: 9e8fd1dff7 am: 78bf54cc23 am: 83f28ad6b6
am: 960c6bd18b

* commit '960c6bd18b30accc4c18a468d42e31edcfde3da6':
  Add error logging on invalid cmap
2016-02-18 00:17:26 +00:00
Raph Levien
88645a5b0f Add penalty for breaks in URLs and email addresses
am: 76772e8ad4

* commit '76772e8ad4a88cbe87edc873dd66af7d0baf6a25':
  Add penalty for breaks in URLs and email addresses
2016-02-18 00:17:18 +00:00
Raph Levien
fbf13599d9 Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea am: 055b8c8cda -s ours am: c4ed0af154 am: 0eb5239cf5 -s ours am: 794c4d930b
am: 7cfeeaeb0b

* commit '7cfeeaeb0bb7db7e86f5f7839031c580629f25ad':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-18 00:13:35 +00:00
Raph Levien
7cfeeaeb0b Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea am: 055b8c8cda -s ours am: c4ed0af154 am: 0eb5239cf5 -s ours
am: 794c4d930b

* commit '794c4d930bb6a3a74734ab5f89897bb6eb92c117':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-18 00:04:40 +00:00
Raph Levien
794c4d930b Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea am: 055b8c8cda -s ours am: c4ed0af154
am: 0eb5239cf5  -s ours

* commit '0eb5239cf5fdae1de84a93e0881add6cb4ead7f6':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-17 23:59:33 +00:00
Raph Levien
960c6bd18b Add error logging on invalid cmap am: 9e8fd1dff7 am: 78bf54cc23
am: 83f28ad6b6

* commit '83f28ad6b687d09fb14c5f76673376962cd563cd':
  Add error logging on invalid cmap
2016-02-17 23:55:18 +00:00
Raph Levien
0eb5239cf5 Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea am: 055b8c8cda -s ours
am: c4ed0af154

* commit 'c4ed0af1541b7592f9b5b0a9f2c281f150db8c39':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-17 23:55:07 +00:00
Raph Levien
83f28ad6b6 Add error logging on invalid cmap am: 9e8fd1dff7
am: 78bf54cc23

* commit '78bf54cc23fd7752302e9e39cc6fbc7346f6f939':
  Add error logging on invalid cmap
2016-02-17 23:51:06 +00:00
Raph Levien
c4ed0af154 Add error logging on invalid cmap - DO NOT MERGE am: ac3b9bc4ea
am: 055b8c8cda  -s ours

* commit '055b8c8cda0b491f17cd597a96f651ff0c2cde49':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-17 23:47:10 +00:00
Raph Levien
78bf54cc23 Add error logging on invalid cmap
am: 9e8fd1dff7

* commit '9e8fd1dff74e2c696d3fd7a2873d982bcb0b06cd':
  Add error logging on invalid cmap
2016-02-17 23:43:34 +00:00
Raph Levien
055b8c8cda Add error logging on invalid cmap - DO NOT MERGE
am: ac3b9bc4ea

* commit 'ac3b9bc4ea57584b6b98307dc505567beaeedab1':
  Add error logging on invalid cmap - DO NOT MERGE
2016-02-17 23:43:26 +00:00
Raph Levien
90118a90f5 Add line breaks to email addresses and URLs
am: 5102c20dd5

* commit '5102c20dd50fde7ab9cdcdce173f53a6cacbd9e0':
  Add line breaks to email addresses and URLs
2016-02-17 23:42:21 +00:00
Raph Levien
084923f611 Special-case URLs and email addresses for line breaking
am: 76022a08e3

* commit '76022a08e3f01db804d97c10277ee2704ef68f45':
  Special-case URLs and email addresses for line breaking
2016-02-17 23:42:08 +00:00
Raph Levien
806dd8f792 Refine hyphenation around punctuation
am: c3b16d8894

* commit 'c3b16d88941b337c2b0b861daf610bf9ca80f908':
  Refine hyphenation around punctuation
2016-02-17 23:41:55 +00:00
Raph Levien
76772e8ad4 Add penalty for breaks in URLs and email addresses
Recent changes have added special cases for line breaks within URLs
and email addresses. Such breaks are undesirable when they can be
avoided, but at other times are needed to avoid huge gaps, or indeed
to make the line fit at all.

This patch assigns a penalty for such breaks, equal to the hyphenation
penalty. The mechanism is currently very simple, but would be easy to
fine-tune based on more detailed information about break quality.

Bug: 20126487
Bug: 20566159
Change-Id: I0d3323897737a2850f1e734fa17b96b065eabd9c
2016-02-17 23:13:44 +00:00
Raph Levien
5102c20dd5 Add line breaks to email addresses and URLs
This change adds accceptable line breaks according to sections 7.42
(Dividing URLs and e-mail addresses) and 14.12 (URLs or DOIs and line
breaks) of the Chicago Manual of Style (16th ed.). In general, these
place breaks before punctuation symbols, and suppresses them after
hyphens.

Bug: 20126487
Bug: 20566159
Change-Id: I2d07d516b920a506a2f718c38fb435c5eb1ee1f8
2016-02-17 23:12:48 +00:00
Raph Levien
76022a08e3 Special-case URLs and email addresses for line breaking
Detect URLs and email addresses, and suppress both line breaking and
hyphenation within them.

Bug: 20126487
Bug: 20566159

Change-Id: I43629347a063dcf579e355e5b678d7195f453ad9
2016-02-17 23:11:46 +00:00
Bill Yi
7e4f21a4e3 Merge commit \'408d44a0834d88a9ed4060dbeb8223fcd321f5d0\' into HEAD
am: d166b937e4

* commit 'd166b937e4aafc61e00a59101e38f628d19e1505':
2016-02-17 20:47:59 +00:00
Bill Yi
d166b937e4 Merge commit '408d44a0834d88a9ed4060dbeb8223fcd321f5d0' into HEAD 2016-02-17 09:50:45 -08:00
Seigo Nonaka
650392314e Improve Paint.measureText and Paint.hasGlyph for variation sequences.
Before this patch, the font fallback chain iterated all installed font
families if a variation selector was specified.

This CL narrows down the range of iteration.
To decide the font family for the variation sequence, we need to search
for both the variation sequence and its base code point.
The new range of the iteration is a union of them.

With this change, the running time of Paint.hasGlyph for the variation
sequence improves 50% and the running time of Paint.measureText for the
variation sequence improves 40% for the large text case on Nexus 6
userdebug.

Bug: 26784699
Bug: 11750374

Change-Id: Iced1349e3ca750821d8882c551551f65bb569794
2016-02-17 16:01:20 +09:00