diff options
author | Sébastien Helleu <flashcode@flashtux.org> | 2024-05-01 13:53:10 +0200 |
---|---|---|
committer | Sébastien Helleu <flashcode@flashtux.org> | 2024-05-01 13:53:58 +0200 |
commit | 3aeea2d6aa7b272844bee28e1ddfd1b5d7858a07 (patch) | |
tree | 5b1c9c953bcfe394234f98ddc025becf6fbf32dd /src | |
parent | afe037c579b541bb86657916abef23a7ab8907bb (diff) | |
download | weechat-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.c | 33 |
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)) |