summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2024-05-01 13:53:10 +0200
committerSébastien Helleu <flashcode@flashtux.org>2024-05-01 13:53:58 +0200
commit3aeea2d6aa7b272844bee28e1ddfd1b5d7858a07 (patch)
tree5b1c9c953bcfe394234f98ddc025becf6fbf32dd /src
parentafe037c579b541bb86657916abef23a7ab8907bb (diff)
downloadweechat-3aeea2d6aa7b272844bee28e1ddfd1b5d7858a07.zip
relay/remote: set buffer local keys (issue #2066)
Diffstat (limited to 'src')
-rw-r--r--src/plugins/relay/api/remote/relay-remote-event.c33
1 files changed, 30 insertions, 3 deletions
diff --git a/src/plugins/relay/api/remote/relay-remote-event.c b/src/plugins/relay/api/remote/relay-remote-event.c
index c2b3717a9..8062024cc 100644
--- a/src/plugins/relay/api/remote/relay-remote-event.c
+++ b/src/plugins/relay/api/remote/relay-remote-event.c
@@ -475,9 +475,10 @@ RELAY_REMOTE_EVENT_CALLBACK(buffer)
struct t_gui_buffer *ptr_buffer;
struct t_hashtable *buffer_props;
struct t_relay_remote_event event_line;
- cJSON *json_obj, *json_lines, *json_line, *json_nicklist_root;
- const char *name, *short_name, *type, *title;
- char *full_name, str_number[64];
+ cJSON *json_obj, *json_keys, *json_key, *json_key_name, *json_key_command;
+ cJSON *json_lines, *json_line, *json_nicklist_root;
+ const char *name, *short_name, *type, *title, *ptr_key, *ptr_command;
+ char *full_name, str_number[64], *property;
long long id;
int number, nicklist, nicklist_case_sensitive, nicklist_display_groups;
@@ -542,6 +543,32 @@ RELAY_REMOTE_EVENT_CALLBACK(buffer)
if (!ptr_buffer)
goto end;
+ /* add keys */
+ json_keys = cJSON_GetObjectItem (event->json, "keys");
+ if (json_keys && cJSON_IsArray (json_keys))
+ {
+ cJSON_ArrayForEach (json_key, json_keys)
+ {
+ json_key_name = cJSON_GetObjectItem (json_key, "key");
+ json_key_command = cJSON_GetObjectItem (json_key, "command");
+ if (json_key_name && cJSON_IsString (json_key_name)
+ && json_key_command && cJSON_IsString (json_key_command))
+ {
+ ptr_key = cJSON_GetStringValue (json_key_name);
+ ptr_command = cJSON_GetStringValue (json_key_command);
+ if (ptr_key && ptr_command)
+ {
+ if (weechat_asprintf (&property, "key_bind_%s", ptr_key) >= 0)
+ {
+ weechat_buffer_set (ptr_buffer, property, ptr_command);
+ free (property);
+ }
+ }
+ }
+ }
+ }
+
+
/* add lines */
json_lines = cJSON_GetObjectItem (event->json, "lines");
if (json_lines && cJSON_IsArray (json_lines))