From 95d052a791262ebccbfeb794b992525ba2cc0ffc Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Sat, 22 Jan 2022 10:16:23 -0700 Subject: [PATCH] [unsafe-to-concat] Adjust GPOS lookbacks Fixes Cursive aots test, fails a couple new aots ones. --- src/hb-ot-layout-gpos-table.hh | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/hb-ot-layout-gpos-table.hh b/src/hb-ot-layout-gpos-table.hh index c24ccdd98..e91f416d3 100644 --- a/src/hb-ot-layout-gpos-table.hh +++ b/src/hb-ot-layout-gpos-table.hh @@ -1881,14 +1881,14 @@ struct CursivePosFormat1 unsigned unsafe_from; if (!skippy_iter.prev (&unsafe_from)) { - buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx); + buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx + 1); return_trace (false); } const EntryExitRecord &prev_record = entryExitRecord[(this+coverage).get_coverage (buffer->info[skippy_iter.idx].codepoint)]; if (!prev_record.exitAnchor) { - buffer->unsafe_to_concat_from_outbuffer (skippy_iter.idx, buffer->idx); + buffer->unsafe_to_concat_from_outbuffer (skippy_iter.idx, buffer->idx + 1); return_trace (false); } @@ -2157,7 +2157,7 @@ struct MarkBasePosFormat1 unsigned unsafe_from; if (!skippy_iter.prev (&unsafe_from)) { - buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx); + buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx + 1); return_trace (false); } @@ -2417,7 +2417,7 @@ struct MarkLigPosFormat1 unsigned unsafe_from; if (!skippy_iter.prev (&unsafe_from)) { - buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx); + buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx + 1); return_trace (false); } @@ -2619,7 +2619,7 @@ struct MarkMarkPosFormat1 unsigned unsafe_from; if (!skippy_iter.prev (&unsafe_from)) { - buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx); + buffer->unsafe_to_concat_from_outbuffer (unsafe_from, buffer->idx + 1); return_trace (false); }