completed 06 ticket management
Some checks failed
CI / build (push) Failing after 1m16s
CI / gravity (push) Has been skipped
CI / is_fresh (push) Successful in 26s
CI / formatter (push) Failing after 17s

This commit is contained in:
2025-04-07 12:12:47 +05:30
parent 199b57aad8
commit 9bc063a05b
5 changed files with 65 additions and 13 deletions

View File

@@ -11,6 +11,7 @@ use ticket_fields::{TicketDescription, TicketTitle};
#[derive(Clone)] #[derive(Clone)]
pub struct TicketStore { pub struct TicketStore {
tickets: Vec<Ticket>, tickets: Vec<Ticket>,
total: usize,
} }
#[derive(Clone, Copy, Debug, PartialEq)] #[derive(Clone, Copy, Debug, PartialEq)]
@@ -41,11 +42,25 @@ impl TicketStore {
pub fn new() -> Self { pub fn new() -> Self {
Self { Self {
tickets: Vec::new(), tickets: Vec::new(),
total: 0,
} }
} }
pub fn add_ticket(&mut self, ticket: Ticket) { pub fn add_ticket(&mut self, ticket: TicketDraft) -> TicketId {
self.tickets.push(ticket); let newID = TicketId(self.total as u64 + 1);
let tick: Ticket = Ticket {
title: ticket.title,
description: ticket.description,
status: Status::ToDo,
id: newID,
};
self.tickets.push(tick);
self.total += 1;
return newID;
}
pub fn get(&self, id: TicketId) -> Option<&Ticket> {
return Some(&self.tickets[(id.0 - 1) as usize]);
} }
} }

View File

@@ -1,5 +1,7 @@
// TODO: Implement `Index<&TicketId>` and `Index<TicketId>` for `TicketStore`. // TODO: Implement `Index<&TicketId>` and `Index<TicketId>` for `TicketStore`.
use std::ops::Index;
use ticket_fields::{TicketDescription, TicketTitle}; use ticket_fields::{TicketDescription, TicketTitle};
#[derive(Clone)] #[derive(Clone)]
@@ -58,6 +60,20 @@ impl TicketStore {
} }
} }
impl Index<TicketId> for TicketStore {
type Output = Ticket;
fn index(&self, index: TicketId) -> &Self::Output {
return &self.tickets[index.0 as usize];
}
}
impl Index<&TicketId> for TicketStore {
type Output = Ticket;
fn index(&self, index: &TicketId) -> &Self::Output {
return &self.tickets[index.0 as usize];
}
}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use crate::{Status, TicketDraft, TicketStore}; use crate::{Status, TicketDraft, TicketStore};

View File

@@ -1,6 +1,6 @@
// TODO: Implement `IndexMut<&TicketId>` and `IndexMut<TicketId>` for `TicketStore`. // TODO: Implement `IndexMut<&TicketId>` and `IndexMut<TicketId>` for `TicketStore`.
use std::ops::Index; use std::ops::{Index, IndexMut};
use ticket_fields::{TicketDescription, TicketTitle}; use ticket_fields::{TicketDescription, TicketTitle};
#[derive(Clone)] #[derive(Clone)]
@@ -75,6 +75,18 @@ impl Index<&TicketId> for TicketStore {
} }
} }
impl IndexMut<TicketId> for TicketStore {
fn index_mut(&mut self, index: TicketId) -> &mut Self::Output {
self.tickets.iter_mut().find(|a| a.id == index).unwrap()
}
}
impl IndexMut<&TicketId> for TicketStore {
fn index_mut(&mut self, index: &TicketId) -> &mut Self::Output {
self.tickets.iter_mut().find(|a| a.id == *index).unwrap()
}
}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use crate::{Status, TicketDraft, TicketStore}; use crate::{Status, TicketDraft, TicketStore};

View File

@@ -11,7 +11,7 @@ pub struct TicketStore {
counter: u64, counter: u64,
} }
#[derive(Clone, Copy, Debug, PartialEq)] #[derive(Clone, Copy, Debug, PartialEq, Eq, Hash)]
pub struct TicketId(u64); pub struct TicketId(u64);
#[derive(Clone, Debug, PartialEq)] #[derive(Clone, Debug, PartialEq)]
@@ -38,7 +38,7 @@ pub enum Status {
impl TicketStore { impl TicketStore {
pub fn new() -> Self { pub fn new() -> Self {
Self { Self {
tickets: todo!(), tickets: HashMap::new(),
counter: 0, counter: 0,
} }
} }
@@ -52,16 +52,16 @@ impl TicketStore {
description: ticket.description, description: ticket.description,
status: Status::ToDo, status: Status::ToDo,
}; };
todo!(); self.tickets.insert(id, ticket);
id id
} }
pub fn get(&self, id: TicketId) -> Option<&Ticket> { pub fn get(&self, id: TicketId) -> Option<&Ticket> {
todo!() self.tickets.get(&id)
} }
pub fn get_mut(&mut self, id: TicketId) -> Option<&mut Ticket> { pub fn get_mut(&mut self, id: TicketId) -> Option<&mut Ticket> {
todo!() self.tickets.get_mut(&id)
} }
} }

View File

@@ -13,7 +13,16 @@ pub struct TicketStore {
counter: u64, counter: u64,
} }
#[derive(Clone, Copy, Debug, PartialEq)] impl<'a> IntoIterator for &'a TicketStore {
type Item = &'a Ticket;
type IntoIter = std::collections::btree_map::Values<'a, TicketId, Ticket>;
fn into_iter(self) -> Self::IntoIter {
self.tickets.values()
}
}
#[derive(Clone, Copy, Debug, PartialEq, Eq, Ord, PartialOrd)]
pub struct TicketId(u64); pub struct TicketId(u64);
#[derive(Clone, Debug, PartialEq)] #[derive(Clone, Debug, PartialEq)]
@@ -40,7 +49,7 @@ pub enum Status {
impl TicketStore { impl TicketStore {
pub fn new() -> Self { pub fn new() -> Self {
Self { Self {
tickets: todo!(), tickets: BTreeMap::new(),
counter: 0, counter: 0,
} }
} }
@@ -54,16 +63,16 @@ impl TicketStore {
description: ticket.description, description: ticket.description,
status: Status::ToDo, status: Status::ToDo,
}; };
todo!(); self.tickets.insert(id, ticket);
id id
} }
pub fn get(&self, id: TicketId) -> Option<&Ticket> { pub fn get(&self, id: TicketId) -> Option<&Ticket> {
todo!() self.tickets.get(&id)
} }
pub fn get_mut(&mut self, id: TicketId) -> Option<&mut Ticket> { pub fn get_mut(&mut self, id: TicketId) -> Option<&mut Ticket> {
todo!() self.tickets.get_mut(&id)
} }
} }