From 7013158a6715d94b34e8c471ce25bb5005f3bb49 Mon Sep 17 00:00:00 2001 From: Joel Spadin Date: Wed, 11 Dec 2024 14:00:48 -0600 Subject: [PATCH] fix: Fix warnings in nanopb encoding code (#2643) The "arg" field on nanopb structs is a void* because it is shared between the encode and decode callbacks, even though the encode callback probably should not modify the data. We are passing const data using this non-const pointer, which causes warnings about discarding const. This commit explicitly casts to void* to suppress these warnings. --- app/src/studio/behavior_subsystem.c | 2 +- app/src/studio/keymap_subsystem.c | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/app/src/studio/behavior_subsystem.c b/app/src/studio/behavior_subsystem.c index 96c1f236e67..24591315c38 100644 --- a/app/src/studio/behavior_subsystem.c +++ b/app/src/studio/behavior_subsystem.c @@ -84,7 +84,7 @@ static bool encode_value_description(pb_ostream_t *stream, const pb_field_t *fie zmk_behaviors_BehaviorParameterValueDescription desc = zmk_behaviors_BehaviorParameterValueDescription_init_zero; desc.name.funcs.encode = encode_value_description_name; - desc.name.arg = val; + desc.name.arg = (void *)val; switch (val->type) { case BEHAVIOR_PARAMETER_VALUE_TYPE_VALUE: diff --git a/app/src/studio/keymap_subsystem.c b/app/src/studio/keymap_subsystem.c index 3516a3fb9f2..6ac1e7efc1d 100644 --- a/app/src/studio/keymap_subsystem.c +++ b/app/src/studio/keymap_subsystem.c @@ -306,10 +306,10 @@ static bool encode_layouts(pb_ostream_t *stream, const pb_field_t *field, void * zmk_keymap_PhysicalLayout layout = zmk_keymap_PhysicalLayout_init_zero; layout.name.funcs.encode = encode_layout_name; - layout.name.arg = l; + layout.name.arg = (void *)l; layout.keys.funcs.encode = encode_layout_keys; - layout.keys.arg = l; + layout.keys.arg = (void *)l; if (!pb_encode_submessage(stream, &zmk_keymap_PhysicalLayout_msg, &layout)) { LOG_WRN("Failed to encode layout submessage"); @@ -465,10 +465,10 @@ zmk_studio_Response restore_layer(const zmk_studio_Request *req) { resp.result.ok.id = restore_req->layer_id; resp.result.ok.name.funcs.encode = encode_layer_name; - resp.result.ok.name.arg = &restore_req->layer_id; + resp.result.ok.name.arg = (void *)&restore_req->layer_id; resp.result.ok.bindings.funcs.encode = encode_layer_bindings; - resp.result.ok.bindings.arg = &restore_req->layer_id; + resp.result.ok.bindings.arg = (void *)&restore_req->layer_id; raise_zmk_studio_rpc_notification((struct zmk_studio_rpc_notification){ .notification = KEYMAP_NOTIFICATION(unsaved_changes_status_changed, true)});