From 67cdcc2e12118becb823e20a40cc2687f2b8425a Mon Sep 17 00:00:00 2001 From: Adam Carpenter <53hornet@gmail.com> Date: Wed, 27 Mar 2019 15:32:37 -0400 Subject: Started Rust in Action MEAP. --- minigrep/src/lib.rs | 96 ---------------------------------------------------- minigrep/src/main.rs | 17 ---------- 2 files changed, 113 deletions(-) delete mode 100644 minigrep/src/lib.rs delete mode 100644 minigrep/src/main.rs (limited to 'minigrep/src') diff --git a/minigrep/src/lib.rs b/minigrep/src/lib.rs deleted file mode 100644 index bb8b4d7..0000000 --- a/minigrep/src/lib.rs +++ /dev/null @@ -1,96 +0,0 @@ -use std::env; -use std::error::Error; -use std::fs; - -pub struct Config { - pub query: String, - pub filename: String, - pub case_sensitive: bool, -} - -impl Config { - - pub fn new(mut args: std::env::Args) -> Result { - args.next(); - - let query = match args.next() { - Some(arg) => arg, - None => return Err("Didn't get a query string"), - }; - - let filename = match args.next() { - Some(arg) => arg, - None => return Err("Didn't get a filename"), - }; - - let case_sensitive = env::var("CASE_INSENSITIVE").is_err(); - - Ok(Config { query, filename, case_sensitive }) - } - -} - -pub fn run(config: Config) -> Result<(), Box> { - let contents = fs::read_to_string(config.filename)?; - - let results = if config.case_sensitive { - search(&config.query, &contents) - } - else { - search_case_insensitive(&config.query, &contents) - }; - - for line in results { - println!("{}", line); - } - - Ok(()) -} - -fn search<'a>(query: &str, contents: &'a str) -> Vec<&'a str> { - contents.lines() - .filter(|line| line.contains(query)) - .collect() -} - -fn search_case_insensitive<'a>(query: &str, contents: &'a str) -> Vec<&'a str> { - contents.lines() - .filter(|line| line.to_lowercase() - .contains(&query.to_lowercase())) - .collect() -} - -#[cfg(test)] -mod tests { - use super::*; - - #[test] - fn case_sensitive() { - let query = "duct"; - let contents = "\ -Rust: -safe, fast, productive. -Pick three. -Duct tape."; - - assert_eq!( - vec!["safe, fast, productive."], - search(query, contents) - ); - } - - #[test] - fn case_insensitive() { - let query = "rUsT"; - let contents = "\ -Rust: -safe, fast, productive. -Pick three. -Trust me."; - - assert_eq!( - vec!["Rust:", "Trust me."], - search_case_insensitive(query, contents) - ); - } -} diff --git a/minigrep/src/main.rs b/minigrep/src/main.rs deleted file mode 100644 index c752da1..0000000 --- a/minigrep/src/main.rs +++ /dev/null @@ -1,17 +0,0 @@ -use std::process; -use std::env; - -use minigrep; -use minigrep::Config; - -fn main() { - let config = Config::new(env::args()).unwrap_or_else(|err| { - eprintln!("Problem parsing arguments: {}", err); - process::exit(1); - }); - if let Err(e) = minigrep::run(config) { - eprintln!("Application error: {}", e); - process::exit(1); - } -} - -- cgit v1.2.3