From: Vsevolod Stakhov Date: Mon, 7 Mar 2016 15:14:01 +0000 (+0000) Subject: [Feature] Add lua functions for caseless comparison X-Git-Tag: 1.2.0~104 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=76740965ccff2563afb08e37ce0185003bc2063b;p=thirdparty%2Frspamd.git [Feature] Add lua functions for caseless comparison --- diff --git a/src/lua/lua_util.c b/src/lua/lua_util.c index 04bf76942b..0707f098cc 100644 --- a/src/lua/lua_util.c +++ b/src/lua/lua_util.c @@ -193,6 +193,36 @@ LUA_FUNCTION_DEF (util, parse_mail_address); */ LUA_FUNCTION_DEF (util, strlen_utf8); +/*** + * @function util.strcasecmp(str1, str2) + * Compares two utf8 strings regardless of their case. Return value >0, 0 and <0 + * if `str1` is more, equal or less than `str2` + * @param {string} str1 utf8 encoded string + * @param {string} str2 utf8 encoded string + * @return {number} result of comparison + */ +LUA_FUNCTION_DEF (util, strcasecmp_utf8); + +/*** + * @function util.strcasecmp(str1, str2) + * Compares two ascii strings regardless of their case. Return value >0, 0 and <0 + * if `str1` is more, equal or less than `str2` + * @param {string} str1 plain string + * @param {string} str2 plain string + * @return {number} result of comparison + */ +LUA_FUNCTION_DEF (util, strcasecmp_ascii); + +/*** + * @function util.strequal_caseless(str1, str2) + * Compares two utf8 strings regardless of their case. Return `true` if `str1` is + * equal to `str2` + * @param {string} str1 utf8 encoded string + * @param {string} str2 utf8 encoded string + * @return {bool} result of comparison + */ +LUA_FUNCTION_DEF (util, strequal_caseless); + static const struct luaL_reg utillib_f[] = { LUA_INTERFACE_DEF (util, create_event_base), LUA_INTERFACE_DEF (util, load_rspamd_config), @@ -214,6 +244,9 @@ static const struct luaL_reg utillib_f[] = { LUA_INTERFACE_DEF (util, glob), LUA_INTERFACE_DEF (util, parse_mail_address), LUA_INTERFACE_DEF (util, strlen_utf8), + LUA_INTERFACE_DEF (util, strcasecmp_utf8), + LUA_INTERFACE_DEF (util, strcasecmp_ascii), + LUA_INTERFACE_DEF (util, strequal_caseless), {NULL, NULL} }; @@ -941,6 +974,87 @@ lua_util_strlen_utf8 (lua_State *L) return 1; } +static gint +lua_util_strcasecmp_utf8 (lua_State *L) +{ + const gchar *str1, *str2; + gsize len1, len2; + gint ret = -1; + + str1 = lua_tolstring (L, 1, &len1); + str2 = lua_tolstring (L, 1, &len2); + + if (str1 && str2) { + + if (len1 == len2) { + ret = rspamd_lc_cmp (str1, str2, len1); + } + else { + ret = len1 - len2; + } + } + else { + return luaL_error (L, "invalid arguments"); + } + + lua_pushnumber (L, ret); + return 1; +} + +static gint +lua_util_strcasecmp_ascii (lua_State *L) +{ + const gchar *str1, *str2; + gsize len1, len2; + gint ret = -1; + + str1 = lua_tolstring (L, 1, &len1); + str2 = lua_tolstring (L, 1, &len2); + + if (str1 && str2) { + + if (len1 == len2) { + ret = g_ascii_strncasecmp (str1, str2, len1); + } + else { + ret = len1 - len2; + } + } + else { + return luaL_error (L, "invalid arguments"); + } + + lua_pushnumber (L, ret); + return 1; +} + +static gint +lua_util_strequal_caseless (lua_State *L) +{ + const gchar *str1, *str2; + gsize len1, len2; + gint ret = -1; + + str1 = lua_tolstring (L, 1, &len1); + str2 = lua_tolstring (L, 1, &len2); + + if (str1 && str2) { + + if (len1 == len2) { + ret = rspamd_lc_cmp (str1, str2, len1); + } + else { + ret = len1 - len2; + } + } + else { + return luaL_error (L, "invalid arguments"); + } + + lua_pushboolean (L, (ret == 0)); + return 1; +} + static gint lua_load_util (lua_State * L) {