# HG changeset patch # User Kim Alvefur # Date 1602774843 -7200 # Node ID cbe1edecb8fa0641dc5fc8da9051893af4e4861b # Parent 4bda303d54ed30c9445bd68a3c959522390410f8# Parent 712b2e6a09d95ca98cab0dc2128e43736d8ceff7 Merge 0.11->trunk diff -r 4bda303d54ed -r cbe1edecb8fa util-src/strbitop.c --- a/util-src/strbitop.c Thu Oct 15 16:51:16 2020 +0200 +++ b/util-src/strbitop.c Thu Oct 15 17:14:03 2020 +0200 @@ -2,7 +2,7 @@ * This project is MIT licensed. Please see the * COPYING file in the source package for more information. * - * Copyright (C) 2016-2020 Kim Alvefur + * Copyright (C) 2016 Kim Alvefur */ #include @@ -20,25 +20,39 @@ const char *str_a = luaL_checklstring(L, 1, &a); const char *str_b = luaL_checklstring(L, 2, &b); - luaL_buffinit(L, &buf); + if(a == 0 || b == 0) { + lua_settop(L, 1); + return 1; + } + + for(i = 0; i < a; i++) { + luaL_addchar(&buf, str_a[i] & str_b[i % b]); + } + + luaL_pushresult(&buf); + return 1; +} + +int strop_or(lua_State *L) { + luaL_Buffer buf; + size_t a, b, i; + const char *str_a = luaL_checklstring(L, 1, &a); + const char *str_b = luaL_checklstring(L, 2, &b); if(a == 0 || b == 0) { lua_settop(L, 1); return 1; } - char *cbuf = luaL_buffinitsize(L, &buf, a); - for(i = 0; i < a; i++) { - cbuf[i] = str_a[i] & str_b[i % b]; + luaL_addchar(&buf, str_a[i] | str_b[i % b]); } - luaL_addsize(&buf, a); luaL_pushresult(&buf); return 1; } -int strop_or(lua_State *L) { +int strop_xor(lua_State *L) { luaL_Buffer buf; size_t a, b, i; const char *str_a = luaL_checklstring(L, 1, &a); @@ -51,35 +65,10 @@ return 1; } - char *cbuf = luaL_buffinitsize(L, &buf, a); - for(i = 0; i < a; i++) { - cbuf[i] = str_a[i] | str_b[i % b]; + luaL_addchar(&buf, str_a[i] ^ str_b[i % b]); } - luaL_addsize(&buf, a); - luaL_pushresult(&buf); - return 1; -} - -int strop_xor(lua_State *L) { - luaL_Buffer buf; - size_t a, b, i; - const char *str_a = luaL_checklstring(L, 1, &a); - const char *str_b = luaL_checklstring(L, 2, &b); - - if(a == 0 || b == 0) { - lua_settop(L, 1); - return 1; - } - - char *cbuf = luaL_buffinitsize(L, &buf, a); - - for(i = 0; i < a; i++) { - cbuf[i] = str_a[i] ^ str_b[i % b]; - } - - luaL_addsize(&buf, a); luaL_pushresult(&buf); return 1; }