diff --git a/Cargo.lock b/Cargo.lock index 3273b09..d852719 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -157,7 +157,7 @@ dependencies = [ [[package]] name = "gift_circle" -version = "0.8.5" +version = "0.9.0" dependencies = [ "anyhow", "clap", diff --git a/Cargo.toml b/Cargo.toml index 3287460..665e10d 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "gift_circle" -version = "0.8.5" +version = "0.9.0" edition = "2021" authors = ["Chuck King"] diff --git a/src/gift_circle.rs b/src/gift_circle.rs index c591372..b0f3cd7 100644 --- a/src/gift_circle.rs +++ b/src/gift_circle.rs @@ -5,6 +5,7 @@ use counter::Counter; use rand::seq::SliceRandom; use super::group::Group; +use super::people::People; use super::person::Person; fn largest_group(persons: &[Person]) -> Group { @@ -70,20 +71,20 @@ fn is_gift_circle_valid(persons: &[Person]) -> bool { first_and_last_groups_are_different(persons) && has_no_consecutive_group_numbers(persons) } -fn move_person(from_persons: &mut Vec, to_persons: &mut Vec, person: &Person) { +fn move_person(from_persons: &mut People, to_persons: &mut People, person: &Person) { from_persons.retain(|p| p != person); to_persons.push(person.clone()); } -fn generate_path(from_persons: &[Person]) -> Vec { +fn generate_path(from_persons: &[Person]) -> People { // Go through the list of available participants and generate a gift path // where noone gives a gift to anyone in their same group. // Preserve the from_persons vec for follow on attempts by working with a cloned vec - let mut available_persons: Vec = from_persons.to_owned(); + let mut available_persons: People = from_persons.to_owned(); // Build up the path by adding persons with different group numbers - let mut persons_path: Vec = vec![]; + let mut persons_path: People = vec![]; let mut previous_group: u16 = 0; @@ -93,22 +94,21 @@ fn generate_path(from_persons: &[Person]) -> Vec { let largest_np_group = largest_non_prev_group(&available_persons, previous_group); - let candidates: Vec = - if (largest_np_group.size as usize * 2) > available_persons.len() { - // Build candidates list from the remaining persons in the largest group that is not the previous group - available_persons - .iter() - .filter(|&p| p.group_number.unwrap() == largest_np_group.number) - .cloned() - .collect::>() - } else { - // Build the candidates list from all remaining persons not in the previous group - available_persons - .iter() - .filter(|&p| p.group_number.unwrap() != previous_group) - .cloned() - .collect::>() - }; + let candidates: People = if (largest_np_group.size as usize * 2) > available_persons.len() { + // Build candidates list from the remaining persons in the largest group that is not the previous group + available_persons + .iter() + .filter(|&p| p.group_number.unwrap() == largest_np_group.number) + .cloned() + .collect::() + } else { + // Build the candidates list from all remaining persons not in the previous group + available_persons + .iter() + .filter(|&p| p.group_number.unwrap() != previous_group) + .cloned() + .collect::() + }; // Randomly select one person from the candidates list let choice = candidates.choose(&mut rand::thread_rng()).unwrap(); @@ -122,14 +122,14 @@ fn generate_path(from_persons: &[Person]) -> Vec { persons_path } -fn generate_no_group_path(from_persons: &[Person]) -> Vec { +fn generate_no_group_path(from_persons: &[Person]) -> People { // Go through the list of available participants and generate a gift path. // Preserve the from_persons vec for follow on attempts by working with a cloned vec - let mut available_persons: Vec = from_persons.to_owned(); + let mut available_persons: People = from_persons.to_owned(); // Build up the path by adding random persons - let mut persons_path: Vec = vec![]; + let mut persons_path: People = vec![]; while !available_persons.is_empty() { // Randomly select one person @@ -145,7 +145,7 @@ fn generate_no_group_path(from_persons: &[Person]) -> Vec { persons_path } -pub fn get_gift_circle(from_persons: Vec, use_groups: bool) -> Result> { +pub fn get_gift_circle(from_persons: People, use_groups: bool) -> Result { if from_persons.len() <= 2 { return Err(anyhow!( "You must submit at least three people in order to form a gift circle." @@ -170,7 +170,7 @@ pub fn get_gift_circle(from_persons: Vec, use_groups: bool) -> Result = vec![]; + let mut gift_circle: People = vec![]; while !have_valid_circle && attempt_count < MAX_ATTEMPTS { if use_groups { @@ -328,7 +328,7 @@ mod tests { let person1 = Person::new("Father", 1); let person_to_move = person1.clone(); let mut move_from = vec![person1]; - let mut move_to: Vec = vec![]; + let mut move_to = vec![]; move_person(&mut move_from, &mut move_to, &person_to_move); assert_eq!(move_from.len(), 0); assert_eq!(move_to.len(), 1); diff --git a/src/main.rs b/src/main.rs index 1a0b22e..90d5af2 100644 --- a/src/main.rs +++ b/src/main.rs @@ -1,6 +1,7 @@ mod gift_circle; mod group; mod myargs; +mod people; mod person; use std::io; @@ -10,6 +11,7 @@ use anyhow::{anyhow, Context, Result}; use gift_circle::get_gift_circle; use myargs::get_args; +use people::People; use person::{Person, PersonWithoutGroup}; fn run() -> Result<()> { @@ -18,7 +20,7 @@ fn run() -> Result<()> { let mut rdr = csv::Reader::from_path(args.input.clone()) .with_context(|| format!("Failed to read input from {}", &args.input))?; - let mut participants: Vec = vec![]; + let mut participants: People = vec![]; for result in rdr.deserialize() { let person: Person = result?; @@ -26,7 +28,7 @@ fn run() -> Result<()> { } #[allow(unused_assignments)] - let mut gift_circle: Vec = vec![]; + let mut gift_circle: People = vec![]; if args.use_groups { if participants.iter().any(|p| p.group_number.is_none()) { diff --git a/src/people.rs b/src/people.rs new file mode 100644 index 0000000..c39e537 --- /dev/null +++ b/src/people.rs @@ -0,0 +1,4 @@ +use crate::Person; + +#[allow(dead_code)] +pub type People = Vec;