From a2897cb4641a8f632cb79d9453e036554df0226d Mon Sep 17 00:00:00 2001 From: Andrew Kushyk <61907955+git-user-cpp@users.noreply.github.com> Date: Wed, 24 Apr 2024 07:57:37 +0000 Subject: [PATCH] enums --- exercises/08_enums/enums1.rs | 6 ++++-- exercises/08_enums/enums2.rs | 6 ++++-- exercises/08_enums/enums3.rs | 14 ++++++++++---- 3 files changed, 18 insertions(+), 8 deletions(-) diff --git a/exercises/08_enums/enums1.rs b/exercises/08_enums/enums1.rs index 25525b25..74967b66 100644 --- a/exercises/08_enums/enums1.rs +++ b/exercises/08_enums/enums1.rs @@ -2,11 +2,13 @@ // // 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() { diff --git a/exercises/08_enums/enums2.rs b/exercises/08_enums/enums2.rs index df93fe0f..ee76d3c5 100644 --- a/exercises/08_enums/enums2.rs +++ b/exercises/08_enums/enums2.rs @@ -3,11 +3,13 @@ // 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: i32, y: i32}, + Echo (String), + ChangeColor (i16, i16 ,i16), + Quit } impl Message { diff --git a/exercises/08_enums/enums3.rs b/exercises/08_enums/enums3.rs index 92d18c46..16c7fa32 100644 --- a/exercises/08_enums/enums3.rs +++ b/exercises/08_enums/enums3.rs @@ -5,10 +5,13 @@ // 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 { @@ -41,9 +44,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(r, g, b) => self.change_color((r, g, b)), + Message::Echo(s) => self.echo(s), + Message::Move(p) => self.move_position(p), + Message::Quit => self.quit(), + } } }