diff options
| author | Arne Dußin | 2021-02-03 10:51:08 +0100 |
|---|---|---|
| committer | Arne Dußin | 2021-02-03 10:51:08 +0100 |
| commit | d4c1c7ecb5688ef64f45425d9ac8e7ddeb8e8602 (patch) | |
| tree | 6788d2efc22373d735947ba46d3a3ea3b3b3733c /src/client/cli/cmd/edit.rs | |
| parent | f92e9f6f07b1e3834c2ca58ce3510734819d08e4 (diff) | |
| download | graf_karto-d4c1c7ecb5688ef64f45425d9ac8e7ddeb8e8602.tar.gz graf_karto-d4c1c7ecb5688ef64f45425d9ac8e7ddeb8e8602.zip | |
Fix commands
Commands now operate on the local file system, but on the remote world
Diffstat (limited to 'src/client/cli/cmd/edit.rs')
| -rw-r--r-- | src/client/cli/cmd/edit.rs | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/src/client/cli/cmd/edit.rs b/src/client/cli/cmd/edit.rs index 7a02959..1cfb530 100644 --- a/src/client/cli/cmd/edit.rs +++ b/src/client/cli/cmd/edit.rs @@ -2,8 +2,9 @@ use super::Command; use super::{CmdParseError, FromArgs}; -use crate::client::map::MapData; use crate::client::Editor; +use crate::net::Cargo; +use crate::world::World; use std::path::PathBuf; /// Command to load a file from the disk and replace the current editor contents with it's info. @@ -25,8 +26,8 @@ impl FromArgs for Edit { impl Command for Edit { fn process(&self, editor: &mut Editor) -> Result<String, String> { - let data = match MapData::load_from_file(&self.file) { - Ok(data) => data, + let world = match World::load_from_file(&self.file) { + Ok(world) => world, Err(err) => { return Err(format!( "Unable to read file: {:?}, reason: {:?}", @@ -35,7 +36,18 @@ impl Command for Edit { } }; - editor.map_mut().set_data(data); + // Clear all data from the world, afterwards add all components from the file. + editor.server().send(Cargo::ClearAll); + for (_, icon) in world.icons().iter() { + editor.server().send(Cargo::AddIcon(icon.clone())); + } + for (_, room) in world.rooms().iter() { + editor.server().send(Cargo::AddRoom(room.clone())); + } + for (_, wall) in world.walls().iter() { + editor.server().send(Cargo::AddWall(wall.clone())); + } + Ok(format!("Map data from {:?} loaded.", &self.file)) } } |
