From aed32589af6d5fce3e68fe41865e258ea7eb2413 Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Fri, 2 Feb 2018 16:08:50 -0500 Subject: [PATCH] [aat] In ContextualSubtable, mark mark after substituting mark Fixes MORX-21. --- src/hb-aat-layout-morx-table.hh | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/hb-aat-layout-morx-table.hh b/src/hb-aat-layout-morx-table.hh index 7a45a24e5..ffe4d03ae 100644 --- a/src/hb-aat-layout-morx-table.hh +++ b/src/hb-aat-layout-morx-table.hh @@ -207,13 +207,7 @@ struct ContextualSubtable { hb_buffer_t *buffer = driver->buffer; - if (entry->flags & SetMark) - { - mark = buffer->idx; - last_zero_before_mark = driver->last_zero; - } - - if (entry->data.markIndex != 0xFFFF) + if (entry->data.markIndex != 0xFFFF && mark < buffer->len) { const Lookup &lookup = subs[entry->data.markIndex]; hb_glyph_info_t *info = buffer->info; @@ -225,7 +219,7 @@ struct ContextualSubtable ret = true; } } - if (entry->data.currentIndex != 0xFFFF) + if (entry->data.currentIndex != 0xFFFF && buffer->idx < buffer->len) { const Lookup &lookup = subs[entry->data.currentIndex]; hb_glyph_info_t *info = buffer->info; @@ -238,6 +232,12 @@ struct ContextualSubtable } } + if (entry->flags & SetMark) + { + mark = buffer->idx; + last_zero_before_mark = driver->last_zero; + } + return true; }