#[macro_use]
extern crate lazy_static;
#[macro_use]
extern crate serde_derive;
extern crate serde;
extern crate bincode;
extern crate libc;
extern crate rand;
use std::time::{Duration, SystemTime, UNIX_EPOCH};
use std::sync::{Arc, mpsc::SyncSender, Mutex, MutexGuard};
use std::cell::RefCell;
use std::net::SocketAddr;
use std::fmt::Debug;
use serde::de::DeserializeOwned;
use serde::Serialize;
#[cfg(target_os = "linux")]
pub mod spawn;
pub mod file;
pub trait Reactor: Debug + Clone {
type Peer: std::net::ToSocketAddrs;
type Message: Serialize + DeserializeOwned;
fn receive(
&mut self,
at: SystemTime,
from: Self::Peer,
msg: Self::Message,
) -> Vec<(Self::Peer, Self::Message)>;
fn tick(&mut self, _at: SystemTime) -> Vec<(Self::Peer, Self::Message)> {
vec![]
}
}
thread_local! {
pub static CONTEXT: RefCell<Arc<Context>> = RefCell::new(Arc::new(Context::default()));
}
fn context<'a>() -> Arc<Context> {
CONTEXT.with(|c| {
c.borrow().clone()
})
}
fn set_context(context: Arc<Context>) {
CONTEXT.with(|c| *c.borrow_mut() = context);
}
pub mod context;
use context::Context;
pub enum Call {
Sleep(Duration),
AtomicOp,
RwWriteLock(usize),
RwWriteUnlock(usize),
RwReadLock(usize),
RwReadUnlock(usize),
MutexLock(usize),
MutexUnlock(usize),
SyncFile,
SyncFileMetadata,
SendMsg(SocketAddr, Vec<u8>),
}