mirror of
https://github.com/hexedtech/codemp.git
synced 2024-12-23 05:14:54 +01:00
feat: initial features splitting, added singleton
This commit is contained in:
parent
02b2588073
commit
5cddb27b98
6 changed files with 54 additions and 14 deletions
|
@ -13,7 +13,7 @@ name = "codemp"
|
|||
# core
|
||||
tracing = "0.1"
|
||||
tonic = { version = "0.9", features = ["tls", "tls-roots"] }
|
||||
prost = "0.11.8"
|
||||
prost = { version = "0.11.8", optional = true }
|
||||
md5 = "0.7.0"
|
||||
uuid = { version = "1.3.1", features = ["v4"] }
|
||||
operational-transform = { version = "0.6", features = ["serde"] }
|
||||
|
@ -23,6 +23,12 @@ serde = { version = "1", optional = false }
|
|||
serde_json = { version = "1", optional = false }
|
||||
tracing-subscriber = { version = "0.3", optional = true }
|
||||
similar = { version = "2.2", features = ["inline"] }
|
||||
lazy_static = { version = "1.4", optional = true }
|
||||
|
||||
[build-dependencies]
|
||||
tonic-build = "0.9"
|
||||
|
||||
[features]
|
||||
default = ["proto", "static"]
|
||||
proto = ["dep:prost"]
|
||||
static = ["dep:lazy_static"]
|
||||
|
|
|
@ -14,17 +14,28 @@ pub struct TextChange {
|
|||
}
|
||||
|
||||
#[async_trait]
|
||||
pub trait OperationControllerSubscriber {
|
||||
pub trait OperationControllerSubscriber : OperationFactory {
|
||||
async fn poll(&self) -> Option<TextChange>;
|
||||
async fn apply(&self, op: OperationSeq);
|
||||
}
|
||||
|
||||
#[derive(Clone)]
|
||||
|
||||
pub struct OperationControllerHandle {
|
||||
content: watch::Receiver<String>,
|
||||
operations: mpsc::Sender<OperationSeq>,
|
||||
original: Arc<broadcast::Sender<OperationSeq>>,
|
||||
stream: Arc<Mutex<broadcast::Receiver<OperationSeq>>>,
|
||||
stream: Mutex<broadcast::Receiver<OperationSeq>>,
|
||||
}
|
||||
|
||||
impl Clone for OperationControllerHandle {
|
||||
fn clone(&self) -> Self {
|
||||
OperationControllerHandle {
|
||||
content: self.content.clone(),
|
||||
operations: self.operations.clone(),
|
||||
original: self.original.clone(),
|
||||
stream: Mutex::new(self.original.subscribe()),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[async_trait]
|
||||
|
@ -87,7 +98,7 @@ impl<C : OperationControllerEditor + Send> ControllerWorker<OperationControllerH
|
|||
content: self.receiver.clone(),
|
||||
operations: self.sender.clone(),
|
||||
original: self.stream.clone(),
|
||||
stream: Arc::new(Mutex::new(self.stream.subscribe())),
|
||||
stream: Mutex::new(self.stream.subscribe()),
|
||||
}
|
||||
}
|
||||
|
||||
|
|
1
src/cursor/client.rs
Normal file
1
src/cursor/client.rs
Normal file
|
@ -0,0 +1 @@
|
|||
// TODO separate cursor movement from buffer operations in protocol!
|
20
src/lib.rs
20
src/lib.rs
|
@ -1,20 +1,28 @@
|
|||
pub mod workspace;
|
||||
pub mod cursor;
|
||||
pub mod errors;
|
||||
pub mod buffer;
|
||||
|
||||
pub mod state;
|
||||
|
||||
pub use tonic;
|
||||
pub use tokio;
|
||||
pub use operational_transform as ot;
|
||||
|
||||
use tonic::async_trait;
|
||||
#[cfg(feature = "proto")]
|
||||
pub mod proto {
|
||||
tonic::include_proto!("buffer");
|
||||
}
|
||||
|
||||
#[async_trait] // TODO move this somewhere?
|
||||
pub trait ControllerWorker<T> {
|
||||
pub use errors::CodempError;
|
||||
|
||||
#[tonic::async_trait] // TODO move this somewhere?
|
||||
pub(crate) trait ControllerWorker<T> {
|
||||
fn subscribe(&self) -> T;
|
||||
async fn work(self);
|
||||
}
|
||||
|
||||
pub mod proto {
|
||||
tonic::include_proto!("buffer");
|
||||
#[tonic::async_trait]
|
||||
pub trait Controller<T> {
|
||||
async fn recv(&self) -> Result<T, CodempError>;
|
||||
async fn send(&self, x: T) -> Result<(), CodempError>;
|
||||
}
|
||||
|
|
|
@ -8,6 +8,21 @@ use crate::{
|
|||
cursor::controller::CursorSubscriber, errors::CodempError,
|
||||
};
|
||||
|
||||
#[cfg(feature = "static")]
|
||||
pub mod instance {
|
||||
use tokio::runtime::Runtime;
|
||||
use super::Workspace;
|
||||
|
||||
const CODEMP_DEFAULT_HOST : &str = "http://fantabos.co:50051";
|
||||
|
||||
lazy_static::lazy_static! {
|
||||
static ref RUNTIME : Runtime = Runtime::new().expect("could not create tokio runtime");
|
||||
static ref WORKSPACE : Workspace = RUNTIME.block_on(
|
||||
Workspace::new(&std::env::var("CODEMP_HOST").unwrap_or(CODEMP_DEFAULT_HOST.into()))
|
||||
).expect("could not create codemp workspace");
|
||||
}
|
||||
}
|
||||
|
||||
pub struct Workspace {
|
||||
client: CodempClient,
|
||||
buffers: RwLock<BTreeMap<Box<str>, BufferController>>,
|
||||
|
@ -19,7 +34,7 @@ pub type BufferController = Arc<dyn OperationControllerSubscriber + Send + Sync>
|
|||
|
||||
#[async_trait]
|
||||
pub trait WorkspaceHandle {
|
||||
fn cursor(&self) -> CursorController;
|
||||
async fn cursor(&self) -> CursorController;
|
||||
async fn buffer(&self, path: &str) -> Option<BufferController>;
|
||||
async fn attach(&self, path: &str) -> Result<(), CodempError>;
|
||||
async fn create(&self, path: &str, content: Option<&str>) -> Result<bool, CodempError>;
|
||||
|
@ -42,7 +57,7 @@ impl Workspace {
|
|||
#[async_trait]
|
||||
impl WorkspaceHandle for Workspace {
|
||||
// Cursor
|
||||
fn cursor(&self) -> CursorController {
|
||||
async fn cursor(&self) -> CursorController {
|
||||
self.cursor.clone()
|
||||
}
|
||||
|
|
@ -1 +0,0 @@
|
|||
pub mod controller;
|
Loading…
Reference in a new issue