#representation #values #explicit #api #display #four-character-codes #four-character-code

no-std four-cc

Newtype wrapper providing a convenient representation of four-character-code values

4 releases (breaking)

0.4.0 Mar 16, 2024
0.3.0 May 30, 2023
0.2.0 May 22, 2022
0.1.0 Jul 15, 2020

#459 in Parser implementations

Download history 1920/week @ 2024-09-20 1718/week @ 2024-09-27 1406/week @ 2024-10-04 1463/week @ 2024-10-11 1064/week @ 2024-10-18 1015/week @ 2024-10-25 1490/week @ 2024-11-01 1163/week @ 2024-11-08 865/week @ 2024-11-15 1180/week @ 2024-11-22 1443/week @ 2024-11-29 1534/week @ 2024-12-06 1641/week @ 2024-12-13 1693/week @ 2024-12-20 1158/week @ 2024-12-27 1805/week @ 2025-01-03

6,548 downloads per month
Used in 39 crates (7 directly)

MIT/Apache

11KB
190 lines

four-cc

Representation of four-character-codes.

crates.io version Documentation Coverage Status


lib.rs:

Newtype wrapper providing a convenient representation of four-character-code values.

Using this type in a public APIs as an alternative to simply passing the equivalent u32 makes the value's expected use explicit.

Creating a FourCC value

use four_cc::FourCC;

let uuid = FourCC(*b"uuid");

// using Into
let code: FourCC = b"uuid".into();
assert_eq!(uuid, code);

From a slice

let data = b"moofftyp";
let code = FourCC::from(&data[0..4]);  // would panic if fewer than 4 bytes
assert_eq!(FourCC(*b"moof"), code);

From a u32

let data: u32 = 0x6d6f6f66;
let code = FourCC::from(data);
assert_eq!(FourCC(*b"moof"), code);
// conversion back into a u32
let converted: u32 = code.into();
assert_eq!(data, converted);

Constants

FourCC values can be used in const expressions

const UUID: FourCC = FourCC(*b"uuid");

Matching

You can use FourCC values in match patterns as long as you define constants to match against,

const UUID: FourCC = FourCC(*b"uuid");
const MOOV: FourCC = FourCC(*b"moov");
match other_value {
    MOOV => println!("movie"),
    UUID => println!("unique identifier"),
    // compiler will not accept: FourCC(*b"trun") => println!("track fragment run"),
    _ => println!("Other value; scary stuff")
}

Invalid literal values

If the literal has other than four bytes, compilation will fail

let bad_fourcc = FourCC(*b"uuid123");
// -> expected an array with a fixed size of 4 elements, found one with 7 elements

Note the FourCC value may contain non-printable byte values, including the byte-value zero.

Debug display

let uuid = FourCC(*b"uuid");
println!("it's {:?}", uuid);  // produces: it's FourCC{uuid}

Note that if the FourCC bytes are not able to be converted to UTF8, then a fallback representation will be used (as it would be surprising for format!() to panic).

let uuid = FourCC(*b"u\xFFi\0");
println!("it's {:?}", uuid);  // produces: it's FourCC{u\xffi\x00}

Dependencies

~0–490KB