diff options
author | Sebastien Helleu <flashcode@flashtux.org> | 2011-12-17 17:03:39 +0100 |
---|---|---|
committer | Sebastien Helleu <flashcode@flashtux.org> | 2011-12-17 17:03:39 +0100 |
commit | bd3f554e0228e5aec087b07a269596b487f3a60f (patch) | |
tree | 4861f8e07c16073791a44033450e729b62b64679 /src/plugins/scripts | |
parent | dc8807a4173ccabbe3bb03d3f1d02c8b11580056 (diff) | |
download | weechat-bd3f554e0228e5aec087b07a269596b487f3a60f.zip |
api: add new function hdata_check_pointer
Diffstat (limited to 'src/plugins/scripts')
-rw-r--r-- | src/plugins/scripts/guile/weechat-guile-api.c | 118 | ||||
-rw-r--r-- | src/plugins/scripts/lua/weechat-lua-api.c | 26 | ||||
-rw-r--r-- | src/plugins/scripts/perl/weechat-perl-api.c | 26 | ||||
-rw-r--r-- | src/plugins/scripts/python/weechat-python-api.c | 25 | ||||
-rw-r--r-- | src/plugins/scripts/ruby/weechat-ruby-api.c | 31 | ||||
-rw-r--r-- | src/plugins/scripts/tcl/weechat-tcl-api.c | 29 |
6 files changed, 216 insertions, 39 deletions
diff --git a/src/plugins/scripts/guile/weechat-guile-api.c b/src/plugins/scripts/guile/weechat-guile-api.c index f2e1be9dc..3cc2683de 100644 --- a/src/plugins/scripts/guile/weechat-guile-api.c +++ b/src/plugins/scripts/guile/weechat-guile-api.c @@ -4838,6 +4838,27 @@ weechat_guile_api_hdata_get_list (SCM hdata, SCM name) } /* + * weechat_guile_api_hdata_check_pointer: check pointer with hdata/list + */ + +SCM +weechat_guile_api_hdata_check_pointer (SCM hdata, SCM list, SCM pointer) +{ + int value; + + API_FUNC(1, "hdata_check_pointer", API_RETURN_INT(0)); + if (!scm_is_string (hdata) || !scm_is_string (list) + || !scm_is_string (pointer)) + API_WRONG_ARGS(API_RETURN_INT(0)); + + value = weechat_hdata_check_pointer (script_str2ptr (scm_i_string_chars (hdata)), + script_str2ptr (scm_i_string_chars (list)), + script_str2ptr (scm_i_string_chars (pointer))); + + API_RETURN_INT(value); +} + +/* * weechat_guile_api_hdata_move: move pointer to another element in list */ @@ -5341,6 +5362,7 @@ weechat_guile_api_module_init (void *data) scm_c_define_gsubr ("weechat:hdata_get_var_type_string", 2, 0, 0, &weechat_guile_api_hdata_get_var_type_string); scm_c_define_gsubr ("weechat:hdata_get_var_hdata", 2, 0, 0, &weechat_guile_api_hdata_get_var_hdata); scm_c_define_gsubr ("weechat:hdata_get_list", 2, 0, 0, &weechat_guile_api_hdata_get_list); + scm_c_define_gsubr ("weechat:hdata_check_pointer", 3, 0, 0, &weechat_guile_api_hdata_check_pointer); scm_c_define_gsubr ("weechat:hdata_move", 3, 0, 0, &weechat_guile_api_hdata_move); scm_c_define_gsubr ("weechat:hdata_char", 3, 0, 0, &weechat_guile_api_hdata_char); scm_c_define_gsubr ("weechat:hdata_integer", 3, 0, 0, &weechat_guile_api_hdata_integer); @@ -5361,16 +5383,20 @@ weechat_guile_api_module_init (void *data) "weechat:string_has_highlight", "weechat:string_has_highlight_regex", "weechat:string_mask_to_regex", "weechat:string_remove_color", "weechat:string_is_command_char", "weechat:string_input_for_buffer", - "weechat:mkdir_home", "weechat:mkdir", - "weechat:mkdir_parents", "weechat:list_new", - "weechat:list_add", "weechat:list_search", - "weechat:list_search_pos", "weechat:list_casesearch", - "weechat:list_casesearch_pos", "weechat:list_get", - "weechat:list_set", "weechat:list_next", - "weechat:list_prev", "weechat:list_string", - "weechat:list_size", "weechat:list_remove", - "weechat:list_remove_all", "weechat:list_free", - "weechat:config_new", "weechat:config_new_section", + NULL); + scm_c_export ("weechat:mkdir_home", "weechat:mkdir", + "weechat:mkdir_parents", + NULL); + scm_c_export ("weechat:list_new", "weechat:list_add", + "weechat:list_search", "weechat:list_search_pos", + "weechat:list_casesearch", "weechat:list_casesearch_pos", + "weechat:list_get", "weechat:list_set", + "weechat:list_next", "weechat:list_prev", + "weechat:list_string", "weechat:list_size", + "weechat:list_remove", "weechat:list_remove_all", + "weechat:list_free", + NULL); + scm_c_export ("weechat:config_new", "weechat:config_new_section", "weechat:config_search_section", "weechat:config_new_option", "weechat:config_search_option", "weechat:config_string_to_boolean", "weechat:config_option_reset", "weechat:config_option_set", @@ -5388,11 +5414,14 @@ weechat_guile_api_module_init (void *data) "weechat:config_get", "weechat:config_get_plugin", "weechat:config_is_set_plugin", "weechat:config_set_plugin", "weechat:config_set_desc_plugin", "weechat:config_unset_plugin", - "weechat:key_bind", "weechat:key_unbind", - "weechat:prefix", "weechat:color", + NULL); + scm_c_export ("weechat:key_bind", "weechat:key_unbind", + NULL); + scm_c_export ("weechat:prefix", "weechat:color", "weechat:print", "weechat:print_date_tags", "weechat:print_y", "weechat:log_print", - "weechat:hook_command", "weechat:hook_command_run", + NULL); + scm_c_export ("weechat:hook_command", "weechat:hook_command_run", "weechat:hook_timer", "weechat:hook_fd", "weechat:hook_process", "weechat:hook_connect", "weechat:hook_print", "weechat:hook_signal", @@ -5403,46 +5432,57 @@ weechat_guile_api_module_init (void *data) "weechat:hook_info", "weechat:hook_info_hashtable", "weechat:hook_infolist", "weechat:hook_focus", "weechat:unhook", "weechat:unhook_all", - "weechat:buffer_new", "weechat:buffer_search", + NULL); + scm_c_export ("weechat:buffer_new", "weechat:buffer_search", "weechat:buffer_search_main", "weechat:current_buffer", "weechat:buffer_clear", "weechat:buffer_close", "weechat:buffer_merge", "weechat:buffer_unmerge", "weechat:buffer_get_integer", "weechat:buffer_get_string", "weechat:buffer_get_pointer", "weechat:buffer_set", "weechat:buffer_string_replace_local_var", "weechat:buffer_match_list", - "weechat:current_window", "weechat:window_search_with_buffer", + NULL); + scm_c_export ("weechat:current_window", "weechat:window_search_with_buffer", "weechat:window_get_integer", "weechat:window_get_string", "weechat:window_get_pointer", "weechat:window_set_title", - "weechat:nicklist_add_group", "weechat:nicklist_search_group", + NULL); + scm_c_export ("weechat:nicklist_add_group", "weechat:nicklist_search_group", "weechat:nicklist_add_nick", "weechat:nicklist_search_nick", "weechat:nicklist_remove_group", "weechat:nicklist_remove_nick", "weechat:nicklist_remove_all", "weechat:nicklist_group_get_integer", "weechat:nicklist_group_get_string", "weechat:nicklist_group_get_pointer", "weechat:nicklist_group_set", "weechat:nicklist_nick_get_integer", "weechat:nicklist_nick_get_string", "weechat:nicklist_nick_get_pointer", - "weechat:nicklist_nick_set", "weechat:bar_item_search", - "weechat:bar_item_new", "weechat:bar_item_update", - "weechat:bar_item_remove", "weechat:bar_search", - "weechat:bar_new", "weechat:bar_set", - "weechat:bar_update", "weechat:bar_remove", - "weechat:command", "weechat:info_get", - "weechat:info_get_hashtable", "weechat:infolist_new", - "weechat:infolist_new_item", "weechat:infolist_new_var_integer", - "weechat:infolist_new_var_string", "weechat:infolist_new_var_pointer", - "weechat:infolist_new_var_time", "weechat:infolist_get", - "weechat:infolist_next", "weechat:infolist_prev", - "weechat:infolist_reset_item_cursor", "weechat:infolist_fields", - "weechat:infolist_integer", "weechat:infolist_string", - "weechat:infolist_pointer", "weechat:infolist_time", - "weechat:infolist_free", "weechat:hdata_get", - "weechat:hdata_get_var_offset", "weechat:hdata_get_var_type_string", - "weechat:hdata_get_var_hdata", "weechat:hdata_get_list", - "weechat:hdata_move", "weechat:hdata_integer", - "weechat:hdata_long", "weechat:hdata_string", - "weechat:hdata_pointer", "weechat:hdata_time", - "weechat:hdata_get_string", "weechat:upgrade_new", - "weechat:upgrade_write_object", "weechat:upgrade_read", - "weechat:upgrade_close", + "weechat:nicklist_nick_set", + NULL); + scm_c_export ("weechat:bar_item_search", "weechat:bar_item_new", + "weechat:bar_item_update", "weechat:bar_item_remove", + "weechat:bar_search", "weechat:bar_new", + "weechat:bar_set", "weechat:bar_update", + "weechat:bar_remove", + NULL); + scm_c_export ("weechat:command", + NULL); + scm_c_export ("weechat:info_get", "weechat:info_get_hashtable", + NULL); + scm_c_export ("weechat:infolist_new", "weechat:infolist_new_item", + "weechat:infolist_new_var_integer", "weechat:infolist_new_var_string", + "weechat:infolist_new_var_pointer", "weechat:infolist_new_var_time", + "weechat:infolist_get", "weechat:infolist_next", + "weechat:infolist_prev", "weechat:infolist_reset_item_cursor", + "weechat:infolist_fields", "weechat:infolist_integer", + "weechat:infolist_string", "weechat:infolist_pointer", + "weechat:infolist_time", "weechat:infolist_free", + NULL); + scm_c_export ("weechat:hdata_get", "weechat:hdata_get_var_offset", + "weechat:hdata_get_var_type_string", "weechat:hdata_get_var_hdata", + "weechat:hdata_get_list", "weechat:hdata_check_pointer", + "weechat:hdata_move", "weechat:hdata_char", + "weechat:hdata_integer", "weechat:hdata_long", + "weechat:hdata_string", "weechat:hdata_pointer", + "weechat:hdata_time", "weechat:hdata_get_string", + NULL); + scm_c_export ("weechat:upgrade_new", "weechat:upgrade_write_object", + "weechat:upgrade_read", "weechat:upgrade_close", NULL); /* interface constants */ diff --git a/src/plugins/scripts/lua/weechat-lua-api.c b/src/plugins/scripts/lua/weechat-lua-api.c index a9d3ed861..1f59ba5b0 100644 --- a/src/plugins/scripts/lua/weechat-lua-api.c +++ b/src/plugins/scripts/lua/weechat-lua-api.c @@ -5330,6 +5330,31 @@ weechat_lua_api_hdata_get_list (lua_State *L) } /* + * weechat_lua_api_hdata_check_pointer: check pointer with hdata/list + */ + +static int +weechat_lua_api_hdata_check_pointer (lua_State *L) +{ + const char *hdata, *list, *pointer; + int value; + + API_FUNC(1, "hdata_check_pointer", API_RETURN_INT(0)); + if (lua_gettop (lua_current_interpreter) < 3) + API_WRONG_ARGS(API_RETURN_INT(0)); + + hdata = lua_tostring (lua_current_interpreter, -3); + list = lua_tostring (lua_current_interpreter, -2); + pointer = lua_tostring (lua_current_interpreter, -1); + + value = weechat_hdata_check_pointer (script_str2ptr (hdata), + script_str2ptr (list), + script_str2ptr (pointer)); + + API_RETURN_INT(value); +} + +/* * weechat_lua_api_hdata_move: move pointer to another element in list */ @@ -6238,6 +6263,7 @@ const struct luaL_reg weechat_lua_api_funcs[] = { { "hdata_get_var_type_string", &weechat_lua_api_hdata_get_var_type_string }, { "hdata_get_var_hdata", &weechat_lua_api_hdata_get_var_hdata }, { "hdata_get_list", &weechat_lua_api_hdata_get_list }, + { "hdata_check_pointer", &weechat_lua_api_hdata_check_pointer }, { "hdata_move", &weechat_lua_api_hdata_move }, { "hdata_char", &weechat_lua_api_hdata_char }, { "hdata_integer", &weechat_lua_api_hdata_integer }, diff --git a/src/plugins/scripts/perl/weechat-perl-api.c b/src/plugins/scripts/perl/weechat-perl-api.c index bae033256..ea9491389 100644 --- a/src/plugins/scripts/perl/weechat-perl-api.c +++ b/src/plugins/scripts/perl/weechat-perl-api.c @@ -5070,6 +5070,31 @@ XS (XS_weechat_api_hdata_get_list) } /* + * weechat::hdata_check_pointer: check pointer with hdata/list + */ + +XS (XS_weechat_api_hdata_check_pointer) +{ + char *hdata, *list, *pointer; + int value; + dXSARGS; + + API_FUNC(1, "hdata_check_pointer", API_RETURN_INT(0)); + if (items < 3) + API_WRONG_ARGS(API_RETURN_INT(0)); + + hdata = SvPV_nolen (ST (0)); + list = SvPV_nolen (ST (1)); + pointer = SvPV_nolen (ST (2)); + + value = weechat_hdata_check_pointer (script_str2ptr (hdata), + script_str2ptr (list), + script_str2ptr (pointer)); + + API_RETURN_INT(value); +} + +/* * weechat::hdata_move: move pointer to another element in list */ @@ -5595,6 +5620,7 @@ weechat_perl_api_init (pTHX) newXS ("weechat::hdata_get_var_type_string", XS_weechat_api_hdata_get_var_type_string, "weechat"); newXS ("weechat::hdata_get_var_hdata", XS_weechat_api_hdata_get_var_hdata, "weechat"); newXS ("weechat::hdata_get_list", XS_weechat_api_hdata_get_list, "weechat"); + newXS ("weechat::hdata_check_pointer", XS_weechat_api_hdata_check_pointer, "weechat"); newXS ("weechat::hdata_move", XS_weechat_api_hdata_move, "weechat"); newXS ("weechat::hdata_char", XS_weechat_api_hdata_char, "weechat"); newXS ("weechat::hdata_integer", XS_weechat_api_hdata_integer, "weechat"); diff --git a/src/plugins/scripts/python/weechat-python-api.c b/src/plugins/scripts/python/weechat-python-api.c index c02716c73..0048ee518 100644 --- a/src/plugins/scripts/python/weechat-python-api.c +++ b/src/plugins/scripts/python/weechat-python-api.c @@ -5250,6 +5250,30 @@ weechat_python_api_hdata_get_list (PyObject *self, PyObject *args) } /* + * weechat_python_api_hdata_check_pointer: check pointer with hdata/list + */ + +static PyObject * +weechat_python_api_hdata_check_pointer (PyObject *self, PyObject *args) +{ + char *hdata, *list, *pointer; + int value; + + API_FUNC(1, "hdata_check_pointer", API_RETURN_INT(0)); + hdata = NULL; + list = NULL; + pointer = NULL; + if (!PyArg_ParseTuple (args, "sss", &hdata, &list, &pointer)) + API_WRONG_ARGS(API_RETURN_INT(0)); + + value = weechat_hdata_check_pointer (script_str2ptr (hdata), + script_str2ptr (list), + script_str2ptr (pointer)); + + API_RETURN_INT(value); +} + +/* * weechat_python_api_hdata_move: move pointer to another element in list */ @@ -5765,6 +5789,7 @@ PyMethodDef weechat_python_funcs[] = { "hdata_get_var_type_string", &weechat_python_api_hdata_get_var_type_string, METH_VARARGS, "" }, { "hdata_get_var_hdata", &weechat_python_api_hdata_get_var_hdata, METH_VARARGS, "" }, { "hdata_get_list", &weechat_python_api_hdata_get_list, METH_VARARGS, "" }, + { "hdata_check_pointer", &weechat_python_api_hdata_check_pointer, METH_VARARGS, "" }, { "hdata_move", &weechat_python_api_hdata_move, METH_VARARGS, "" }, { "hdata_char", &weechat_python_api_hdata_char, METH_VARARGS, "" }, { "hdata_integer", &weechat_python_api_hdata_integer, METH_VARARGS, "" }, diff --git a/src/plugins/scripts/ruby/weechat-ruby-api.c b/src/plugins/scripts/ruby/weechat-ruby-api.c index 3ffb20bdf..21c52923b 100644 --- a/src/plugins/scripts/ruby/weechat-ruby-api.c +++ b/src/plugins/scripts/ruby/weechat-ruby-api.c @@ -6029,6 +6029,36 @@ weechat_ruby_api_hdata_get_list (VALUE class, VALUE hdata, VALUE name) } /* + * weechat_ruby_api_hdata_check_pointer: check pointer with hdata/list + */ + +static VALUE +weechat_ruby_api_hdata_check_pointer (VALUE class, VALUE hdata, VALUE list, + VALUE pointer) +{ + char *c_hdata, *c_list, *c_pointer; + int value; + + API_FUNC(1, "hdata_check_pointer", API_RETURN_INT(0)); + if (NIL_P (hdata) || NIL_P (list) || NIL_P (pointer)) + API_WRONG_ARGS(API_RETURN_INT(0)); + + Check_Type (hdata, T_STRING); + Check_Type (list, T_STRING); + Check_Type (pointer, T_STRING); + + c_hdata = StringValuePtr (hdata); + c_list = StringValuePtr (list); + c_pointer = StringValuePtr (pointer); + + value = weechat_hdata_check_pointer (script_str2ptr (c_hdata), + script_str2ptr (c_list), + script_str2ptr (c_pointer)); + + API_RETURN_INT(value); +} + +/* * weechat_ruby_api_hdata_move: move pointer to another element in list */ @@ -6657,6 +6687,7 @@ weechat_ruby_api_init (VALUE ruby_mWeechat) rb_define_module_function (ruby_mWeechat, "hdata_get_var_type_string", &weechat_ruby_api_hdata_get_var_type_string, 2); rb_define_module_function (ruby_mWeechat, "hdata_get_var_hdata", &weechat_ruby_api_hdata_get_var_hdata, 2); rb_define_module_function (ruby_mWeechat, "hdata_get_list", &weechat_ruby_api_hdata_get_list, 2); + rb_define_module_function (ruby_mWeechat, "hdata_check_pointer", &weechat_ruby_api_hdata_check_pointer, 3); rb_define_module_function (ruby_mWeechat, "hdata_move", &weechat_ruby_api_hdata_move, 3); rb_define_module_function (ruby_mWeechat, "hdata_char", &weechat_ruby_api_hdata_char, 3); rb_define_module_function (ruby_mWeechat, "hdata_integer", &weechat_ruby_api_hdata_integer, 3); diff --git a/src/plugins/scripts/tcl/weechat-tcl-api.c b/src/plugins/scripts/tcl/weechat-tcl-api.c index c8f797185..81b9cb5ce 100644 --- a/src/plugins/scripts/tcl/weechat-tcl-api.c +++ b/src/plugins/scripts/tcl/weechat-tcl-api.c @@ -5773,6 +5773,33 @@ weechat_tcl_api_hdata_get_list (ClientData clientData, Tcl_Interp *interp, } /* + * weechat_tcl_api_hdata_check_pointer: check pointer with hdata/list + */ + +static int +weechat_tcl_api_hdata_check_pointer (ClientData clientData, Tcl_Interp *interp, + int objc, Tcl_Obj *CONST objv[]) +{ + Tcl_Obj *objp; + char *hdata, *list, *pointer; + int result, i; + + API_FUNC(1, "hdata_check_pointer", API_RETURN_INT(0)); + if (objc < 4) + API_WRONG_ARGS(API_RETURN_INT(0)); + + hdata = Tcl_GetStringFromObj (objv[1], &i); + list = Tcl_GetStringFromObj (objv[2], &i); + pointer = Tcl_GetStringFromObj (objv[3], &i); + + result = weechat_hdata_check_pointer (script_str2ptr (hdata), + script_str2ptr (list), + script_str2ptr (pointer)); + + API_RETURN_INT(result); +} + +/* * weechat_tcl_api_hdata_move: move pointer to another element in list */ @@ -6568,6 +6595,8 @@ void weechat_tcl_api_init (Tcl_Interp *interp) weechat_tcl_api_hdata_get_var_hdata, (ClientData)NULL, (Tcl_CmdDeleteProc*)NULL); Tcl_CreateObjCommand (interp, "weechat::hdata_get_list", weechat_tcl_api_hdata_get_list, (ClientData)NULL, (Tcl_CmdDeleteProc*)NULL); + Tcl_CreateObjCommand (interp, "weechat::hdata_check_pointer", + weechat_tcl_api_hdata_check_pointer, (ClientData)NULL, (Tcl_CmdDeleteProc*)NULL); Tcl_CreateObjCommand (interp, "weechat::hdata_move", weechat_tcl_api_hdata_move, (ClientData)NULL, (Tcl_CmdDeleteProc*)NULL); Tcl_CreateObjCommand (interp, "weechat::hdata_integer", |