Решение на CSS Цветове от Галя Додова
Резултати
- 8 точки от тестове
- 0 бонус точки
- 8 точки общо
- 2 успешни тест(а)
- 3 неуспешни тест(а)
Код
pub enum Color {
RGB {
red: u8,
green: u8,
blue: u8
},
HSV {
hue: u16,
saturation: u8,
value: u8,
}
}
impl Color {
/// Конструира нова стойност от вариант `RGB` с дадените стойности за червено, зелено и синьо.
///
pub fn new_rgb(red: u8, green: u8, blue: u8) -> Color {
crate::Color::RGB{red, green, blue}
}
/// Конструира нова стойност от вариант `HSV` с дадените стойности.
///
/// В случай, че hue е над 360 или saturation или value са над 100, очакваме да `panic!`-нете с
/// каквото съобщение си изберете.
///
pub fn new_hsv(hue: u16, saturation: u8, value: u8) -> Color {
if hue <=360 && saturation<=100 && value<=100{
crate::Color::HSV{hue, saturation, value}
} else{
panic!("Too high values!");
}
}
/// Ако `self` е `RGB`, тогава връщате неговите `red`, `green`, `blue` компоненти в този ред.
/// Иначе, `panic!`-вате с каквото съобщение си изберете.
///
pub fn unwrap_rgb(&self) -> (u8, u8, u8) {
match &self{
Color::RGB { red, green, blue } => return (*red, *green, *blue),
Color::HSV { hue, saturation, value } => panic!("Not a RGB!"),
}
}
/// Ако `self` е `HSV`, тогава връщате неговите `hue`, `saturation`, `value` компоненти в този
/// ред. Иначе, `panic!`-вате с каквото съобщение си изберете.
///
pub fn unwrap_hsv(&self) -> (u16, u8, u8) {
match &self{
Color::RGB { red, green, blue } => panic!("Not a HSV!"),
Color::HSV { hue, saturation, value } => return (*hue, *saturation, *value),
}
}
/// В случай, че варианта на `self` е `RGB`, очакваме низ със съдържание `#rrggbb`, където
/// червения, зеления и синия компонент са форматирани в шестнадесетична система, и всеки от тях е
/// точно два символа с малки букви (запълнени с нули).
///
/// Ако варианта е `HSV`, очакваме низ `hsv(h,s%,v%)`, където числата са си напечатани в
/// десетичната система, без водещи нули, без интервали след запетаите, вторите две завършващи на
/// `%`.
///
pub fn to_string(&self) -> String {
match &self{
Color::RGB { red, green, blue } =>
return String::from("#")+ &(*red as u16).to_string() + &(*green as u16).to_string() + &(*blue as u16).to_string()
,
Color::HSV { hue, saturation, value } =>
return String::from("hsv(") + &hue.to_string() + "," + &saturation.to_string() + "%" +
&value.to_string() + &String::from("% )")
,
}
}
/// Инвертира цвят покомпонентно -- за всяка от стойностите се взема разликата с максимума.
///
pub fn invert(&self) -> Self {
match &self{
Color::RGB { red, green, blue } => return Color::RGB{ red: 255-red, green: 255-green, blue: 255-blue },
Color::HSV { hue, saturation, value } => panic!("Not a RGB!"),
}
}
}
Лог от изпълнението
Compiling solution v0.1.0 (/tmp/d20230111-3772066-flt6ix/solution) warning: unused variable: `hue` --> src/lib.rs:41:22 | 41 | Color::HSV { hue, saturation, value } => panic!("Not a RGB!"), | ^^^ help: try ignoring the field: `hue: _` | = note: `#[warn(unused_variables)]` on by default warning: unused variable: `saturation` --> src/lib.rs:41:27 | 41 | Color::HSV { hue, saturation, value } => panic!("Not a RGB!"), | ^^^^^^^^^^ help: try ignoring the field: `saturation: _` warning: unused variable: `value` --> src/lib.rs:41:39 | 41 | Color::HSV { hue, saturation, value } => panic!("Not a RGB!"), | ^^^^^ help: try ignoring the field: `value: _` warning: unused variable: `red` --> src/lib.rs:50:21 | 50 | Color::RGB { red, green, blue } => panic!("Not a HSV!"), | ^^^ help: try ignoring the field: `red: _` warning: unused variable: `green` --> src/lib.rs:50:26 | 50 | Color::RGB { red, green, blue } => panic!("Not a HSV!"), | ^^^^^ help: try ignoring the field: `green: _` warning: unused variable: `blue` --> src/lib.rs:50:33 | 50 | Color::RGB { red, green, blue } => panic!("Not a HSV!"), | ^^^^ help: try ignoring the field: `blue: _` warning: unused variable: `hue` --> src/lib.rs:80:27 | 80 | Color::HSV { hue, saturation, value } => panic!("Not a RGB!"), | ^^^ help: try ignoring the field: `hue: _` warning: unused variable: `saturation` --> src/lib.rs:80:32 | 80 | Color::HSV { hue, saturation, value } => panic!("Not a RGB!"), | ^^^^^^^^^^ help: try ignoring the field: `saturation: _` warning: unused variable: `value` --> src/lib.rs:80:44 | 80 | Color::HSV { hue, saturation, value } => panic!("Not a RGB!"), | ^^^^^ help: try ignoring the field: `value: _` warning: `solution` (lib) generated 9 warnings Finished test [unoptimized + debuginfo] target(s) in 0.63s Running tests/solution_test.rs (target/debug/deps/solution_test-0edbea2040daef01) running 5 tests test solution_test::test_invert_hsv ... FAILED test solution_test::test_hsv_display ... FAILED test solution_test::test_invert_rgb ... ok test solution_test::test_new_hsv ... ok test solution_test::test_rgb_display ... FAILED failures: ---- solution_test::test_invert_hsv stdout ---- thread 'solution_test::test_invert_hsv' panicked at 'Not a RGB!', src/lib.rs:80:56 ---- solution_test::test_hsv_display stdout ---- thread 'solution_test::test_hsv_display' panicked at 'assertion failed: `(left == right)` left: `"hsv(0,0%0% )"`, right: `"hsv(0,0%,0%)"`', tests/solution_test.rs:15:5 note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace ---- solution_test::test_rgb_display stdout ---- thread 'solution_test::test_rgb_display' panicked at 'assertion failed: `(left == right)` left: `"#000"`, right: `"#000000"`', tests/solution_test.rs:8:5 failures: solution_test::test_hsv_display solution_test::test_invert_hsv solution_test::test_rgb_display test result: FAILED. 2 passed; 3 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s error: test failed, to rerun pass `--test solution_test`