The basic version of hb_shape()
determines
its shaping strategy based on examining the capabilities of the
font file. OpenType font tables cause HarfBuzz to try the
ot
shaper, while AAT font tables cause HarfBuzz to try the
aat
shaper.
In the real world, however, a font might include some unusual
mix of tables, or one of the tables might simply be broken for
the script you need to shape. So, sometimes, you might not
want to rely on HarfBuzz's process for deciding what to do, and
just tell hb_shape()
what you want it to try.
hb_shape_full()
is an alternate shaping
function that lets you supply a list of shapers for HarfBuzz to
try, in order, when shaping your buffer. For example, if you
have determined that HarfBuzz's attempts to work around broken
tables gives you better results than the AAT shaper itself does,
you might move the AAT shaper to the end of your list of
preferences and call hb_shape_full()
char *shaperprefs[3] = {"ot", "default", "aat"}; ... hb_shape_full(font, buf, userfeatures, num_features, shaperprefs);
to get results you are happier with.
You may also want to call
hb_shape_list_shapers()
to get a list of
the shapers that were built at compile time in your copy of HarfBuzz.