refactor(client): use new messenger
This commit is contained in:
@@ -32,7 +32,7 @@ prisma = "0.1.1"
|
|||||||
slog = "2.7.0"
|
slog = "2.7.0"
|
||||||
slog-stdlog = "4.1.1"
|
slog-stdlog = "4.1.1"
|
||||||
xkbcommon = { version = "0.5.0", default-features = false }
|
xkbcommon = { version = "0.5.0", default-features = false }
|
||||||
stardust-xr = "0.5.2"
|
stardust-xr = "0.7.1"
|
||||||
directories = "4.0.1"
|
directories = "4.0.1"
|
||||||
serde = { version = "1.0.145", features = ["derive"] }
|
serde = { version = "1.0.145", features = ["derive"] }
|
||||||
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ use anyhow::{anyhow, Result};
|
|||||||
use lazy_static::lazy_static;
|
use lazy_static::lazy_static;
|
||||||
use once_cell::sync::OnceCell;
|
use once_cell::sync::OnceCell;
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
use stardust_xr::messenger::Messenger;
|
use stardust_xr::messenger::{self, MessageSenderHandle};
|
||||||
use std::{
|
use std::{
|
||||||
path::PathBuf,
|
path::PathBuf,
|
||||||
sync::{Arc, Weak},
|
sync::{Arc, Weak},
|
||||||
@@ -23,7 +23,7 @@ lazy_static! {
|
|||||||
stop_notifier: Default::default(),
|
stop_notifier: Default::default(),
|
||||||
join_handle: OnceCell::new(),
|
join_handle: OnceCell::new(),
|
||||||
|
|
||||||
messenger: None,
|
message_sender_handle: None,
|
||||||
scenegraph: Default::default(),
|
scenegraph: Default::default(),
|
||||||
root: OnceCell::new(),
|
root: OnceCell::new(),
|
||||||
base_resource_prefixes: Default::default(),
|
base_resource_prefixes: Default::default(),
|
||||||
@@ -36,8 +36,8 @@ pub struct Client {
|
|||||||
stop_notifier: Arc<Notify>,
|
stop_notifier: Arc<Notify>,
|
||||||
join_handle: OnceCell<JoinHandle<Result<()>>>,
|
join_handle: OnceCell<JoinHandle<Result<()>>>,
|
||||||
|
|
||||||
pub messenger: Option<Messenger>,
|
pub message_sender_handle: Option<MessageSenderHandle>,
|
||||||
pub scenegraph: Scenegraph,
|
pub scenegraph: Arc<Scenegraph>,
|
||||||
pub root: OnceCell<Arc<Root>>,
|
pub root: OnceCell<Arc<Root>>,
|
||||||
pub base_resource_prefixes: Mutex<Vec<PathBuf>>,
|
pub base_resource_prefixes: Mutex<Vec<PathBuf>>,
|
||||||
}
|
}
|
||||||
@@ -48,17 +48,18 @@ impl Client {
|
|||||||
connection: UnixStream,
|
connection: UnixStream,
|
||||||
) -> Arc<Self> {
|
) -> Arc<Self> {
|
||||||
println!("New client connected");
|
println!("New client connected");
|
||||||
|
|
||||||
|
let (mut messenger_tx, mut messenger_rx) = messenger::create(connection);
|
||||||
|
let scenegraph = Arc::new(Scenegraph::default());
|
||||||
|
|
||||||
let client = CLIENTS.add(Client {
|
let client = CLIENTS.add(Client {
|
||||||
event_loop: Arc::downgrade(event_loop),
|
event_loop: Arc::downgrade(event_loop),
|
||||||
index,
|
index,
|
||||||
stop_notifier: Default::default(),
|
stop_notifier: Default::default(),
|
||||||
join_handle: OnceCell::new(),
|
join_handle: OnceCell::new(),
|
||||||
|
|
||||||
messenger: Some(Messenger::new(
|
message_sender_handle: Some(messenger_tx.handle()),
|
||||||
tokio::runtime::Handle::current(),
|
scenegraph: scenegraph.clone(),
|
||||||
connection,
|
|
||||||
)),
|
|
||||||
scenegraph: Default::default(),
|
|
||||||
root: OnceCell::new(),
|
root: OnceCell::new(),
|
||||||
base_resource_prefixes: Default::default(),
|
base_resource_prefixes: Default::default(),
|
||||||
});
|
});
|
||||||
@@ -76,14 +77,14 @@ impl Client {
|
|||||||
let _ = client.join_handle.set(tokio::spawn({
|
let _ = client.join_handle.set(tokio::spawn({
|
||||||
let client = client.clone();
|
let client = client.clone();
|
||||||
async move {
|
async move {
|
||||||
let dispatch_loop = async {
|
let dispatch_loop = async move {
|
||||||
loop {
|
loop {
|
||||||
client.dispatch().await?
|
messenger_rx.dispatch(&*scenegraph).await?
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
let flush_loop = async {
|
let flush_loop = async {
|
||||||
loop {
|
loop {
|
||||||
client.flush().await?
|
messenger_tx.flush().await?
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -106,20 +107,6 @@ impl Client {
|
|||||||
.ok_or_else(|| anyhow!("{} not found", name))
|
.ok_or_else(|| anyhow!("{} not found", name))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn dispatch(&self) -> Result<(), std::io::Error> {
|
|
||||||
match &self.messenger {
|
|
||||||
Some(messenger) => messenger.dispatch(&self.scenegraph).await,
|
|
||||||
None => Err(std::io::Error::from(std::io::ErrorKind::Unsupported)),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn flush(&self) -> Result<(), std::io::Error> {
|
|
||||||
match &self.messenger {
|
|
||||||
Some(messenger) => messenger.flush().await,
|
|
||||||
None => Err(std::io::Error::from(std::io::ErrorKind::Unsupported)),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn disconnect(&self) {
|
pub async fn disconnect(&self) {
|
||||||
self.stop_notifier.notify_one();
|
self.stop_notifier.notify_one();
|
||||||
if let Some(event_loop) = self.event_loop.upgrade() {
|
if let Some(event_loop) = self.event_loop.upgrade() {
|
||||||
|
|||||||
@@ -226,19 +226,19 @@ impl Node {
|
|||||||
let method = method.to_string();
|
let method = method.to_string();
|
||||||
let data = data.to_vec();
|
let data = data.to_vec();
|
||||||
if let Some(client) = self.get_client() {
|
if let Some(client) = self.get_client() {
|
||||||
if let Some(messenger) = client.messenger.as_ref() {
|
if let Some(message_sender_handle) = client.message_sender_handle.as_ref() {
|
||||||
messenger.send_remote_signal(path.as_str(), method.as_str(), data.as_slice());
|
message_sender_handle.signal(path.as_str(), method.as_str(), data.as_slice())?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
pub async fn execute_remote_method(&self, method: &str, data: Vec<u8>) -> Result<Vec<u8>> {
|
pub async fn execute_remote_method(&self, method: &str, data: Vec<u8>) -> Result<Vec<u8>> {
|
||||||
if let Some(client) = self.get_client() {
|
if let Some(client) = self.get_client() {
|
||||||
match client.messenger.as_ref() {
|
match client.message_sender_handle.as_ref() {
|
||||||
None => Err(anyhow!("Messenger does not exist for this node's client")),
|
None => Err(anyhow!("Messenger does not exist for this node's client")),
|
||||||
Some(messenger) => {
|
Some(message_sender_handle) => {
|
||||||
messenger
|
message_sender_handle
|
||||||
.execute_remote_method(self.path.as_str(), method, &data)
|
.method(self.path.as_str(), method, &data)?
|
||||||
.await
|
.await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user