From 69f3feaa58965aaf58b5528ff0388a6b8e2b0c49 Mon Sep 17 00:00:00 2001 From: Markus Mayer Date: Mon, 26 Feb 2024 12:31:30 +0100 Subject: [PATCH 1/3] Add tea constitution file --- tea.yaml | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 tea.yaml diff --git a/tea.yaml b/tea.yaml new file mode 100644 index 0000000..8603c83 --- /dev/null +++ b/tea.yaml @@ -0,0 +1,7 @@ +# https://tea.xyz/what-is-this-file +--- +version: 1.0.0 +codeOwners: + - '0xfB0cb2c716Ceb7A207C18c540c8EfdDf71B64689' +quorum: 1 + From d8adff1b9b770cf2670d9e3fdf0cee42970173d1 Mon Sep 17 00:00:00 2001 From: Markus Mayer Date: Sun, 5 May 2024 14:40:38 +0200 Subject: [PATCH 2/3] Add borsh support --- CHANGELOG.md | 3 ++- Cargo.toml | 19 +++++++++++-------- src/lib.rs | 44 ++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 57 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 93e71a9..e677341 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,6 +8,7 @@ This project uses [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ### Added - Added support for the `uuid` crate's `bytemuck` feature. +- Added support for [Borsh](https://borsh.io/) serialization via the `uuid` crate's `borsh` feature. ## 0.6.0 - 2023-06-24 @@ -41,7 +42,7 @@ This project uses [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ### Added -- Added `PartialEq` for `Vec` and `&[u8; 16]`. +- Added `PartialEq` for `Vec` and `&[u8; 16]`. ### Changed diff --git a/Cargo.toml b/Cargo.toml index cabc21a..0f79bef 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -12,13 +12,14 @@ readme = "README.md" rust-version = "1.67.1" [features] -default = ["random"] +default = ["fast-rng"] arbitrary = ["uuid/arbitrary", "arbitrary/derive"] # Add support for arbitrary types random = ["uuid/v4"] # Create random ShortGuid IDs -fast-rng = ["uuid/fast-rng"] # Use a faster (but still sufficiently random) RNG +fast-rng = ["random", "uuid/fast-rng"] # Use a faster (but still sufficiently random) RNG serde = ["dep:serde", "uuid/serde"] # Serialization and deserialization support # zerocopy = ["dep:zerocopy", "uuid/zerocopy"] # Zerocopy support bytemuck = ["dep:bytemuck", "uuid/bytemuck"] # Bytemuck support +borsh = ["dep:borsh", "dep:borsh-derive", "uuid/borsh"] # Borsh support [[example]] name = "shortguid" @@ -31,15 +32,17 @@ required-features = ["serde"] [dependencies] arbitrary = { version = "1.3.2", optional = true } -base64 = "0.21.5" -bytemuck = { version = "1.14.0", optional = true, features = ["derive"] } -serde = { version = "1.0.193", optional = true } -uuid = "1.6.1" -zerocopy = { version = "0.7.32", optional = true, features = ["derive"] } +base64 = "0.22.1" +borsh = { version = "1.5.0", optional = true, features = ["derive"] } +borsh-derive = { version = "1.5.0", optional = true } +bytemuck = { version = "1.15.0", optional = true, features = ["derive"] } +serde = { version = "1.0.200", optional = true } +uuid = "1.8.0" +zerocopy = { version = "0.7.33", optional = true, features = ["derive"] } [dev-dependencies] hex = "0.4.3" -clap = "4.4.11" +clap = "4.5.4" serde_test = "1.0.176" [package.metadata.docs.rs] diff --git a/src/lib.rs b/src/lib.rs index 517a95f..cf737d6 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -10,6 +10,22 @@ //! let random = ShortGuid::new_random(); //! assert_ne!(from_uuid, random); //! ``` +//! +//! # Create features +//! +//! Other crate features can also be useful beyond the version support: +//! +//! * `serde` - adds the ability to serialize and deserialize a UUID using +//! `serde`. +//! * `borsh` - adds the ability to serialize and deserialize a UUID using +//! `borsh`. +//! * `arbitrary` - adds an `Arbitrary` trait implementation to `Uuid` for +//! fuzzing. +//! * `random` - adds the ability to generate a random [`ShortGuid`]s. +//! * `fast-rng` - uses a faster algorithm for generating random [`ShortGuid`]s. +//! This feature requires more dependencies to compile, but is just as suitable for +//! [`ShortGuid`] as the default algorithm. Implies `random`. +//! * `bytemuck` - adds a `Pod` trait implementation to `Uuid` for byte manipulation // only enables the `doc_cfg` feature when // the `docsrs` configuration attribute is defined @@ -56,6 +72,10 @@ use uuid::Uuid; // feature = "zerocopy", // derive(zerocopy::AsBytes, zerocopy::FromBytes, zerocopy::Unaligned) // )] +#[cfg_attr( + feature = "borsh", + derive(borsh_derive::BorshDeserialize, borsh_derive::BorshSerialize) +)] #[cfg_attr( feature = "bytemuck", derive(bytemuck::Zeroable, bytemuck::Pod, bytemuck::TransparentWrapper) @@ -610,3 +630,27 @@ mod tests { assert_eq!(id, slice); } } + +#[cfg(all(test, feature = "borsh"))] +mod borsh_tests { + use super::*; + use std::string::ToString; + + #[test] + fn test_serialize() { + let uuid_str = "f9168c5e-ceb2-4faa-b6bf-329bf39fa1e4"; + let sg = ShortGuid::from_str(uuid_str).unwrap(); + let sg_bytes = sg.as_bytes().to_vec(); + let borsh_bytes = borsh::to_vec(&sg).unwrap(); + assert_eq!(sg_bytes, borsh_bytes); + } + + #[test] + fn test_deserialize() { + let uuid_str = "f9168c5e-ceb2-4faa-b6bf-329bf39fa1e4"; + let sg = ShortGuid::from_str(uuid_str).unwrap(); + let sg_bytes = sg.as_bytes().to_vec(); + let deserialized = borsh::from_slice::(&sg_bytes).unwrap().to_string(); + assert_eq!(uuid_str, deserialized); + } +} From a214e606e01252720be72073269bf47256c87451 Mon Sep 17 00:00:00 2001 From: Markus Mayer Date: Fri, 10 May 2024 11:41:23 +0200 Subject: [PATCH 3/3] Update crate documentation comment --- src/lib.rs | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index cf737d6..babdc9b 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1,3 +1,5 @@ +//! # shortguid +//! //! Provides short, URL-safe UUID representations. //! //! ``` @@ -11,21 +13,18 @@ //! assert_ne!(from_uuid, random); //! ``` //! -//! # Create features +//! ## Create features //! //! Other crate features can also be useful beyond the version support: //! -//! * `serde` - adds the ability to serialize and deserialize a UUID using -//! `serde`. -//! * `borsh` - adds the ability to serialize and deserialize a UUID using -//! `borsh`. -//! * `arbitrary` - adds an `Arbitrary` trait implementation to `Uuid` for -//! fuzzing. +//! * `serde` - adds the ability to serialize and deserialize a UUID using `serde`. +//! * `borsh` - adds the ability to serialize and deserialize a UUID using `borsh`. +//! * `arbitrary` - adds an `Arbitrary` trait implementation to `Uuid` for fuzzing. //! * `random` - adds the ability to generate a random [`ShortGuid`]s. //! * `fast-rng` - uses a faster algorithm for generating random [`ShortGuid`]s. //! This feature requires more dependencies to compile, but is just as suitable for -//! [`ShortGuid`] as the default algorithm. Implies `random`. -//! * `bytemuck` - adds a `Pod` trait implementation to `Uuid` for byte manipulation +//! [`ShortGuid`] as the default algorithm. Implies `random`, enabled by default. +//! * `bytemuck` - adds a `Pod` trait implementation to `Uuid` for byte manipulation. // only enables the `doc_cfg` feature when // the `docsrs` configuration attribute is defined