Function zebra_test::prelude::prop::char::select_char

pub fn select_char(
    rnd: &mut impl Rng,
    special: &[char],
    preferred: &[RangeInclusive<char>],
    ranges: &[RangeInclusive<char>],
) -> char
Expand description

Selects a random character the way CharStrategy does.

If special is non-empty, there is a 50% chance that a character from this array is chosen randomly, and will be returned if that character falls within ranges.

If preferred is non-empty, there is a 50% chance that any generation which gets past the special step picks a random element from this list, then a random character from within that range (both endpoints inclusive). That character will be returned if it falls within ranges.

In all other cases, an element is picked randomly from ranges and a random character within the range (both endpoints inclusive) is chosen and returned.

Notice that in all cases, ranges completely defines the set of characters that can possibly be defined.

It is legal for ranges in all cases to contain non-characters.

Both preferred and ranges bias selection towards characters in smaller ranges. This is deliberate. preferred is usually tuned to select particular characters anyway. ranges is usually derived from some external property, and the fact that a range is small often means it is more interesting.