From 60006d368770982c6a0d3bf06eb937773343cf5b Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Thu, 20 Jan 2022 15:29:28 -0700 Subject: [PATCH] [gsubgpos] Adjust chaining unsafe-to-concat application Fixes three tests. --- src/hb-ot-layout-gsubgpos.hh | 44 ++++++++++++++++++++---------------- 1 file changed, 24 insertions(+), 20 deletions(-) diff --git a/src/hb-ot-layout-gsubgpos.hh b/src/hb-ot-layout-gsubgpos.hh index 9c48b0ee8..8ee114d5b 100644 --- a/src/hb-ot-layout-gsubgpos.hh +++ b/src/hb-ot-layout-gsubgpos.hh @@ -2490,34 +2490,38 @@ static inline bool chain_context_apply_lookup (hb_ot_apply_context_t *c, const LookupRecord lookupRecord[], ChainContextApplyLookupContext &lookup_context) { - unsigned start_index = c->buffer->out_len, end_index = c->buffer->idx; + unsigned end_index = c->buffer->idx; unsigned match_end = 0; unsigned match_positions[HB_MAX_CONTEXT_LENGTH]; - if (match_input (c, - inputCount, input, - lookup_context.funcs.match, lookup_context.match_data[1], - &match_end, match_positions) && (end_index = match_end) - && match_backtrack (c, - backtrackCount, backtrack, - lookup_context.funcs.match, lookup_context.match_data[0], - &start_index) - && match_lookahead (c, - lookaheadCount, lookahead, - lookup_context.funcs.match, lookup_context.match_data[2], - match_end, &end_index)) + if (!(match_input (c, + inputCount, input, + lookup_context.funcs.match, lookup_context.match_data[1], + &match_end, match_positions) && (end_index = match_end) + && match_lookahead (c, + lookaheadCount, lookahead, + lookup_context.funcs.match, lookup_context.match_data[2], + match_end, &end_index))) { - c->buffer->unsafe_to_break_from_outbuffer (start_index, end_index); - apply_lookup (c, - inputCount, match_positions, - lookupCount, lookupRecord, - match_end); - return true; + c->buffer->unsafe_to_concat (c->buffer->idx, end_index); + return false; } - else + + unsigned start_index = c->buffer->out_len; + if (!match_backtrack (c, + backtrackCount, backtrack, + lookup_context.funcs.match, lookup_context.match_data[0], + &start_index)) { c->buffer->unsafe_to_concat_from_outbuffer (start_index, end_index); return false; } + + c->buffer->unsafe_to_break_from_outbuffer (start_index, end_index); + apply_lookup (c, + inputCount, match_positions, + lookupCount, lookupRecord, + match_end); + return true; } struct ChainRule