2020-05-19 19:47:44 +03:00
|
|
|
// quiz2.rs
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
2020-05-19 19:47:44 +03:00
|
|
|
// This is a quiz for the following sections:
|
2019-11-11 15:46:42 +03:00
|
|
|
// - Strings
|
2022-07-14 14:16:32 +03:00
|
|
|
// - Vecs
|
|
|
|
// - Move semantics
|
|
|
|
// - Modules
|
|
|
|
// - Enums
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
|
|
|
// Let's build a little machine in the form of a function. As input, we're going
|
|
|
|
// to give a list of strings and commands. These commands determine what action
|
|
|
|
// is going to be applied to the string. It can either be:
|
2022-07-14 14:16:32 +03:00
|
|
|
// - Uppercase the string
|
|
|
|
// - Trim the string
|
|
|
|
// - Append "bar" to the string a specified amount of times
|
|
|
|
// The exact form of this will be:
|
|
|
|
// - The input is going to be a Vector of a 2-length tuple,
|
|
|
|
// the first element is the string, the second one is the command.
|
|
|
|
// - The output element is going to be a Vector of strings.
|
2023-05-29 20:39:08 +03:00
|
|
|
//
|
2022-09-12 16:53:59 +03:00
|
|
|
// No hints this time!
|
2015-09-21 01:31:41 +03:00
|
|
|
|
2022-07-14 14:16:32 +03:00
|
|
|
pub enum Command {
|
|
|
|
Uppercase,
|
|
|
|
Trim,
|
|
|
|
Append(usize),
|
2019-11-11 15:46:42 +03:00
|
|
|
}
|
2022-07-14 14:16:32 +03:00
|
|
|
|
|
|
|
mod my_module {
|
|
|
|
use super::Command;
|
|
|
|
|
|
|
|
// TODO: Complete the function signature!
|
2024-02-01 23:40:18 +03:00
|
|
|
pub fn transformer(input: Vec<(String, Command)>) -> Vec<String> {
|
2022-07-14 14:16:32 +03:00
|
|
|
// TODO: Complete the output declaration!
|
2024-02-01 23:40:18 +03:00
|
|
|
let mut output: Vec<String> = vec![];
|
2022-07-14 14:16:32 +03:00
|
|
|
for (string, command) in input.iter() {
|
|
|
|
// TODO: Complete the function body. You can do it!
|
2024-02-01 23:40:18 +03:00
|
|
|
match command {
|
|
|
|
Command::Uppercase => output.push(string.to_uppercase()),
|
|
|
|
Command::Trim => output.push(string.trim().to_string()),
|
|
|
|
Command::Append(count) => {
|
|
|
|
let mut new_string = string.clone();
|
|
|
|
// The star in front of count dereferences the value of count.
|
|
|
|
// This is necessary because the append method expects a usize, not a &usize.
|
|
|
|
for _ in 0..*count {
|
|
|
|
new_string.push_str("bar");
|
|
|
|
}
|
|
|
|
output.push(new_string)
|
|
|
|
}
|
|
|
|
}
|
2022-07-14 14:16:32 +03:00
|
|
|
}
|
|
|
|
output
|
|
|
|
}
|
2015-09-21 01:31:41 +03:00
|
|
|
}
|
|
|
|
|
2022-07-14 14:16:32 +03:00
|
|
|
#[cfg(test)]
|
|
|
|
mod tests {
|
2022-11-24 22:20:59 +03:00
|
|
|
// TODO: What do we need to import to have `transformer` in scope?
|
2024-02-01 23:40:18 +03:00
|
|
|
use crate::my_module::transformer;
|
2022-07-14 14:16:32 +03:00
|
|
|
use super::Command;
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn it_works() {
|
|
|
|
let output = transformer(vec![
|
|
|
|
("hello".into(), Command::Uppercase),
|
|
|
|
(" all roads lead to rome! ".into(), Command::Trim),
|
|
|
|
("foo".into(), Command::Append(1)),
|
|
|
|
("bar".into(), Command::Append(5)),
|
|
|
|
]);
|
|
|
|
assert_eq!(output[0], "HELLO");
|
|
|
|
assert_eq!(output[1], "all roads lead to rome!");
|
|
|
|
assert_eq!(output[2], "foobar");
|
|
|
|
assert_eq!(output[3], "barbarbarbarbarbar");
|
|
|
|
}
|
2015-09-21 01:31:41 +03:00
|
|
|
}
|