complete chapter 7
Some checks failed
CI / gravity (push) Has been skipped
CI / build (push) Failing after 14s
CI / is_fresh (push) Successful in 49s
CI / formatter (push) Failing after 17s

This commit is contained in:
2025-05-02 14:11:16 +05:30
parent 4fbee2d894
commit b044878fe8
11 changed files with 90 additions and 31 deletions

View File

@@ -5,3 +5,4 @@ edition = "2021"
[dependencies]
ticket_fields = { path = "../../../helpers/ticket_fields" }
thiserror="* "

View File

@@ -1,40 +1,58 @@
// TODO: Convert the implementation to use bounded channels.
use crate::data::{Ticket, TicketDraft};
use crate::store::{TicketId, TicketStore};
use std::sync::mpsc::{Receiver, Sender};
use std::sync::mpsc::{Receiver, Sender, SyncSender};
pub mod data;
pub mod store;
#[derive(Clone)]
pub struct TicketStoreClient {
sender: todo!(),
sender: SyncSender<Command>,
}
#[derive(Debug, thiserror::Error)]
#[error("Server is overloaded")]
pub struct OverLoadedError;
impl TicketStoreClient {
pub fn insert(&self, draft: TicketDraft) -> Result<TicketId, todo!()> {
todo!()
pub fn insert(&self, draft: TicketDraft) -> Result<TicketId, OverLoadedError> {
let (sender, receiver) = std::sync::mpsc::sync_channel(1);
self.sender
.try_send(Command::Insert {
draft,
response_channel: sender,
})
.map_err(|_| OverLoadedError);
Ok(receiver.recv().unwrap())
}
pub fn get(&self, id: TicketId) -> Result<Option<Ticket>, todo!()> {
todo!()
pub fn get(&self, id: TicketId) -> Result<Option<Ticket>, OverLoadedError> {
let (sender, receiver) = std::sync::mpsc::sync_channel(1);
self.sender
.try_send(Command::Get {
id,
response_channel: sender,
})
.map_err(|_| OverLoadedError);
Ok(receiver.recv().unwrap())
}
}
pub fn launch(capacity: usize) -> TicketStoreClient {
todo!();
let (sender, receiver) = std::sync::mpsc::sync_channel(capacity);
std::thread::spawn(move || server(receiver));
todo!()
TicketStoreClient { sender }
}
enum Command {
Insert {
draft: TicketDraft,
response_channel: todo!(),
response_channel: SyncSender<TicketId>,
},
Get {
id: TicketId,
response_channel: todo!(),
response_channel: SyncSender<Option<Ticket>>,
},
}
@@ -47,14 +65,14 @@ pub fn server(receiver: Receiver<Command>) {
response_channel,
}) => {
let id = store.add_ticket(draft);
todo!()
response_channel.send(id);
}
Ok(Command::Get {
id,
response_channel,
}) => {
let ticket = store.get(id);
todo!()
response_channel.send(ticket.cloned());
}
Err(_) => {
// There are no more senders, so we can safely break