From 5217ca6121267ca4c7a705144e498300f0f3ee97 Mon Sep 17 00:00:00 2001 From: Jacalz Date: Sun, 10 Nov 2024 20:03:36 +0100 Subject: [PATCH] Introduce functions for parsing values from ReadOne or settings callbacks --- settings/appearance/color.go | 36 ++++++++++++++++++++++++++------- settings/appearance/contrast.go | 13 +++++++++++- 2 files changed, 41 insertions(+), 8 deletions(-) diff --git a/settings/appearance/color.go b/settings/appearance/color.go index 5b12d8b..372924e 100644 --- a/settings/appearance/color.go +++ b/settings/appearance/color.go @@ -26,12 +26,7 @@ func GetColorScheme() (ColorScheme, error) { return NoPreference, err } - result := value.(uint32) - if result > 2 || result > 255 { - result = 0 // Unknown values should be treated as 0 (no preference). - } - - return ColorScheme(result), nil + return ValueToColorScheme(value) } // GetAccentColor returns the currently set accent color. @@ -42,7 +37,34 @@ func GetAccentColor() (*color.RGBA, error) { return nil, ErrNotSet } - result := value.([]float64) + return ValueToAccentColor(value) +} + +// ValueToColorScheme converts a read value to a ColorScheme type. +// This is useful when for example parsing a value from the callback +// in [settings.SignalOnSettingChanged] or a value from [settings.ReadOne]. +func ValueToColorScheme(value any) (ColorScheme, error) { + result, ok := value.(uint32) + if !ok { + return NoPreference, ErrNotSet + } + + if result > 2 || result > 255 { + result = 0 // Unknown values should be treated as 0 (no preference). + } + + return ColorScheme(result), nil +} + +// ValueToAccentColor converts a read value to an accent color type. +// This is useful when for example parsing a value from the callback +// in [settings.SignalOnSettingChanged] or a value from [settings.ReadOne]. +func ValueToAccentColor(value any) (*color.RGBA, error) { + result, ok := value.([]float64) + if !ok { + return nil, ErrNotSet + } + if len(result) != 4 { return nil, ErrNotSet } diff --git a/settings/appearance/contrast.go b/settings/appearance/contrast.go index e8e0652..d7bb26d 100644 --- a/settings/appearance/contrast.go +++ b/settings/appearance/contrast.go @@ -17,7 +17,18 @@ func GetContrast() (Contrast, error) { return NormalContrast, err } - result := value.(uint32) + return ValueToContrast(value) +} + +// ValueToContrast converts a read value to a Contrast type. +// This is useful when for example parsing a value from the callback +// in [settings.SignalOnSettingChanged] or a value from [settings.ReadOne]. +func ValueToContrast(value any) (Contrast, error) { + result, ok := value.(uint32) + if !ok { + return NormalContrast, ErrNotSet + } + if result > 1 || result > 255 { result = 0 // Unknown values should be treated as 0 (no preference). }