nio: Make the callback futures Sync/Send.
This commit is contained in:
parent
71d8500453
commit
066d76cc8e
3 changed files with 26 additions and 28 deletions
|
@ -3,8 +3,8 @@
|
|||
use std::{env, process::exit};
|
||||
use std::pin::Pin;
|
||||
use std::future::Future;
|
||||
use std::sync::{Arc, Mutex};
|
||||
use std::rc::Rc;
|
||||
use std::cell::RefCell;
|
||||
|
||||
use matrix_nio::{
|
||||
self,
|
||||
|
@ -16,8 +16,8 @@ use matrix_nio::{
|
|||
AsyncClient, AsyncClientConfig, SyncSettings, Room
|
||||
};
|
||||
|
||||
async fn async_helper(room: Rc<RefCell<Room>>, event: Rc<RoomEvent>) {
|
||||
let room = room.borrow();
|
||||
async fn async_helper(room: Arc<Mutex<Room>>, event: Arc<RoomEvent>) {
|
||||
let room = room.lock().unwrap();
|
||||
if let RoomEvent::RoomMessage(MessageEvent {
|
||||
content: MessageEventContent::Text(TextMessageEventContent { body: msg_body, .. }),
|
||||
sender,
|
||||
|
@ -27,10 +27,9 @@ async fn async_helper(room: Rc<RefCell<Room>>, event: Rc<RoomEvent>) {
|
|||
let user = room.members.get(&sender.to_string()).unwrap();
|
||||
println!("{}: {}", user.display_name.as_ref().unwrap_or(&sender.to_string()), msg_body);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
fn async_callback(room: Rc<RefCell<Room>>, event: Rc<RoomEvent>) -> Pin<Box<dyn Future<Output = ()>>> {
|
||||
fn async_callback(room: Arc<Mutex<Room>>, event: Arc<RoomEvent>) -> Pin<Box<dyn Future<Output = ()> + Send + Sync >> {
|
||||
Box::pin(async_helper(room, event))
|
||||
}
|
||||
|
||||
|
|
|
@ -2,7 +2,7 @@ use std::convert::{TryFrom, TryInto};
|
|||
use std::future::Future;
|
||||
use std::pin::Pin;
|
||||
use std::rc::Rc;
|
||||
use std::cell::RefCell;
|
||||
use std::sync::{Arc, Mutex};
|
||||
|
||||
use http::Method as HttpMethod;
|
||||
use http::Response as HttpResponse;
|
||||
|
@ -22,7 +22,7 @@ use crate::error::{Error, InnerError};
|
|||
use crate::session::Session;
|
||||
|
||||
type RoomEventCallback = Box::<dyn FnMut(&Room, &RoomEvent)>;
|
||||
type RoomEventCallbackF = Box::<dyn FnMut(Rc<RefCell<Room>>, Rc<RoomEvent>) -> Pin<Box<dyn Future<Output = ()>>>>;
|
||||
type RoomEventCallbackF = Box::<dyn FnMut(Arc<Mutex<Room>>, Arc<RoomEvent>) -> Pin<Box<dyn Future<Output = ()> + Send + Sync>> + Send + Sync>;
|
||||
|
||||
pub struct AsyncClient {
|
||||
/// The URL of the homeserver to connect to.
|
||||
|
@ -31,8 +31,8 @@ pub struct AsyncClient {
|
|||
http_client: reqwest::Client,
|
||||
/// User session data.
|
||||
base_client: BaseClient,
|
||||
/// Event callbacks
|
||||
event_callbacks: Vec<RoomEventCallback>,
|
||||
// /// Event callbacks
|
||||
// event_callbacks: Vec<RoomEventCallback>,
|
||||
/// Event futures
|
||||
event_futures: Vec<RoomEventCallbackF>,
|
||||
}
|
||||
|
@ -166,18 +166,18 @@ impl AsyncClient {
|
|||
homeserver,
|
||||
http_client,
|
||||
base_client: BaseClient::new(session),
|
||||
event_callbacks: Vec::new(),
|
||||
// event_callbacks: Vec::new(),
|
||||
event_futures: Vec::new(),
|
||||
})
|
||||
}
|
||||
|
||||
pub fn add_event_callback(
|
||||
&mut self,
|
||||
event_type: EventType,
|
||||
callback: RoomEventCallback,
|
||||
) {
|
||||
self.event_callbacks.push(callback);
|
||||
}
|
||||
// pub fn add_event_callback(
|
||||
// &mut self,
|
||||
// event_type: EventType,
|
||||
// callback: RoomEventCallback,
|
||||
// ) {
|
||||
// self.event_callbacks.push(callback);
|
||||
// }
|
||||
|
||||
pub fn add_event_future(
|
||||
&mut self,
|
||||
|
@ -245,12 +245,12 @@ impl AsyncClient {
|
|||
|
||||
let room = self.base_client.joined_rooms.get(&room_id).unwrap();
|
||||
|
||||
for mut cb in &mut self.event_callbacks {
|
||||
cb(&room.borrow(), &event);
|
||||
}
|
||||
// for mut cb in &mut self.event_callbacks {
|
||||
// cb(&room.lock().unwrap(), &event);
|
||||
// }
|
||||
|
||||
for mut cb in &mut self.event_futures {
|
||||
cb(room.clone(), Rc::new(event.clone())).await;
|
||||
cb(room.clone(), Arc::new(event.clone())).await;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -4,8 +4,7 @@ use crate::api::r0 as api;
|
|||
use crate::events::collections::all::{RoomEvent, StateEvent};
|
||||
use crate::events::room::member::{MemberEvent, MembershipState};
|
||||
use crate::session::Session;
|
||||
use std::rc::Rc;
|
||||
use std::cell::RefCell;
|
||||
use std::sync::{Arc, Mutex};
|
||||
|
||||
pub type Token = String;
|
||||
pub type RoomId = String;
|
||||
|
@ -150,7 +149,7 @@ pub struct Client {
|
|||
/// The current sync token that should be used for the next sync call.
|
||||
pub sync_token: Option<Token>,
|
||||
/// A map of the rooms our user is joined in.
|
||||
pub joined_rooms: HashMap<RoomId, Rc<RefCell<Room>>>,
|
||||
pub joined_rooms: HashMap<RoomId, Arc<Mutex<Room>>>,
|
||||
}
|
||||
|
||||
impl Client {
|
||||
|
@ -186,11 +185,11 @@ impl Client {
|
|||
self.session = Some(session);
|
||||
}
|
||||
|
||||
fn get_or_create_room(&mut self, room_id: &RoomId) -> &mut Rc<RefCell<Room>> {
|
||||
fn get_or_create_room(&mut self, room_id: &RoomId) -> &mut Arc<Mutex<Room>> {
|
||||
self.joined_rooms
|
||||
.entry(room_id.to_string())
|
||||
.or_insert(
|
||||
Rc::new(RefCell::new(Room::new(
|
||||
Arc::new(Mutex::new(Room::new(
|
||||
room_id,
|
||||
&self
|
||||
.session
|
||||
|
@ -210,7 +209,7 @@ impl Client {
|
|||
/// Returns true if the membership list of the room changed, false
|
||||
/// otherwise.
|
||||
pub fn receive_joined_timeline_event(&mut self, room_id: &RoomId, event: &RoomEvent) -> bool {
|
||||
let mut room = self.get_or_create_room(room_id).borrow_mut();
|
||||
let mut room = self.get_or_create_room(room_id).lock().unwrap();
|
||||
room.receive_timeline_event(event)
|
||||
}
|
||||
|
||||
|
@ -223,7 +222,7 @@ impl Client {
|
|||
/// Returns true if the membership list of the room changed, false
|
||||
/// otherwise.
|
||||
pub fn receive_joined_state_event(&mut self, room_id: &RoomId, event: &StateEvent) -> bool {
|
||||
let mut room = self.get_or_create_room(room_id).borrow_mut();
|
||||
let mut room = self.get_or_create_room(room_id).lock().unwrap();
|
||||
room.receive_state_event(event)
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue