summaryrefslogtreecommitdiff
path: root/src/modules/rkt
diff options
context:
space:
mode:
authorVito Caputo <vcaputo@pengaru.com>2023-07-04 20:50:56 -0700
committerVito Caputo <vcaputo@pengaru.com>2023-07-04 22:17:07 -0700
commit3ef4f9fd1e6ae233adb0bbfd90573623ee1059e6 (patch)
treea4ce04703e37a683f33d8675c6f10e21d4070e6a /src/modules/rkt
parent68f6dee32dea0fb1bfe40d901169cf68aa6528d0 (diff)
modules/*: return invalid setting on -EINVAL in setup
In the interests of improving error handling of interactive setups, return the setting that was invalid when setup returns -EINVAL. For now this is only supported for non-finalized/non-baking setup calls, i.e. (!res_setup). In the future I want this also supported for finalizing when res_setup is set. A lot of the -EINVAL returns are actually during that stage (or need to be added) due to that being when the more sensitive parsing occurs going from strings to native numeric types and such. The main reason it's not already being done in this commit is it'll churn quite a bit to get there, since the setup funcs don't generally have the setting pointers onhand at that phase. It'll require changing the string-value-centric local variables to instead all be the til_setting_t* holding those values. And if setup funcs aren't going to be so value-centric, the settings API will likely change to not even return the values directly anymore and only return the full-blown til_settings_t as the main return pointer, perhaps rid of their res_setting use even. Anyway, while here I did some random little cleanups too.
Diffstat (limited to 'src/modules/rkt')
-rw-r--r--src/modules/rkt/rkt.c16
1 files changed, 10 insertions, 6 deletions
diff --git a/src/modules/rkt/rkt.c b/src/modules/rkt/rkt.c
index 3c97bc4..6d0a8bf 100644
--- a/src/modules/rkt/rkt.c
+++ b/src/modules/rkt/rkt.c
@@ -376,12 +376,9 @@ static int rkt_setup(const til_settings_t *settings, til_setting_t **res_setting
for (size_t i = 0; til_settings_get_value_by_idx(scenes_settings, i, &scene_setting); i++) {
til_setting_t *scene_module_setting;
const char *scene_module_name = til_settings_get_value_by_idx(scene_setting->value_as_nested_settings, 0, &scene_module_setting);
- const til_module_t *scene_module = til_lookup_module(scene_module_name);
-
- if (!scene_module || !scene_module_setting)
- return -EINVAL;
+ const til_module_t *scene_module;
- if (!scene_module_setting->desc) {
+ if (!scene_module_name || !scene_module_setting->desc) {
r = til_setting_desc_new( scene_setting->value_as_nested_settings,
&(til_setting_spec_t){
.name = "Scene module name",
@@ -391,11 +388,18 @@ static int rkt_setup(const til_settings_t *settings, til_setting_t **res_setting
if (r < 0)
return r;
- *res_setting = scene_module_setting;
+ *res_setting = scene_module_name ? scene_module_setting : NULL;
return 1;
}
+ scene_module = til_lookup_module(scene_module_name);
+ if (!scene_module) {
+ *res_setting = scene_module_setting;
+
+ return -EINVAL;
+ }
+
if (scene_module->setup) {
r = scene_module->setup(scene_setting->value_as_nested_settings, res_setting, res_desc, NULL);
if (r)
© All Rights Reserved