Function enumValueWithIndex [src]

Returns a random value from an enum, evenly distributed. An index into an array of all named values is generated using the specified Index type to determine the return value. This allows for results to be independent of usize representation. Prefer enumValue if this isn't important. See uintLessThan, which this function uses in most cases, for commentary on the runtime of this function.

Prototype

pub fn enumValueWithIndex(r: Random, comptime EnumType: type, comptime Index: type) EnumType

Parameters

r: RandomEnumType: typeIndex: type

Source

pub fn enumValueWithIndex(r: Random, comptime EnumType: type, comptime Index: type) EnumType { comptime assert(@typeInfo(EnumType) == .@"enum"); // We won't use int -> enum casting because enum elements can have // arbitrary values. Instead we'll randomly pick one of the type's values. const values = comptime std.enums.values(EnumType); comptime assert(values.len > 0); // can't return anything comptime assert(maxInt(Index) >= values.len - 1); // can't access all values if (values.len == 1) return values[0]; const index = if (comptime values.len - 1 == maxInt(Index)) r.int(Index) else r.uintLessThan(Index, values.len); const MinInt = MinArrayIndex(Index); return values[@as(MinInt, @intCast(index))]; }