1#![cfg_attr(docsrs, feature(doc_cfg))]
2#![cfg_attr(not(stageleft_trybuild), warn(missing_docs))]
3
4stageleft::stageleft_no_entry_crate!();
16
17#[cfg(feature = "runtime_support")]
18#[cfg_attr(docsrs, doc(cfg(feature = "runtime_support")))]
19#[doc(hidden)]
20pub mod runtime_support {
21 pub use ::{bincode, dfir_rs, slotmap, stageleft, tokio};
22 #[cfg(feature = "sim")]
23 pub use colored;
24 #[cfg(feature = "deploy_integration")]
25 pub use hydro_deploy_integration;
26
27 #[cfg(any(feature = "deploy_integration", feature = "docker_runtime"))]
28 pub mod launch;
29}
30
31#[doc(hidden)]
32pub mod macro_support {
33 pub use copy_span;
34}
35
36pub mod prelude {
37 pub use stageleft::q;
49
50 pub use crate::compile::builder::FlowBuilder;
51 pub use crate::live_collections::boundedness::{Bounded, Unbounded};
52 pub use crate::live_collections::keyed_singleton::KeyedSingleton;
53 pub use crate::live_collections::keyed_stream::KeyedStream;
54 pub use crate::live_collections::optional::Optional;
55 pub use crate::live_collections::singleton::Singleton;
56 pub use crate::live_collections::sliced::sliced;
57 pub use crate::live_collections::stream::Stream;
58 pub use crate::location::{Cluster, External, Location as _, Process, Tick};
59 pub use crate::networking::TCP;
60 pub use crate::nondet::{NonDet, nondet};
61 pub use crate::properties::{ManualProof, manual_proof};
62
63 #[macro_export]
65 macro_rules! setup {
66 () => {
67 stageleft::stageleft_no_entry_crate!();
68
69 #[cfg(test)]
70 mod test_init {
71 #[ctor::ctor]
72 fn init() {
73 $crate::compile::init_test();
74 }
75 }
76 };
77 }
78}
79
80#[cfg(feature = "dfir_context")]
81#[cfg_attr(docsrs, doc(cfg(feature = "dfir_context")))]
82pub mod runtime_context;
83
84pub mod nondet;
85
86pub mod live_collections;
87
88pub mod location;
89
90pub mod networking;
91
92pub mod properties;
93
94pub mod telemetry;
95
96#[cfg(any(
97 feature = "deploy",
98 feature = "deploy_integration" ))]
100#[cfg_attr(docsrs, doc(cfg(feature = "deploy")))]
101pub mod deploy;
102
103#[cfg(feature = "sim")]
104#[cfg_attr(docsrs, doc(cfg(feature = "sim")))]
105pub mod sim;
106
107pub mod forward_handle;
108
109pub mod compile;
110
111pub mod singleton_ref;
112
113mod manual_expr;
114
115#[cfg(stageleft_runtime)]
116#[cfg(feature = "viz")]
117#[cfg_attr(docsrs, doc(cfg(feature = "viz")))]
118#[expect(missing_docs, reason = "TODO")]
119pub mod viz;
120
121#[cfg_attr(
122 feature = "stageleft_macro_entrypoint",
123 expect(missing_docs, reason = "staging internals")
124)]
125mod staging_util;
126
127#[cfg(feature = "deploy")]
128#[cfg_attr(docsrs, doc(cfg(feature = "deploy")))]
129pub mod test_util;
130
131#[cfg(feature = "build")]
132#[ctor::ctor]
133fn init_rewrites() {
134 stageleft::add_private_reexport(
135 vec!["tokio_util", "codec", "lines_codec"],
136 vec!["tokio_util", "codec"],
137 );
138}
139
140#[cfg(all(test, feature = "trybuild"))]
141mod test_init {
142 #[ctor::ctor]
143 fn init() {
144 crate::compile::init_test();
145 }
146}
147
148#[doc(hidden)]
161#[macro_export]
162macro_rules! newtype_counter {
163 (
164 $(
165 $( #[$attr:meta] )*
166 $vis:vis struct $name:ident($typ:ty);
167 )*
168 ) => {
169 $(
170 $( #[$attr] )*
171 #[repr(transparent)]
172 #[derive(Clone, Copy, Debug, Default, Eq, Hash, Ord, PartialEq, PartialOrd)]
173 $vis struct $name($typ);
174
175 #[allow(clippy::allow_attributes, dead_code, reason = "macro-generated methods may be unused")]
176 impl $name {
177 pub fn get_and_increment(&mut self) -> Self {
179 let id = self.0;
180 self.0 += 1;
181 Self(id)
182 }
183
184 pub fn range_up_to(&self) -> impl std::iter::DoubleEndedIterator<Item = Self>
188 + std::iter::FusedIterator
189 {
190 (0..self.0).map(Self)
191 }
192
193 pub fn into_inner(self) -> $typ {
195 self.0
196 }
197 }
198
199 impl std::fmt::Display for $name {
200 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
201 write!(f, "{}", self.0)
202 }
203 }
204
205 impl serde::ser::Serialize for $name {
206 fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
207 where
208 S: serde::Serializer
209 {
210 serde::ser::Serialize::serialize(&self.0, serializer)
211 }
212 }
213
214 impl<'de> serde::de::Deserialize<'de> for $name {
215 fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
216 where
217 D: serde::Deserializer<'de>
218 {
219 serde::de::Deserialize::deserialize(deserializer).map(Self)
220 }
221 }
222 )*
223 };
224}