mirror of
https://github.com/Astatin3/unshell.git
synced 2026-06-08 22:38:01 -06:00
Add compile-time leaf declarations
Introduce a function-like leaf declaration macro, bind endpoint and TUI hosts to shared generated metadata, and move remote shell endpoint construction out of the leaf module into the examples and runtime assembly code.
This commit is contained in:
@@ -10,12 +10,24 @@ use std::sync::mpsc::RecvTimeoutError;
|
||||
use std::time::Duration;
|
||||
|
||||
use unshell::leaves::remote_shell;
|
||||
use unshell::protocol::tree::Ingress;
|
||||
use unshell::protocol::tree::{Ingress, ProcedureRuntime, ProtocolEndpoint};
|
||||
|
||||
fn main() -> Result<(), Box<dyn Error>> {
|
||||
let mut stream = TcpStream::connect(remote_shell::endpoint::LISTEN_ADDR)?;
|
||||
let frame_rx = remote_shell::endpoint::spawn_frame_reader(stream.try_clone()?);
|
||||
let mut runtime = remote_shell::endpoint::build_agent_runtime();
|
||||
let endpoint = ProtocolEndpoint::new(
|
||||
agent_path(),
|
||||
Some(Vec::new()),
|
||||
Vec::new(),
|
||||
vec![remote_shell::endpoint::RemoteShellEndpoint::protocol_leaf_spec()],
|
||||
);
|
||||
let mut runtime = ProcedureRuntime::<
|
||||
remote_shell::endpoint::RemoteShellEndpoint,
|
||||
remote_shell::endpoint::Open,
|
||||
>::new(
|
||||
endpoint,
|
||||
remote_shell::endpoint::RemoteShellEndpoint::default(),
|
||||
);
|
||||
|
||||
println!(
|
||||
"connected to controller at {}",
|
||||
@@ -39,3 +51,7 @@ fn main() -> Result<(), Box<dyn Error>> {
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
fn agent_path() -> Vec<String> {
|
||||
vec![String::from("agent")]
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user