10 releases

0.1.8 Sep 11, 2024
0.1.7 Dec 29, 2021
0.1.5 Jan 2, 2021
0.1.4 Dec 26, 2018
0.0.0 Oct 22, 2018

#107 in Concurrency

Download history 862/week @ 2024-06-13 604/week @ 2024-06-20 417/week @ 2024-06-27 400/week @ 2024-07-04 410/week @ 2024-07-11 548/week @ 2024-07-18 686/week @ 2024-07-25 498/week @ 2024-08-01 832/week @ 2024-08-08 991/week @ 2024-08-15 411/week @ 2024-08-22 1024/week @ 2024-08-29 1545/week @ 2024-09-05 1529/week @ 2024-09-12 1039/week @ 2024-09-19 1317/week @ 2024-09-26

5,880 downloads per month
Used in 16 crates (7 directly)

GPL-3.0-or-later

18KB
168 lines

pipeline coverage crates.io Docs rustc

uid

uid (short for unique identifiers) is a crate for creating unique IDs for usage in a Rust program. IDs can have many purposes in programs, but this crate's IDs are mostly useful for identification tasks. For example, consider having some form of simple in-memory database (in the form of a HashMap or something more sophisticated). IDs as created by this crate make for perfect primary keys.

Said IDs have a couple properties that, depending on the context, are useful to have:

  1. IDs are lightweight and ultimately just a number with some compile time magic (and a small creation cost) attached to them.
  2. Created IDs are guaranteed to be unique. That is, when created at runtime (deserialization is not supported for obvious reasons), two newly crated IDs are guaranteed to never be the same.
  3. They are fully thread safe. That is, uniqueness is guaranteed even among different threads.
  4. IDs are immutable. Once created, an ID can (potentially) be copied, hashed, compared, and more, but it cannot be changed.
  5. IDs can form name (or rather type) spaces. That is, an ID can be parametrized by an arbitrary (potentially private) type and only IDs that are parametrized by the same type can interact (i.e., be compared etc.).

No runtime deps