aboutsummaryrefslogtreecommitdiffstats
path: root/mumlib/src
diff options
context:
space:
mode:
authorEskil Queseth <eskilq@kth.se>2020-10-17 01:19:45 +0200
committerEskil Queseth <eskilq@kth.se>2020-10-17 01:19:45 +0200
commit1974db9d719640f5cd5a8b51fa1b97f801f5a809 (patch)
tree47d1b1a92a836ef0f69e45a543b96c11451ab380 /mumlib/src
parente2f5c15e17d0ddcde88830194410c387793c045f (diff)
downloadmum-1974db9d719640f5cd5a8b51fa1b97f801f5a809.tar.gz
change connecting with channel name instead of id
Diffstat (limited to 'mumlib/src')
-rw-r--r--mumlib/src/command.rs2
-rw-r--r--mumlib/src/error.rs4
-rw-r--r--mumlib/src/state.rs7
3 files changed, 10 insertions, 3 deletions
diff --git a/mumlib/src/command.rs b/mumlib/src/command.rs
index b2ac321..a0673f4 100644
--- a/mumlib/src/command.rs
+++ b/mumlib/src/command.rs
@@ -6,7 +6,7 @@ use std::collections::HashMap;
#[derive(Clone, Debug, Deserialize, Serialize)]
pub enum Command {
ChannelJoin {
- channel_id: u32,
+ channel_identifier: String,
},
ChannelList,
ServerConnect {
diff --git a/mumlib/src/error.rs b/mumlib/src/error.rs
index cb88aa7..3e514fd 100644
--- a/mumlib/src/error.rs
+++ b/mumlib/src/error.rs
@@ -8,7 +8,7 @@ pub type Result<T> = std::result::Result<T, Error>;
pub enum Error {
DisconnectedError,
AlreadyConnectedError,
- InvalidChannelIdError(u32),
+ InvalidChannelIdentifierError(String),
InvalidServerAddrError(String, u16),
}
@@ -17,7 +17,7 @@ impl Display for Error {
match self {
Error::DisconnectedError => write!(f, "Not connected to a server"),
Error::AlreadyConnectedError => write!(f, "Already connected to a server"),
- Error::InvalidChannelIdError(id) => write!(f, "Invalid channel id: {}", id),
+ Error::InvalidChannelIdentifierError(id) => write!(f, "Couldn't find channel {}", id),
Error::InvalidServerAddrError(addr, port) => write!(f, "Invalid server address: {}:{}", addr, port),
}
}
diff --git a/mumlib/src/state.rs b/mumlib/src/state.rs
index f90634e..51fb492 100644
--- a/mumlib/src/state.rs
+++ b/mumlib/src/state.rs
@@ -128,6 +128,13 @@ impl Channel {
pub fn name(&self) -> &str {
&self.name
}
+
+ pub fn path(&self, channels: &HashMap<u32, Channel>) -> String {
+ match &self.parent {
+ Some(t) => format!("{}/{}", channels.get(t).unwrap().path(channels), self.name),
+ None => self.name.clone(),
+ }
+ }
}
#[derive(Clone, Debug, Deserialize, Serialize)]