kx-utils 0.1.3

Common utils incubator
Documentation
//

/// Defines a marker type with [Clone], [Copy], [Debug], [Display] nad [PartialEq].
///
/// # Example
///
/// ```rust
/// use kx_utils::marker;
/// marker!(Token, "Has no inner value");
/// let token = Token;
/// ```
///
/// This is the equivalent of:
///
/// ```rust
/// #[doc = "Has no inner value"]
/// #[derive(
///     Clone,
///     Copy,
///     Debug,
///     derive_more::Display,
///     PartialEq,
/// )]
/// pub struct Token;
/// let token = Token;
/// ```
#[macro_export]
macro_rules! marker {
    ($name:ident, $docs:literal) => {
        #[doc = $docs]
        #[derive(Clone, Copy, Debug, derive_more::Display, PartialEq, Eq)]
        pub struct $name;
    };
}

#[cfg(test)]
mod tests {
    // a newtype with no inner value
    marker!(A, "a type");

    #[test]
    fn marker_is_equals() {
        assert_eq!(A, A);
    }

    #[test]
    fn marker_is_clone() {
        let a1 = A;
        #[allow(clippy::clone_on_copy)]
        let a2 = a1.clone();
        assert_eq!(a1, a2);
    }

    #[test]
    fn marker_is_copy() {
        let a1 = A;
        let a2 = a1;
        fn consume(_a: A) {}
        consume(a1);
        assert_eq!(a2, a1);
    }

    #[test]
    fn marker_is_debug() {
        assert_eq!(format!("{:?}", A), "A");
    }

    #[test]
    fn marker_is_display() {
        assert_eq!(format!("{}", A), "A");
    }
}