aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorTeddy Wing2016-04-23 06:56:00 -0400
committerTeddy Wing2016-04-23 06:56:00 -0400
commit0327cc0b8b509248d61c08e57ee7ef69843db593 (patch)
tree42dc08dc9923f922637c1a57fa71f6b74d86c364 /src
parent0d3e1073e4a3f683b746a5248227c57004ba8cec (diff)
parentf8490d43dfa0ecea0bb4716d93067ec37c6212dc (diff)
downloadmutt-alias-auto-add-0327cc0b8b509248d61c08e57ee7ef69843db593.tar.bz2
Merge branch 'specify-alias-file-on-command-line'
Diffstat (limited to 'src')
-rw-r--r--src/main.rs25
1 files changed, 20 insertions, 5 deletions
diff --git a/src/main.rs b/src/main.rs
index ae7bf17..75e74ac 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -1,3 +1,4 @@
+use std::env;
use std::error::{self, Error};
use std::io::{self, BufRead, BufReader, Write};
use std::fmt;
@@ -65,11 +66,11 @@ impl Alias {
}
}
-fn write_alias(from: String) -> Result<(), AliasSearchError> {
+fn write_alias<P: AsRef<Path>>(from: String, file: P) -> Result<(), AliasSearchError> {
let mut alias = Alias::new(&from);
- let similar_aliases = try!(find_alias_in_file(&alias, "./testaliases"));
+ let similar_aliases = try!(find_alias_in_file(&alias, &file));
alias.update_alias_id(similar_aliases);
- try!(alias.write_to_file("./testaliases"));
+ try!(alias.write_to_file(&file));
Ok(())
}
@@ -133,7 +134,7 @@ impl PartialEq<AliasSearchError> for AliasSearchError {
}
}
-fn find_alias_in_file(alias: &Alias, file: &str) -> Result<Vec<String>, AliasSearchError> {
+fn find_alias_in_file<P: AsRef<Path>>(alias: &Alias, file: P) -> Result<Vec<String>, AliasSearchError> {
let mut matches = Vec::new();
let f = try!(File::open(file));
let file = BufReader::new(&f);
@@ -157,7 +158,21 @@ fn find_alias_in_file(alias: &Alias, file: &str) -> Result<Vec<String>, AliasSea
}
}
+fn print_usage(program: &str) {
+ println!("Usage: {} FILE", program);
+}
+
fn main() {
+ let args: Vec<String> = env::args().collect();
+ let program = args[0].clone();
+
+ let file = if args.len() > 1 {
+ &args[1]
+ } else {
+ print_usage(&program);
+ return;
+ };
+
let stdin = io::stdin();
for line in stdin.lock().lines() {
@@ -167,7 +182,7 @@ fn main() {
println!("{}", line);
if line.starts_with("From: ") {
- match write_alias(line) {
+ match write_alias(line, &file) {
Ok(_) => continue,
Err(e @ AliasSearchError::NotFound) | Err(e @ AliasSearchError::EmailExists) =>
io::stderr().write(e.to_string().as_bytes()).ok(),