#[allow(non_snake_case)] pub mod common { tonic::include_proto!("common"); impl From for Identity { fn from(id: uuid::Uuid) -> Self { let (hi, lo) = id.as_u64_pair(); Identity { hi, lo } } } impl From<&uuid::Uuid> for Identity { fn from(id: &uuid::Uuid) -> Self { let (hi, lo) = id.as_u64_pair(); Identity { hi, lo } } } impl From for uuid::Uuid { fn from(value: Identity) -> Self { uuid::Uuid::from_u64_pair(value.hi, value.lo) } } impl From<&Identity> for uuid::Uuid { fn from(value: &Identity) -> Self { uuid::Uuid::from_u64_pair(value.hi, value.lo) } } impl Identity { pub fn uuid(&self) -> uuid::Uuid { uuid::Uuid::from(self) } } } pub mod files { tonic::include_proto!("files"); impl From for BufferNode { fn from(value: String) -> Self { BufferNode { path: value } } } impl From<&str> for BufferNode { fn from(value: &str) -> Self { BufferNode { path: value.to_string(), } } } impl From for String { fn from(value: BufferNode) -> Self { value.path } } } pub mod buffer { tonic::include_proto!("buffer"); } pub mod cursor { tonic::include_proto!("cursor"); impl From for (i32, i32) { fn from(pos: RowCol) -> (i32, i32) { (pos.row, pos.col) } } impl From<(i32, i32)> for RowCol { fn from((row, col): (i32, i32)) -> Self { RowCol { row, col } } } impl PartialOrd for RowCol { fn partial_cmp(&self, other: &Self) -> Option { match self.row.partial_cmp(&other.row) { Some(core::cmp::Ordering::Equal) => {} ord => return ord, } self.col.partial_cmp(&other.col) } } } pub mod workspace { tonic::include_proto!("workspace"); } pub mod session { tonic::include_proto!("session"); } pub mod auth { tonic::include_proto!("auth"); }