You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
eeeeeta 973f98152a Derive PartialOrd and Ord for Uuid 7 years ago
benches Add simple benchmarks 7 years ago
src Derive PartialOrd and Ord for Uuid 7 years ago
.gitignore Update to master 8 years ago
.travis.yml Rename the rand feature to v4 7 years ago
Cargo.toml Bump to 0.2.0 7 years ago
LICENSE-APACHE Organise code and add Travis CI config 8 years ago
LICENSE-MIT Organise code and add Travis CI config 8 years ago
README.md Rename the rand feature to v4 7 years ago

README.md

uuid

Build Status

A Rust library to generate and parse UUIDs.

Provides support for Universally Unique Identifiers (UUIDs). A UUID is a unique 128-bit number, stored as 16 octets. UUIDs are used to assign unique identifiers to entities without requiring a central allocating authority.

They are particularly useful in distributed systems, though can be used in disparate areas, such as databases and network protocols. Typically a UUID is displayed in a readable string form as a sequence of hexadecimal digits, separated into groups by hyphens.

The uniqueness property is not strictly guaranteed, however for all practical purposes, it can be assumed that an unintentional collision would be extremely unlikely.

Documentation

Usage

Add this to your Cargo.toml:

[dependencies]
uuid = "0.2"

and this to your crate root:

extern crate uuid;

Examples

To parse a simple UUID, then print the version and urn string format:

use uuid::Uuid;

fn main() {
    let my_uuid = Uuid::parse_str("936DA01F9ABD4d9d80C702AF85C822A8").unwrap();
    println!("Parsed a version {} UUID.", my_uuid.get_version_num());
    println!("{}", my_uuid.to_urn_string());
}

The library supports 5 versions of UUID:

Name Version
Mac Version 1: MAC address
Dce Version 2: DCE Security
Md5 Version 3: MD5 hash
Random Version 4: Random
Sha1 Version 5: SHA-1 hash

To create a new random (V4) UUID and print it out in hexadecimal form, first you'll need to change how you depend on uuid:

[dependencies]
uuid = { version = "0.2", features = ["v4"] }

Next, you'll write:

use uuid::Uuid;

fn main() {
    let my_uuid = Uuid::new_v4();
    println!("{}", my_uuid);
}

References

Wikipedia: Universally Unique Identifier