homework: dynamic insert / remove in devices and rooms

This commit is contained in:
3 changed files with 53 additions and 2 deletions

View File

@@ -77,8 +77,8 @@
Доработать хранение объектов: Доработать хранение объектов:
- [x] Заменить массивы устройств и комнат на ассоциативные коллекции из std. В качестве ключей использовать строки. - [x] Заменить массивы устройств и комнат на ассоциативные коллекции из std. В качестве ключей использовать строки.
- [x] Реализовать трейт Debug на всех типах. - [x] Реализовать трейт Debug на всех типах.
- [ ] Добавить возможность динамически добавлять/удалять устройства в комнату. - [x] Добавить возможность динамически добавлять/удалять устройства в комнату.
- [ ] Добавить возможность динамически добавлять/удалять комнату в дом. - [x] Добавить возможность динамически добавлять/удалять комнату в дом.
- [ ] Добавить в тип умного дома метод, позволяющий сразу получить ссылку на умное устройство. Метод принимает имя комнаты - [ ] Добавить в тип умного дома метод, позволяющий сразу получить ссылку на умное устройство. Метод принимает имя комнаты
и имя устройства. В случае, если устройство или комната не найдены, возвращать тип ошибки, сообщающий, что именно и имя устройства. В случае, если устройство или комната не найдены, возвращать тип ошибки, сообщающий, что именно
произошло. Тип ошибки должен реализовывать трейт `std::error::Error`. произошло. Тип ошибки должен реализовывать трейт `std::error::Error`.

View File

@@ -28,6 +28,14 @@ impl House {
self.rooms.get_mut(key) self.rooms.get_mut(key)
} }
pub fn insert_room(&mut self, room: Room) -> Option<Room> {
self.rooms.insert(room.get_name().to_string(), room)
}
pub fn remove_room(&mut self, key: &str) -> Option<Room> {
self.rooms.remove(key)
}
pub fn print_status(&self) { pub fn print_status(&self) {
println!("HOUSE '{}':", self.address); println!("HOUSE '{}':", self.address);
println!("{}", "=".repeat(32)); println!("{}", "=".repeat(32));
@@ -102,4 +110,18 @@ mod tests {
let house = create_test_house(); let house = create_test_house();
assert!(house.get_room("absent").is_none()); assert!(house.get_room("absent").is_none());
} }
#[test]
fn test_add_remove() {
let mut house = create_test_house();
let room = Room::new("empty", Box::new([]));
let result = house.insert_room(room);
assert!(result.is_none());
assert_eq!(house.rooms.len(), 3);
let Some(result) = house.remove_room("bedroom") else { unreachable!() };
assert_eq!(result.get_name(), "bedroom");
assert_eq!(house.rooms.len(), 2);
}
} }

View File

@@ -28,6 +28,14 @@ impl Room {
self.devices.get_mut(key) self.devices.get_mut(key)
} }
pub fn insert_device(&mut self, device: Device) -> Option<Device> {
self.devices.insert(device.get_name().to_string(), device)
}
pub fn remove_device(&mut self, key: &str) -> Option<Device> {
self.devices.remove(key)
}
pub fn print_status(&self) { pub fn print_status(&self) {
println!("ROOM '{}':", self.name); println!("ROOM '{}':", self.name);
println!("{}", "-".repeat(24)); println!("{}", "-".repeat(24));
@@ -76,4 +84,25 @@ mod tests {
); );
assert!(room.get_device("dummy").is_none()); assert!(room.get_device("dummy").is_none());
} }
#[test]
fn test_add_remove() {
let mut room = Room::new(
"test_room",
Box::new([
Device::PowerSocket(PowerSocket::new("PSoc", 12.34, false)),
Device::Thermometer(Thermometer::new("Therm", 21.56)),
]),
);
let result = room.insert_device(Device::Thermometer(Thermometer::new("NewTerm", 20.0)));
assert!(result.is_none());
assert_eq!(room.devices.len(), 3);
let Some(Device::Thermometer(removed)) = room.remove_device("Therm") else {
unreachable!()
};
assert_eq!(removed.get_name(), "Therm");
assert_eq!(removed.get_temperature(), 21.56);
assert_eq!(room.devices.len(), 2);
}
} }