rustlings/exercises/07_structs/structs1.rs

60 lines
1.4 KiB
Rust
Raw Normal View History

2019-05-25 14:39:58 +03:00
// structs1.rs
//
2019-05-25 14:39:58 +03:00
// Address all the TODOs to make the tests pass!
//
// Execute `rustlings hint structs1` or use the `hint` watch subcommand for a
// hint.
2019-05-25 14:39:58 +03:00
struct ColorClassicStruct {
// TODO: Something goes here
2024-02-01 00:28:39 +03:00
red: i32,
green: i32,
blue: i32,
2019-05-25 14:39:58 +03:00
}
2024-02-01 00:28:39 +03:00
struct ColorTupleStruct(i32, i32, i32);
2019-05-25 14:39:58 +03:00
#[derive(Debug)]
struct UnitLikeStruct;
2019-05-25 14:39:58 +03:00
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn classic_c_structs() {
// TODO: Instantiate a classic c struct!
2024-02-01 00:28:39 +03:00
let green = ColorClassicStruct {
red: 0,
green: 255,
blue: 0
};
2019-05-25 14:39:58 +03:00
assert_eq!(green.red, 0);
assert_eq!(green.green, 255);
assert_eq!(green.blue, 0);
2019-05-25 14:39:58 +03:00
}
#[test]
fn tuple_structs() {
// TODO: Instantiate a tuple struct!
2024-02-01 00:28:39 +03:00
let green = ColorTupleStruct(0, 255, 0);
2019-05-25 14:39:58 +03:00
assert_eq!(green.0, 0);
assert_eq!(green.1, 255);
assert_eq!(green.2, 0);
2019-05-25 14:39:58 +03:00
}
#[test]
fn unit_structs() {
// TODO: Instantiate a unit-like struct!
2024-02-01 00:28:39 +03:00
// does not hold data but can be used to improve type safety
// best used when you don't need data but you want to define methods
// Great example of this is errors.
let unit_like_struct = UnitLikeStruct;
let message = format!("{:?}s are fun!", unit_like_struct);
2019-05-25 14:39:58 +03:00
assert_eq!(message, "UnitLikeStructs are fun!");
2019-05-25 14:39:58 +03:00
}
}