hydro_lang/compile/
embedded_runtime.rs1use futures::Stream;
7use stageleft::{QuotedWithContext, RuntimeData, q};
8
9use crate::location::MembershipEvent;
10use crate::location::member_id::TaglessMemberId;
11
12pub fn embedded_cluster_self_id<'a>() -> impl QuotedWithContext<'a, TaglessMemberId, ()> + Clone + 'a
14{
15 let self_id: RuntimeData<&TaglessMemberId> = RuntimeData::new("__cluster_self_id");
16 q!(self_id.clone())
17}
18
19pub fn embedded_cluster_membership_stream<'a>(
21 idx: usize,
22) -> impl QuotedWithContext<'a, Box<dyn Stream<Item = (TaglessMemberId, MembershipEvent)> + Unpin>, ()>
23{
24 let var_name: &'static str = Box::leak(format!("__membership_{}", idx).into_boxed_str());
27 let membership: RuntimeData<
28 Box<dyn Stream<Item = (TaglessMemberId, MembershipEvent)> + Unpin>,
29 > = RuntimeData::new(var_name);
30 q!(membership)
31}