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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
/*******************************************************************************
*
* Copyright (c) 2025 - 2026.
* Haixing Hu, Qubit Co. Ltd.
*
* All rights reserved.
*
******************************************************************************/
//! # Consumer Clone Macro
//!
//! Generates Clone trait implementation for basic Consumer types
//!
//! Generates Clone implementation for Consumer structs that have `function`
//! and `name` fields. The function field is cloned using its inherent `clone`
//! method, which performs a shallow clone for smart pointers like `Arc` or `Rc`.
//!
//! # Parameters
//!
//! * `$struct_name` - The struct name
//! * `$generic` - Generic parameter list (one or two type parameters)
//!
//! # Examples
//!
//! ```rust
//! // For single type parameter
//! use qubit_function::{ArcConsumer, RcConsumer};
//! use qubit_function::consumers::bi_consumer::{ArcBiConsumer, RcBiConsumer};
//! macro_rules! impl_consumer_clone {
//! ($struct_name:ident<$t:ident>) => {
//! let _ = core::marker::PhantomData::<$t>;
//! let _ = stringify!($struct_name);
//! };
//! ($struct_name:ident<$t:ident, $u:ident>) => {
//! let _ = core::marker::PhantomData::<($t, $u)>;
//! let _ = stringify!($struct_name);
//! };
//! }
//! impl_consumer_clone!(ArcConsumer<i32>);
//!
//! // For single type parameter with Rc
//! impl_consumer_clone!(RcConsumer<i32>);
//!
//! // For two type parameters
//! impl_consumer_clone!(ArcBiConsumer<i32, i32>);
//!
//! // For two type parameters with Rc
//! impl_consumer_clone!(RcBiConsumer<i32, i32>);
//! ```
//!
//! # Author
//!
//! Haixing Hu
/// Generates Clone trait implementation for basic Consumer types
///
/// This macro should be used at the top level (outside of any impl block) as
/// it generates a complete `impl Clone for $struct_name` block. It generates
/// Clone implementation for Consumer structs that have `function` and `name`
/// fields. The function field is cloned using its inherent `clone` method,
/// which performs a shallow clone for smart pointers like `Arc` or `Rc`.
///
/// # Parameters
///
/// * `$struct_name` - The struct name
/// * `$t` - Generic parameter list (one or two type parameters)
/// * `$u` - Generic parameter list (one or two type parameters)
///
/// # Examples
///
/// ```rust
/// // For single type parameter with Arc
/// use qubit_function::{ArcConsumer, RcConsumer};
/// use qubit_function::consumers::bi_consumer::{ArcBiConsumer, RcBiConsumer};
/// macro_rules! impl_consumer_clone {
/// ($struct_name:ident<$t:ident>) => {
/// let _ = core::marker::PhantomData::<$t>;
/// let _ = stringify!($struct_name);
/// };
/// ($struct_name:ident<$t:ident, $u:ident>) => {
/// let _ = core::marker::PhantomData::<($t, $u)>;
/// let _ = stringify!($struct_name);
/// };
/// }
/// impl_consumer_clone!(ArcConsumer<i32>);
///
/// // For single type parameter with Rc
/// impl_consumer_clone!(RcConsumer<i32>);
///
/// // For two type parameters with Arc
/// impl_consumer_clone!(ArcBiConsumer<i32, i32>);
///
/// // For two type parameters with Rc
/// impl_consumer_clone!(RcBiConsumer<i32, i32>);
/// ```
///
/// # Author
///
/// Haixing Hu
pub use impl_consumer_clone;