9 stable releases

1.5.0 Mar 29, 2023
1.4.2 Jan 18, 2023
1.3.0 Nov 8, 2022
1.1.0 Sep 10, 2021
1.0.0 Aug 27, 2021

#98 in Memory management

Download history 9061/week @ 2024-07-20 9011/week @ 2024-07-27 9659/week @ 2024-08-03 8135/week @ 2024-08-10 8570/week @ 2024-08-17 11336/week @ 2024-08-24 10106/week @ 2024-08-31 11262/week @ 2024-09-07 12988/week @ 2024-09-14 10090/week @ 2024-09-21 10752/week @ 2024-09-28 12587/week @ 2024-10-05 13145/week @ 2024-10-12 16476/week @ 2024-10-19 13435/week @ 2024-10-26 12437/week @ 2024-11-02

58,510 downloads per month
Used in 69 crates (via zenoh-keyexpr)

EPL-2.0 license

20KB
456 lines

This library provides an alternative to ghost-cell which uses concrete types instead of lifetimes for branding.

This allows a more convenient usage, where cells and tokens can be constructed independently, with the same compile-time guarantees as ghost-cell. The trade-off for this arguably more convenient usage and arguably easier to understand branding method is that tokens, while zero-sized if made correctly, must be guaranteed to be constructable only if no other instance exists.

To this end, this crate provides the generate_token macro, which will create a ZST which can only be constructed using TokenTrait::new.


lib.rs:

This library provides an alternative to ghost-cell which uses concrete types instead of lifetimes for branding.

This allows a more convenient usage, where cells and tokens can be constructed independently, with the same compile-time guarantees as ghost-cell. The trade-off for this arguably more convenient usage and arguably easier to understand branding method is that tokens, while zero-sized if made correctly, must be guaranteed to be constructable only if no other instance exists.

To this end, this crate provides the generate_token macro, which will create a ZST which can only be constructed using TokenTrait::aquire, which is generated to guarantee no other token exists before returning the token. This is done by checking a static AtomicBool flag, which is the only runtime cost of these tokens.

Dependencies