#emoji #hash #generate #value #deterministic #unique #hash-values

no-std hashmoji

Generates deterministic emoji based on the hash of a value

3 releases

new 0.1.2 Jan 15, 2025
0.1.1 Jan 15, 2025
0.1.0 Nov 7, 2023

#185 in Debugging

Download history 14/week @ 2024-11-04 9/week @ 2024-11-11 9/week @ 2024-12-09 8/week @ 2024-12-30 1/week @ 2025-01-06 218/week @ 2025-01-13

227 downloads per month

MIT/Apache

24KB
129 lines

hashmoji

hashmoji generates deterministic emoji based on the hash of a value.

This is useful for generating unique emojis for a given value, such as a user ID, a file hash, UUID, etc. It is easier for the eye to recognise an emoji than remembering some random alphanumeric strings.

hashmoji relies on the Hash trait to generate a unique emoji for a given value, which many types implement, and of course you can implement it for your own types using #[derive(Hash)].

Capabilities

  • Supports multiple versions of Unicode up to 15.1.
  • Supports no_std and optionally with alloc.
  • Choose the set of emojis to be selected from via groups, subgroups, modifiers, version, etc.
  • Generates configurable emoji sets during build so there's minimal runtime overhead.

Usage

let uuid = "30d8c256-0ffa-4e1b-8e1e-437bb0a0b45a";

// Generate a single emoji:
let emoji = hashmoji::one(uuid);
assert_eq!(emoji, "๐ŸŒค๏ธ");

// You can also generate a fixed length string:
let emoji = hashmoji::fixed(uuid, 10);
assert_eq!(emoji, "๐ŸŒค๏ธโ™Ž๐Ÿ˜Ÿ๐ŸŸฉโคต๏ธ๐Ÿ‡ฝ๐Ÿ‡ฐ๐Ÿ‡ง๐Ÿ‡ฆ๐Ÿ‰๐Ÿค ๐Ÿฆต");

// A variable length string, depending on the hash:
let emoji = hashmoji::variable(uuid, 3..7);
assert_eq!(emoji, "๐ŸŒค๏ธโ™Ž๐Ÿ˜Ÿ๐ŸŸฉ");

Features

  • std (default): Enables the use of std types and functionality.
  • alloc (default): Enables the use of alloc types and functionality. Having this off will remove fixed() and variable().
  • additive: Add to an empty set, instead of removing from the full set of emojis.

Filtering Features

By default, filtering features remove from the full set of emoji. When enabling the additive feature, the set of emojis start empty and the filtering features add to the set.

Also by default, the all-modifiers filter is enabled because there are so many very similar permutations of the same emoji where it becomes difficult to differentiate them. Many of these combinations and modifiers don't render correctly in IDEs, terminals, etc.

Groups and Subgroups

You can filter by groups and subgroups too. Here are all the groups:

  • smileys-and-emotion
  • people-and-body
  • animals-and-nature
  • food-and-drink
  • travel-and-places
  • activities
  • objects
  • symbols
  • flags

And some of the subgroups. See Cargo.toml for the full list:

  • face-smiling
  • face-affection
  • face-tongue
  • face-hand
  • face-neutral-skeptical
  • face-sleepy
  • etc...

Modifiers

  • all-modifiers (default): Filter hair-styles, skin-tones, genders.
  • hair-styles: Filter hair-styles.
  • skin-tones: Filter skin-tones.
  • genders: Filter gender modifiers.

Versions

You can choose the maximum Unicode version to be used. By default this is not set, so all versions are used. Versions are two digits for major, two for minor, e.g. v1501 = 15.1.

Supported versions are v1510, v1500, v1400, v1301, v1300, v1201, v1200, v1100, v0500, v0400, v0300, v0200, v0100, v0007, v0006, v0600.

License

hashmoji is licensed under either the MIT license or the Apache-2.0 license, at your discretion.

Dependencies

~185KB