From 5a3de4f4f8791139d2c04a66244001aba192ef6b Mon Sep 17 00:00:00 2001 From: Behdad Esfahbod Date: Tue, 2 Apr 2019 16:53:05 -0700 Subject: [PATCH] [serialize] Allow offset links that have base offset from the object base Rarely used, but used, in name table or similar constructs. --- src/hb-serialize.hh | 22 +++++++++++----------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/src/hb-serialize.hh b/src/hb-serialize.hh index a0b92280d..9b7143e3a 100644 --- a/src/hb-serialize.hh +++ b/src/hb-serialize.hh @@ -68,6 +68,7 @@ struct hb_serialize_context_t { bool is_wide: 1; unsigned position : 31; + int bias; objidx_t objidx; }; @@ -228,19 +229,18 @@ struct hb_serialize_context_t return; assert (current.length); - unsigned i = current.length - 1; - if (!base) - base = current[i].head; - else - { - while (i && base < current[i].head) - i--; - assert (base == current[i].head); - } + assert (current.tail ().head <= (const char *) &ofs); - auto& link = *current[i].links.push (); + if (!base) + base = current.tail ().head; + else + assert (current.tail ().head <= (const char *) base); + + /* FUCK. Check ofs lies within current object? */ + auto& link = *current.tail ().links.push (); link.is_wide = sizeof (T) == 4; link.position = (const char *) &ofs - (const char *) base; + link.bias = (const char *) base - current.tail ().head; link.objidx = objidx; } @@ -256,7 +256,7 @@ struct hb_serialize_context_t { const object_t::link_t &link = *link_it; const object_t &child = packed[link.objidx]; - unsigned offset = child.head - parent.head; + unsigned offset = (child.head - parent.head) - link.bias; if (link.is_wide) {