1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39

/// Test if an item implements `Clone` trait.
/// 
/// ### Examples
///
/// - Clone item:
/// 
/// ```
/// // either "test" or "all" features must be enabled
/// #[cfg(any(feature = "test", feature = "all"))]
/// {
///     use cs_utils::test::implements_clone;
///
///     #[derive(Clone)]
///     struct TestStruct {}
/// 
///     // compiles fine
///     implements_clone(TestStruct {});
/// }
/// ```
/// 
/// - Non-Clone item:
/// 
/// ```compile_fail
/// // either "test" or "all" features must be enabled
/// #[cfg(any(feature = "test", feature = "all"))]
/// {
///     use cs_utils::test::implements_clone;
///     
///     // do not derive clone
///     struct TestStruct {}
/// 
///     // does not compile
///     implements_clone(TestStruct {});
/// }
/// ```
pub fn implements_clone<T: Clone>(item: T) -> T {
    return item;
}