Skip to content

Commit

Permalink
enums
Browse files Browse the repository at this point in the history
  • Loading branch information
git-user-cpp committed Apr 24, 2024
1 parent 0ce9697 commit a2897cb
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 8 deletions.
6 changes: 4 additions & 2 deletions exercises/08_enums/enums1.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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() {
Expand Down
6 changes: 4 additions & 2 deletions exercises/08_enums/enums2.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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 {
Expand Down
14 changes: 10 additions & 4 deletions exercises/08_enums/enums3.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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 {
Expand Down Expand Up @@ -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(),
}
}
}

Expand Down

0 comments on commit a2897cb

Please sign in to comment.