summaryrefslogtreecommitdiff
path: root/src/plugins/ruby
diff options
context:
space:
mode:
authorSébastien Helleu <flashcode@flashtux.org>2023-09-08 17:07:03 +0200
committerSébastien Helleu <flashcode@flashtux.org>2023-09-16 13:00:03 +0200
commitfb00bc1f4b9ede63153cf55ceb38d0fdcb39786c (patch)
treee95b3f0c70d0fc3a8b00b2c97bf88dae21032c34 /src/plugins/ruby
parent24d2ba3338c8467a51ce28eccb05937603e3e6cc (diff)
downloadweechat-fb00bc1f4b9ede63153cf55ceb38d0fdcb39786c.zip
scripts: add function hook_url in scripting API
Diffstat (limited to 'src/plugins/ruby')
-rw-r--r--src/plugins/ruby/weechat-ruby-api.c87
1 files changed, 87 insertions, 0 deletions
diff --git a/src/plugins/ruby/weechat-ruby-api.c b/src/plugins/ruby/weechat-ruby-api.c
index 873aa86c1..9716dc5be 100644
--- a/src/plugins/ruby/weechat-ruby-api.c
+++ b/src/plugins/ruby/weechat-ruby-api.c
@@ -3153,6 +3153,92 @@ weechat_ruby_api_hook_process_hashtable (VALUE class, VALUE command,
}
int
+weechat_ruby_api_hook_url_cb (const void *pointer, void *data,
+ const char *url,
+ struct t_hashtable *options,
+ struct t_hashtable *output)
+{
+ struct t_plugin_script *script;
+ void *func_argv[4];
+ char empty_arg[1] = { '\0' };
+ const char *ptr_function, *ptr_data;
+ int *rc, ret;
+
+ script = (struct t_plugin_script *)pointer;
+ plugin_script_get_function_and_data (data, &ptr_function, &ptr_data);
+
+ if (ptr_function && ptr_function[0])
+ {
+ func_argv[0] = (ptr_data) ? (char *)ptr_data : empty_arg;
+ func_argv[1] = (url) ? (char *)url : empty_arg;
+ func_argv[2] = options;
+ func_argv[3] = output;
+
+ rc = (int *) weechat_ruby_exec (script,
+ WEECHAT_SCRIPT_EXEC_INT,
+ ptr_function,
+ "sshh", func_argv);
+
+ if (!rc)
+ ret = WEECHAT_RC_ERROR;
+ else
+ {
+ ret = *rc;
+ free (rc);
+ }
+
+ return ret;
+ }
+
+ return WEECHAT_RC_ERROR;
+}
+
+static VALUE
+weechat_ruby_api_hook_url (VALUE class, VALUE url,
+ VALUE options, VALUE timeout,
+ VALUE function, VALUE data)
+{
+ char *c_url, *c_function, *c_data;
+ const char *result;
+ struct t_hashtable *c_options;
+ int c_timeout;
+
+ API_INIT_FUNC(1, "hook_url", API_RETURN_EMPTY);
+ if (NIL_P (url) || NIL_P (options) || NIL_P (timeout)
+ || NIL_P (function) || NIL_P (data))
+ API_WRONG_ARGS(API_RETURN_EMPTY);
+
+ Check_Type (url, T_STRING);
+ Check_Type (options, T_HASH);
+ CHECK_INTEGER(timeout);
+ Check_Type (function, T_STRING);
+ Check_Type (data, T_STRING);
+
+ c_url = StringValuePtr (url);
+ c_options = weechat_ruby_hash_to_hashtable (options,
+ WEECHAT_SCRIPT_HASHTABLE_DEFAULT_SIZE,
+ WEECHAT_HASHTABLE_STRING,
+ WEECHAT_HASHTABLE_STRING);
+ c_timeout = NUM2INT (timeout);
+ c_function = StringValuePtr (function);
+ c_data = StringValuePtr (data);
+
+ result = API_PTR2STR(plugin_script_api_hook_url (weechat_ruby_plugin,
+ ruby_current_script,
+ c_url,
+ c_options,
+ c_timeout,
+ &weechat_ruby_api_hook_url_cb,
+ c_function,
+ c_data));
+
+ if (c_options)
+ weechat_hashtable_free (c_options);
+
+ API_RETURN_STRING(result);
+}
+
+int
weechat_ruby_api_hook_connect_cb (const void *pointer, void *data,
int status, int gnutls_rc,
int sock, const char *error,
@@ -6764,6 +6850,7 @@ weechat_ruby_api_init (VALUE ruby_mWeechat)
API_DEF_FUNC(hook_fd, 6);
API_DEF_FUNC(hook_process, 4);
API_DEF_FUNC(hook_process_hashtable, 5);
+ API_DEF_FUNC(hook_url, 5);
API_DEF_FUNC(hook_connect, 8);
API_DEF_FUNC(hook_line, 5);
API_DEF_FUNC(hook_print, 6);