From 8a45ec2875a4f72cb02d574b63b5dda141da35c1 Mon Sep 17 00:00:00 2001 From: Laurenz Date: Thu, 27 Aug 2020 21:56:53 +0200 Subject: [PATCH] =?UTF-8?q?Fix=20default=20values=20for=20rgb-clamping=20?= =?UTF-8?q?=F0=9F=A9=B9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/library/color.rs | 31 ++++++++++++++++++------------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/src/library/color.rs b/src/library/color.rs index eab84fd01..12bebdc97 100644 --- a/src/library/color.rs +++ b/src/library/color.rs @@ -5,22 +5,27 @@ use super::*; pub async fn rgb(span: Span, mut args: TableValue, _: LayoutContext<'_>) -> Pass { let mut f = Feedback::new(); + let r = args.expect::>("red value", span, &mut f); + let g = args.expect::>("green value", span, &mut f); + let b = args.expect::>("blue value", span, &mut f); + let a = args.take::>(); + + let mut clamp = |component: Option>, default| { + component.map(|c| { + if c.v < 0.0 || c.v > 255.0 { + error!(@f, c.span, "should be between 0 and 255") + } + c.v.min(255.0).max(0.0).round() as u8 + }).unwrap_or(default) + }; + let color = RgbaColor::new( - clamp(args.expect::>("red value", span, &mut f), &mut f), - clamp(args.expect::>("green value", span, &mut f), &mut f), - clamp(args.expect::>("blue value", span, &mut f), &mut f), - clamp(args.take::>(), &mut f), + clamp(r, 0), + clamp(g, 0), + clamp(b, 0), + clamp(a, 255), ); args.unexpected(&mut f); Pass::new(Value::Color(color), f) } - -fn clamp(component: Option>, f: &mut Feedback) -> u8 { - component.map(|c| { - if c.v < 0.0 || c.v > 255.0 { - error!(@f, c.span, "should be between 0 and 255") - } - c.v.min(255.0).max(0.0).round() as u8 - }).unwrap_or_default() -}