Make --features rand=1 available to the user
Use rand=255 to mean "randomize". Part of https://github.com/harfbuzz/harfbuzz/pull/803
This commit is contained in:
parent
cc1c4fdf88
commit
71c9f84e7c
|
@ -541,18 +541,15 @@ struct AlternateSet
|
||||||
unsigned int shift = hb_ctz (lookup_mask);
|
unsigned int shift = hb_ctz (lookup_mask);
|
||||||
unsigned int alt_index = ((lookup_mask & glyph_mask) >> shift);
|
unsigned int alt_index = ((lookup_mask & glyph_mask) >> shift);
|
||||||
|
|
||||||
if (unlikely (alt_index > count || alt_index == 0)) return_trace (false);
|
/* If alt_index is MAX, randomize feature if it is the rand feature. */
|
||||||
|
if (alt_index == HB_OT_MAP_MAX_VALUE && c->random)
|
||||||
/* This is ugly... If alt_index is 1, we take it as "on", and randomize
|
|
||||||
* feature if it is the rand feature. If it's > 1, it's a user-set value
|
|
||||||
* for sure, so respect it. So, user cannot set rand=1 and expect it to
|
|
||||||
* choose the first alternate... */
|
|
||||||
if (alt_index == 1 && c->random)
|
|
||||||
{
|
{
|
||||||
c->random_state = (0x5DEECE66Dull * c->random_state + 11) & (((uint64_t) 1 << 48) - 1);
|
c->random_state = (0x5DEECE66Dull * c->random_state + 11) & (((uint64_t) 1 << 48) - 1);
|
||||||
alt_index = (c->random_state >> 32) % count + 1;
|
alt_index = (c->random_state >> 32) % count + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (unlikely (alt_index > count || alt_index == 0)) return_trace (false);
|
||||||
|
|
||||||
c->replace_glyph (alternates[alt_index - 1]);
|
c->replace_glyph (alternates[alt_index - 1]);
|
||||||
|
|
||||||
return_trace (true);
|
return_trace (true);
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
#include "hb-buffer.hh"
|
#include "hb-buffer.hh"
|
||||||
#include "hb-map.hh"
|
#include "hb-map.hh"
|
||||||
#include "hb-set.hh"
|
#include "hb-set.hh"
|
||||||
|
#include "hb-ot-map.hh"
|
||||||
#include "hb-ot-layout-common.hh"
|
#include "hb-ot-layout-common.hh"
|
||||||
#include "hb-ot-layout-gdef-table.hh"
|
#include "hb-ot-layout-gdef-table.hh"
|
||||||
|
|
||||||
|
|
|
@ -210,8 +210,8 @@ hb_ot_map_builder_t::compile (hb_ot_map_t &m,
|
||||||
/* Uses the global bit */
|
/* Uses the global bit */
|
||||||
bits_needed = 0;
|
bits_needed = 0;
|
||||||
else
|
else
|
||||||
/* Limit to 8 bits per feature. */
|
/* Limit bits per feature. */
|
||||||
bits_needed = MIN(8u, hb_bit_storage (info->max_value));
|
bits_needed = MIN(HB_OT_MAP_MAX_BITS, hb_bit_storage (info->max_value));
|
||||||
|
|
||||||
if (!info->max_value || next_bit + bits_needed > 8 * sizeof (hb_mask_t))
|
if (!info->max_value || next_bit + bits_needed > 8 * sizeof (hb_mask_t))
|
||||||
continue; /* Feature disabled, or not enough bits. */
|
continue; /* Feature disabled, or not enough bits. */
|
||||||
|
|
|
@ -32,6 +32,9 @@
|
||||||
#include "hb-buffer.hh"
|
#include "hb-buffer.hh"
|
||||||
|
|
||||||
|
|
||||||
|
#define HB_OT_MAP_MAX_BITS 8u
|
||||||
|
#define HB_OT_MAP_MAX_VALUE ((1u << HB_OT_MAP_MAX_BITS) - 1u)
|
||||||
|
|
||||||
struct hb_ot_shape_plan_t;
|
struct hb_ot_shape_plan_t;
|
||||||
|
|
||||||
static const hb_tag_t table_tags[2] = {HB_OT_TAG_GSUB, HB_OT_TAG_GPOS};
|
static const hb_tag_t table_tags[2] = {HB_OT_TAG_GSUB, HB_OT_TAG_GPOS};
|
||||||
|
|
|
@ -96,7 +96,7 @@ hb_ot_shape_collect_features (hb_ot_shape_planner_t *planner,
|
||||||
map->add_feature (HB_TAG ('d','n','o','m'), 1, F_NONE);
|
map->add_feature (HB_TAG ('d','n','o','m'), 1, F_NONE);
|
||||||
|
|
||||||
/* Random! */
|
/* Random! */
|
||||||
map->add_feature (HB_TAG ('r','a','n','d'), 1, F_GLOBAL | F_RANDOM);
|
map->add_feature (HB_TAG ('r','a','n','d'), HB_OT_MAP_MAX_VALUE, F_GLOBAL | F_RANDOM);
|
||||||
|
|
||||||
if (planner->shaper->collect_features)
|
if (planner->shaper->collect_features)
|
||||||
planner->shaper->collect_features (planner);
|
planner->shaper->collect_features (planner);
|
||||||
|
|
Loading…
Reference in New Issue