From be724ca57080629b48e2663d31296da538b39831 Mon Sep 17 00:00:00 2001 From: Ygor Souza Date: Wed, 2 Oct 2024 18:38:09 +0200 Subject: [PATCH 1/2] Use boxed slice for lookup table to avoid stack overflow --- crates/ecolor/src/color32.rs | 16 +++++++++------- 1 file changed, 9 insertions(+), 7 deletions(-) diff --git a/crates/ecolor/src/color32.rs b/crates/ecolor/src/color32.rs index 80c876d192d..aef7a9d1d24 100644 --- a/crates/ecolor/src/color32.rs +++ b/crates/ecolor/src/color32.rs @@ -108,15 +108,17 @@ impl Color32 { // common-case optimization 255 => Self::from_rgb(r, g, b), a => { - static LOOKUP_TABLE: OnceLock<[u8; 256 * 256]> = OnceLock::new(); + static LOOKUP_TABLE: OnceLock> = OnceLock::new(); let lut = LOOKUP_TABLE.get_or_init(|| { use crate::{gamma_u8_from_linear_f32, linear_f32_from_gamma_u8}; - core::array::from_fn(|i| { - let [value, alpha] = (i as u16).to_ne_bytes(); - let value_lin = linear_f32_from_gamma_u8(value); - let alpha_lin = linear_f32_from_linear_u8(alpha); - gamma_u8_from_linear_f32(value_lin * alpha_lin) - }) + (0..u16::MAX) + .map(|i| { + let [value, alpha] = i.to_ne_bytes(); + let value_lin = linear_f32_from_gamma_u8(value); + let alpha_lin = linear_f32_from_linear_u8(alpha); + gamma_u8_from_linear_f32(value_lin * alpha_lin) + }) + .collect() }); let [r, g, b] = From 3e5f9dfdbb768a980116e4f5e81d3db9feea87ba Mon Sep 17 00:00:00 2001 From: Ygor Souza Date: Wed, 2 Oct 2024 18:52:14 +0200 Subject: [PATCH 2/2] Fix off-by-one error In practice it would not have caused problems since the 255 case is handled separately, but we may as well fix it. --- crates/ecolor/src/color32.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/crates/ecolor/src/color32.rs b/crates/ecolor/src/color32.rs index aef7a9d1d24..827314c0787 100644 --- a/crates/ecolor/src/color32.rs +++ b/crates/ecolor/src/color32.rs @@ -111,7 +111,7 @@ impl Color32 { static LOOKUP_TABLE: OnceLock> = OnceLock::new(); let lut = LOOKUP_TABLE.get_or_init(|| { use crate::{gamma_u8_from_linear_f32, linear_f32_from_gamma_u8}; - (0..u16::MAX) + (0..=u16::MAX) .map(|i| { let [value, alpha] = i.to_ne_bytes(); let value_lin = linear_f32_from_gamma_u8(value);