aboutsummaryrefslogtreecommitdiffstats
path: root/src/main.rs
diff options
context:
space:
mode:
authorTeddy Wing2016-04-18 16:37:33 -0400
committerTeddy Wing2016-04-18 21:54:25 -0400
commit1f8cbcedc3f298f68750075bfdf7aae065d53e87 (patch)
tree5e10dd440e6be9520ebe650b039cf744ba59604c /src/main.rs
parentad2d9e0e1fa965ef94fcbf6e239729008cc34ba2 (diff)
parentda46c5ac7fe737018750dbd5beda389cd13dd123 (diff)
downloadmutt-alias-auto-add-1f8cbcedc3f298f68750075bfdf7aae065d53e87.tar.bz2
Merge branch 'master' into check-for-alias-in-file
Conflicts: src/tests.rs
Diffstat (limited to 'src/main.rs')
-rw-r--r--src/main.rs46
1 files changed, 46 insertions, 0 deletions
diff --git a/src/main.rs b/src/main.rs
index 1677e5c..e089752 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -5,6 +5,52 @@ use std::path::Path;
#[cfg(test)]
mod tests;
+struct Alias {
+ alias: String,
+ name: String,
+ email: String,
+}
+
+impl Alias {
+ fn new(email: &str) -> Alias {
+ let mut split: Vec<&str> = email.split_whitespace().collect();
+
+ // Remove "From: "
+ split.remove(0);
+
+ let mut alias = String::new();
+ let mut name = String::new();
+ let mut email = String::new();
+
+ if split.len() == 1 {
+ alias = split[0].to_lowercase().to_string();
+ email = split[0].to_string();
+ } else if split.len() == 2 {
+ alias = split[0].to_lowercase().to_string();
+ name = split[0].to_string();
+ email = split[1].to_string();
+ } else if split.len() > 2 {
+ alias = format!("{}-{}", split[split.len() - 2], split[0]).to_lowercase().to_string();
+ name = split[0..(split.len() - 1)].join(" ");
+ email = split[split.len() - 1].to_string();
+ }
+
+ alias = alias.replace(',', "");
+ alias = alias.replace('\'', "");
+ alias = alias.replace('"', "");
+
+ Alias { alias: alias, name: name, email: email }
+ }
+
+ fn to_string(&self) -> String {
+ if self.name.is_empty() {
+ format!("alias {} {}", self.alias, self.email)
+ } else {
+ format!("alias {} {} {}", self.alias, self.name, self.email)
+ }
+ }
+}
+
fn handle_alias(s: &str) {
let alias = build_alias(s);
}