summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2024-05-05 23:56:33 +0200
committerSébastien Helleu <flashcode@flashtux.org>2024-05-05 23:56:33 +0200
commit75270d78419e94ad5a6a808e3c448af9f591762a (patch)
tree7915c32cbd29c9c8f37412d83fb97a19d8e8fbc0
parent6526cc230a80d8aa05d36c70c1d97f0e7ccf182d (diff)
downloadweechat-75270d78419e94ad5a6a808e3c448af9f591762a.zip
relay/api: add optional synchronization of input
-rw-r--r--src/plugins/relay/api/relay-api-protocol.c47
-rw-r--r--src/plugins/relay/api/relay-api-protocol.h4
-rw-r--r--src/plugins/relay/api/relay-api.c35
-rw-r--r--src/plugins/relay/api/relay-api.h4
4 files changed, 89 insertions, 1 deletions
diff --git a/src/plugins/relay/api/relay-api-protocol.c b/src/plugins/relay/api/relay-api-protocol.c
index a025db3cc..c3035edcd 100644
--- a/src/plugins/relay/api/relay-api-protocol.c
+++ b/src/plugins/relay/api/relay-api-protocol.c
@@ -266,6 +266,47 @@ relay_api_protocol_hsignal_nicklist_cb (const void *pointer, void *data,
}
/*
+ * Callback for signal "input_text_changed".
+ */
+
+int
+relay_api_protocol_signal_input_cb (const void *pointer, void *data,
+ const char *signal,
+ const char *type_data,
+ void *signal_data)
+{
+ struct t_relay_client *ptr_client;
+ struct t_gui_buffer *ptr_buffer;
+ cJSON *json;
+ long long buffer_id;
+
+ /* make C compiler happy */
+ (void) data;
+ (void) type_data;
+
+ ptr_client = (struct t_relay_client *)pointer;
+ if (!ptr_client || !relay_client_valid (ptr_client))
+ return WEECHAT_RC_OK;
+
+ ptr_buffer = (struct t_gui_buffer *)signal_data;
+ if (!ptr_buffer || relay_buffer_is_relay (ptr_buffer))
+ return WEECHAT_RC_OK;
+
+ json = relay_api_msg_buffer_to_json (
+ ptr_buffer, 0, 0, 0,
+ RELAY_API_DATA(ptr_client, sync_colors));
+
+ if (json)
+ {
+ buffer_id = relay_api_get_buffer_id (ptr_buffer);
+ relay_api_msg_send_event (ptr_client, signal, buffer_id, "buffer", json);
+ cJSON_Delete (json);
+ }
+
+ return WEECHAT_RC_OK;
+}
+
+/*
* Callback for signals "upgrade*".
*/
@@ -763,7 +804,7 @@ RELAY_API_PROTOCOL_CALLBACK(ping)
RELAY_API_PROTOCOL_CALLBACK(sync)
{
- cJSON *json_body, *json_sync, *json_nicks, *json_colors;
+ cJSON *json_body, *json_sync, *json_nicks, *json_input, *json_colors;
if (client->websocket != RELAY_CLIENT_WEBSOCKET_READY)
{
@@ -777,6 +818,7 @@ RELAY_API_PROTOCOL_CALLBACK(sync)
RELAY_API_DATA(client, sync_enabled) = 1;
RELAY_API_DATA(client, sync_nicks) = 1;
+ RELAY_API_DATA(client, sync_input) = 1;
RELAY_API_DATA(client, sync_colors) = RELAY_API_COLORS_ANSI;
json_body = cJSON_Parse (client->http_req->body);
@@ -788,6 +830,9 @@ RELAY_API_PROTOCOL_CALLBACK(sync)
json_nicks = cJSON_GetObjectItem (json_body, "nicks");
if (json_nicks && cJSON_IsBool (json_nicks))
RELAY_API_DATA(client, sync_nicks) = (cJSON_IsTrue (json_nicks)) ? 1 : 0;
+ json_input = cJSON_GetObjectItem (json_body, "input");
+ if (json_input && cJSON_IsBool (json_input))
+ RELAY_API_DATA(client, sync_input) = (cJSON_IsTrue (json_input)) ? 1 : 0;
json_colors = cJSON_GetObjectItem (json_body, "colors");
if (json_colors && cJSON_IsString (json_colors))
RELAY_API_DATA(client, sync_colors) = relay_api_search_colors (
diff --git a/src/plugins/relay/api/relay-api-protocol.h b/src/plugins/relay/api/relay-api-protocol.h
index 63e930fa2..f1aa8e896 100644
--- a/src/plugins/relay/api/relay-api-protocol.h
+++ b/src/plugins/relay/api/relay-api-protocol.h
@@ -45,6 +45,10 @@ extern int relay_api_protocol_hsignal_nicklist_cb (const void *pointer,
void *data,
const char *signal,
struct t_hashtable *hashtable);
+extern int relay_api_protocol_signal_input_cb (const void *pointer, void *data,
+ const char *signal,
+ const char *type_data,
+ void *signal_data);
extern int relay_api_protocol_signal_upgrade_cb (const void *pointer,
void *data,
const char *signal,
diff --git a/src/plugins/relay/api/relay-api.c b/src/plugins/relay/api/relay-api.c
index fda7d06f3..990ff1425 100644
--- a/src/plugins/relay/api/relay-api.c
+++ b/src/plugins/relay/api/relay-api.c
@@ -121,6 +121,24 @@ relay_api_hook_signals (struct t_relay_client *client)
RELAY_API_DATA(client, hook_hsignal_nicklist) = NULL;
}
}
+ if (RELAY_API_DATA(client, sync_input))
+ {
+ if (!RELAY_API_DATA(client, hook_signal_input))
+ {
+ RELAY_API_DATA(client, hook_signal_input) =
+ weechat_hook_signal ("input_text_changed;input_text_cursor_moved",
+ &relay_api_protocol_signal_input_cb,
+ client, NULL);
+ }
+ }
+ else
+ {
+ if (RELAY_API_DATA(client, hook_signal_input))
+ {
+ weechat_unhook (RELAY_API_DATA(client, hook_signal_input));
+ RELAY_API_DATA(client, hook_signal_input) = NULL;
+ }
+ }
if (!RELAY_API_DATA(client, hook_signal_upgrade))
{
RELAY_API_DATA(client, hook_signal_upgrade) =
@@ -147,6 +165,11 @@ relay_api_unhook_signals (struct t_relay_client *client)
weechat_unhook (RELAY_API_DATA(client, hook_hsignal_nicklist));
RELAY_API_DATA(client, hook_hsignal_nicklist) = NULL;
}
+ if (RELAY_API_DATA(client, hook_signal_input))
+ {
+ weechat_unhook (RELAY_API_DATA(client, hook_signal_input));
+ RELAY_API_DATA(client, hook_signal_input) = NULL;
+ }
if (RELAY_API_DATA(client, hook_signal_upgrade))
{
weechat_unhook (RELAY_API_DATA(client, hook_signal_upgrade));
@@ -204,6 +227,7 @@ relay_api_alloc (struct t_relay_client *client)
RELAY_API_DATA(client, hook_signal_buffer) = NULL;
RELAY_API_DATA(client, hook_hsignal_nicklist) = NULL;
+ RELAY_API_DATA(client, hook_signal_input) = NULL;
RELAY_API_DATA(client, hook_signal_upgrade) = NULL;
RELAY_API_DATA(client, buffers_closing) = weechat_hashtable_new (
32,
@@ -213,6 +237,7 @@ relay_api_alloc (struct t_relay_client *client)
NULL);
RELAY_API_DATA(client, sync_enabled) = 0;
RELAY_API_DATA(client, sync_nicks) = 0;
+ RELAY_API_DATA(client, sync_input) = 0;
RELAY_API_DATA(client, sync_colors) = RELAY_API_COLORS_ANSI;
}
@@ -232,6 +257,7 @@ relay_api_alloc_with_infolist (struct t_relay_client *client,
RELAY_API_DATA(client, hook_signal_buffer) = NULL;
RELAY_API_DATA(client, hook_hsignal_nicklist) = NULL;
+ RELAY_API_DATA(client, hook_signal_input) = NULL;
RELAY_API_DATA(client, hook_signal_upgrade) = NULL;
RELAY_API_DATA(client, buffers_closing) = weechat_hashtable_new (
32,
@@ -243,6 +269,8 @@ relay_api_alloc_with_infolist (struct t_relay_client *client,
infolist, "sync_enabled");
RELAY_API_DATA(client, sync_nicks) = weechat_infolist_integer (
infolist, "sync_nicks");
+ RELAY_API_DATA(client, sync_input) = weechat_infolist_integer (
+ infolist, "sync_input");
RELAY_API_DATA(client, sync_colors) = weechat_infolist_integer (
infolist, "sync_colors");
@@ -281,6 +309,7 @@ relay_api_free (struct t_relay_client *client)
{
weechat_unhook (RELAY_API_DATA(client, hook_signal_buffer));
weechat_unhook (RELAY_API_DATA(client, hook_hsignal_nicklist));
+ weechat_unhook (RELAY_API_DATA(client, hook_signal_input));
weechat_unhook (RELAY_API_DATA(client, hook_signal_upgrade));
weechat_hashtable_free (RELAY_API_DATA(client, buffers_closing));
@@ -317,12 +346,16 @@ relay_api_add_to_infolist (struct t_infolist_item *item,
return 0;
if (!weechat_infolist_new_var_pointer (item, "hook_hsignal_nicklist", RELAY_API_DATA(client, hook_hsignal_nicklist)))
return 0;
+ if (!weechat_infolist_new_var_pointer (item, "hook_signal_input", RELAY_API_DATA(client, hook_signal_input)))
+ return 0;
if (!weechat_infolist_new_var_pointer (item, "hook_signal_upgrade", RELAY_API_DATA(client, hook_signal_upgrade)))
return 0;
if (!weechat_infolist_new_var_integer (item, "sync_enabled", RELAY_API_DATA(client, sync_enabled)))
return 0;
if (!weechat_infolist_new_var_integer (item, "sync_nicks", RELAY_API_DATA(client, sync_nicks)))
return 0;
+ if (!weechat_infolist_new_var_integer (item, "sync_input", RELAY_API_DATA(client, sync_input)))
+ return 0;
if (!weechat_infolist_new_var_integer (item, "sync_colors", RELAY_API_DATA(client, sync_colors)))
return 0;
@@ -340,6 +373,7 @@ relay_api_print_log (struct t_relay_client *client)
{
weechat_log_printf (" hook_signal_buffer. . . : %p", RELAY_API_DATA(client, hook_signal_buffer));
weechat_log_printf (" hook_hsignal_nicklist . : %p", RELAY_API_DATA(client, hook_hsignal_nicklist));
+ weechat_log_printf (" hook_signal_input . . . : %p", RELAY_API_DATA(client, hook_signal_input));
weechat_log_printf (" hook_signal_upgrade . . : %p", RELAY_API_DATA(client, hook_signal_upgrade));
weechat_log_printf (" buffers_closing. . . . .: %p (hashtable: '%s')",
RELAY_API_DATA(client, buffers_closing),
@@ -348,6 +382,7 @@ relay_api_print_log (struct t_relay_client *client)
"keys_values"));
weechat_log_printf (" sync_enabled. . . . . . : %d", RELAY_API_DATA(client, sync_enabled));
weechat_log_printf (" sync_nicks. . . . . . . : %d", RELAY_API_DATA(client, sync_nicks));
+ weechat_log_printf (" sync_input. . . . . . . : %d", RELAY_API_DATA(client, sync_input));
weechat_log_printf (" sync_colors . . . . . . : %d", RELAY_API_DATA(client, sync_colors));
}
}
diff --git a/src/plugins/relay/api/relay-api.h b/src/plugins/relay/api/relay-api.h
index be089ee7b..2bef4723b 100644
--- a/src/plugins/relay/api/relay-api.h
+++ b/src/plugins/relay/api/relay-api.h
@@ -55,10 +55,14 @@ struct t_relay_api_data
{
struct t_hook *hook_signal_buffer; /* hook for signals "buffer_*" */
struct t_hook *hook_hsignal_nicklist; /* hook for hsignals "nicklist_*" */
+ struct t_hook *hook_signal_input; /* hook for signal */
+ /* "input_text_changed" */
struct t_hook *hook_signal_upgrade; /* hook for signals "upgrade*" */
struct t_hashtable *buffers_closing; /* ptr -> "id" of buffers closing */
int sync_enabled; /* 1 if sync is enabled */
int sync_nicks; /* 1 if nicks are synchronized */
+ int sync_input; /* 1 if input is synchronized */
+ /* (WeeChat -> client) */
enum t_relay_api_colors sync_colors; /* colors to send with sync */
};