#![allow(dead_code)]
use colored;
use env_logger;
use log;
use apis;
pub const LOG_LEVEL : log::LevelFilter = log::LevelFilter::Info;
apis::def_session! {
context DisconnectSenderSource {
PROCESSES where
let process = self,
let message_in = message_in
[
process Hangup () {
kind {
apis::process::Kind::Isochronous { tick_ms: 20, ticks_per_update: 1 }
}
sourcepoints [Foochan]
endpoints []
handle_message { unreachable!() }
update {
std::thread::sleep (std::time::Duration::from_millis (1000));
apis::process::ControlFlow::Break
}
}
process Async1 () {
kind { apis::process::Kind::asynchronous_default() }
sourcepoints []
endpoints [Foochan]
handle_message { unreachable!() }
update { apis::process::ControlFlow::Continue }
}
process Async2 () {
kind { apis::process::Kind::asynchronous_default() }
sourcepoints []
endpoints [Foochan]
handle_message { unreachable!() }
update { apis::process::ControlFlow::Continue }
}
]
CHANNELS [
channel Foochan <Foo> (Source) {
producers [Hangup]
consumers [Async1, Async2]
}
]
MESSAGES [
message Foo {
Fooint {
foo : i8
}
}
]
}
}
fn main() {
use std::io::Write;
use colored::Colorize;
use apis::session::Context;
let example_name = std::path::PathBuf::from (std::env::args().next().unwrap())
.file_name().unwrap().to_str().unwrap().to_string();
println!("{}", format!("{example_name} main...")
.green().bold());
env_logger::Builder::new()
.filter_level (LOG_LEVEL)
.parse_default_env()
.init();
apis::report_sizes::<DisconnectSenderSource>();
let session_def = DisconnectSenderSource::def().unwrap();
let mut f = std::fs::File::create (format!("{example_name}.dot")).unwrap();
f.write_all (session_def.dotfile().as_bytes()).unwrap();
drop (f);
let mut session : apis::Session <DisconnectSenderSource> = session_def.into();
let results = session.run();
println!("results: {results:?}");
println!("{}", format!("...{example_name} main")
.green().bold());
}