Решение на CSS Цветове от Мирела Граматикова

Обратно към всички решения

Към профила на Мирела Граматикова

Резултати

  • 16 точки от тестове
  • 0 бонус точки
  • 16 точки общо
  • 4 успешни тест(а)
  • 1 неуспешни тест(а)

Код

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 {
Color::RGB {
red: red,
green: green,
blue: blue
}
}
/// Конструира нова стойност от вариант `HSV` с дадените стойности.
///
/// В случай, че hue е над 360 или saturation или value са над 100, очакваме да `panic!`-нете с
/// каквото съобщение си изберете.
///
pub fn new_hsv(hue: u16, saturation: u8, value: u8) -> Color {
if hue > 360 || value > 100 {
panic!("Out of range");
}
Color::HSV {
hue: hue,
saturation: saturation,
value: value
}
}
/// Ако `self` е `RGB`, тогава връщате неговите `red`, `green`, `blue` компоненти в този ред.
/// Иначе, `panic!`-вате с каквото съобщение си изберете.
///
pub fn unwrap_rgb(&self) -> (u8, u8, u8) {
if let Color::RGB{red,green,blue} = self {
(*red, *green, *blue)
} else {
panic!("Not RGB");
}
}
/// Ако `self` е `HSV`, тогава връщате неговите `hue`, `saturation`, `value` компоненти в този
/// ред. Иначе, `panic!`-вате с каквото съобщение си изберете.
///
pub fn unwrap_hsv(&self) -> (u16, u8, u8) {
if let Color::HSV{hue, saturation, value} = self {
(*hue, *saturation, *value)
} else {
panic!("Not HSV");
}
}
/// В случай, че варианта на `self` е `RGB`, очакваме низ със съдържание `#rrggbb`, където
/// червения, зеления и синия компонент са форматирани в шестнадесетична система, и всеки от тях е
/// точно два символа с малки букви (запълнени с нули).
///
/// Ако варианта е `HSV`, очакваме низ `hsv(h,s%,v%)`, където числата са си напечатани в
/// десетичната система, без водещи нули, без интервали след запетаите, вторите две завършващи на
/// `%`.
///
pub fn to_string(&self) -> String {
if let Color::RGB{red, green, blue} = self {
format!("#{:0>2x}{:0>2x}{:0>2x}", red, green, blue)
} else if let Color::HSV{hue, saturation, value} = self {
format!("hsv({},{}%,{}%)", hue, saturation, value)
} else {
panic!("Wtf");
}
}
/// Инвертира цвят покомпонентно -- за всяка от стойностите се взема разликата с максимума.
///
pub fn invert(&self) -> Self {
if let Color::RGB{red, green, blue} = self {
let inverted_red = &(255 - red);
let inverted_green = &(255 - green);
let inverted_blue = &(255 - blue);
Color::RGB {
red: *inverted_red,
green: *inverted_green,
blue: *inverted_blue
}
} else if let Color::HSV{hue, saturation, value} = self {
let inverted_hue = &(360 - hue);
let inverted_saturation = &(100 - saturation);
let inverted_value = &(100 - value);
Color::HSV {
hue: *inverted_hue,
saturation: *inverted_saturation,
value: *inverted_value
}
} else {
panic!("Wtf again");
}
}
}

Лог от изпълнението

Compiling solution v0.1.0 (/tmp/d20230111-3772066-17gpi9f/solution)
    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 ... ok
test solution_test::test_hsv_display ... ok
test solution_test::test_invert_rgb ... ok
test solution_test::test_rgb_display ... ok
test solution_test::test_new_hsv ... FAILED

failures:

---- solution_test::test_new_hsv stdout ----
thread 'solution_test::test_new_hsv' panicked at 'Out of range', src/lib.rs:32:13
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
thread 'solution_test::test_new_hsv' panicked at 'assertion failed: catch_unwind(|| Color::new_hsv(100, 200, 0)).is_err()', tests/solution_test.rs:23:5


failures:
    solution_test::test_new_hsv

test result: FAILED. 4 passed; 1 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s

error: test failed, to rerun pass `--test solution_test`

История (1 версия и 1 коментар)

Мирела качи първо решение на 25.10.2022 22:12 (преди почти 3 години)