Current progress

This commit is contained in:
2023-04-20 05:50:50 -05:00
parent 7f1754ecc5
commit 5004cc3bbb
49 changed files with 152 additions and 132 deletions
+4 -1
View File
@@ -1,11 +1,14 @@
// enums1.rs
// No hints this time! ;)
// I AM NOT DONE
#[derive(Debug)]
enum Message {
// TODO: define a few types of messages as used below
Quit,
Echo,
Move,
ChangeColor,
}
fn main() {
+4 -1
View File
@@ -1,11 +1,14 @@
// enums2.rs
// Execute `rustlings hint enums2` or use the `hint` watch subcommand for a hint.
// I AM NOT DONE
#[derive(Debug)]
enum Message {
// TODO: define the different variants used below
Move{x: u16, y: u16},
Echo(String),
ChangeColor(u16, u16, u16),
Quit,
}
impl Message {
+11 -2
View File
@@ -2,10 +2,13 @@
// Address all the TODOs to make the tests pass!
// Execute `rustlings hint enums3` or use the `hint` watch subcommand for a hint.
// I AM NOT DONE
enum Message {
// TODO: implement the message variant types based on their usage below
ChangeColor((u8, u8, u8)),
Echo(String),
Move(Point),
Quit,
}
struct Point {
@@ -39,6 +42,12 @@ impl State {
fn process(&mut self, message: Message) {
// TODO: create a match expression to process the different message variants
// Remember: When passing a tuple as a function argument, you'll need extra parentheses: fn function((t, u, p, l, e))
match message {
Message::ChangeColor(color) => self.change_color(color),
Message::Echo(string) => self.echo(string),
Message::Move(point) => self.move_position(point),
Message::Quit => self.quit(),
}
}
}
@@ -53,7 +62,7 @@ mod tests {
position: Point { x: 0, y: 0 },
color: (0, 0, 0),
};
state.process(Message::ChangeColor(255, 0, 255));
state.process(Message::ChangeColor((255, 0, 255)));
state.process(Message::Echo(String::from("hello world")));
state.process(Message::Move(Point { x: 10, y: 15 }));
state.process(Message::Quit);