mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
Merge 0.11->trunk
This commit is contained in:
commit
66f3fe9d12
2 changed files with 63 additions and 15 deletions
41
spec/util_strbitop.lua
Normal file
41
spec/util_strbitop.lua
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
local strbitop = require "util.strbitop";
|
||||||
|
describe("util.strbitop", function ()
|
||||||
|
describe("sand()", function ()
|
||||||
|
it("works", function ()
|
||||||
|
assert.equal(string.rep("Aa", 100), strbitop.sand(string.rep("a", 200), "Aa"));
|
||||||
|
end);
|
||||||
|
it("returns empty string if first argument is empty", function ()
|
||||||
|
assert.equal("", strbitop.sand("", ""));
|
||||||
|
assert.equal("", strbitop.sand("", "key"));
|
||||||
|
end);
|
||||||
|
it("returns initial string if key is empty", function ()
|
||||||
|
assert.equal("hello", strbitop.sand("hello", ""));
|
||||||
|
end);
|
||||||
|
end);
|
||||||
|
|
||||||
|
describe("sor()", function ()
|
||||||
|
it("works", function ()
|
||||||
|
assert.equal(string.rep("a", 200), strbitop.sor(string.rep("Aa", 100), "a"));
|
||||||
|
end);
|
||||||
|
it("returns empty string if first argument is empty", function ()
|
||||||
|
assert.equal("", strbitop.sor("", ""));
|
||||||
|
assert.equal("", strbitop.sor("", "key"));
|
||||||
|
end);
|
||||||
|
it("returns initial string if key is empty", function ()
|
||||||
|
assert.equal("hello", strbitop.sor("hello", ""));
|
||||||
|
end);
|
||||||
|
end);
|
||||||
|
|
||||||
|
describe("sxor()", function ()
|
||||||
|
it("works", function ()
|
||||||
|
assert.equal(string.rep("Aa", 100), strbitop.sxor(string.rep("a", 200), " \0"));
|
||||||
|
end);
|
||||||
|
it("returns empty string if first argument is empty", function ()
|
||||||
|
assert.equal("", strbitop.sxor("", ""));
|
||||||
|
assert.equal("", strbitop.sxor("", "key"));
|
||||||
|
end);
|
||||||
|
it("returns initial string if key is empty", function ()
|
||||||
|
assert.equal("hello", strbitop.sxor("hello", ""));
|
||||||
|
end);
|
||||||
|
end);
|
||||||
|
end);
|
|
@ -2,7 +2,7 @@
|
||||||
* This project is MIT licensed. Please see the
|
* This project is MIT licensed. Please see the
|
||||||
* COPYING file in the source package for more information.
|
* COPYING file in the source package for more information.
|
||||||
*
|
*
|
||||||
* Copyright (C) 2016 Kim Alvefur
|
* Copyright (C) 2016-2020 Kim Alvefur
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <lua.h>
|
#include <lua.h>
|
||||||
|
@ -14,11 +14,11 @@
|
||||||
|
|
||||||
/* TODO Deduplicate code somehow */
|
/* TODO Deduplicate code somehow */
|
||||||
|
|
||||||
int strop_and(lua_State* L) {
|
int strop_and(lua_State *L) {
|
||||||
luaL_Buffer buf;
|
luaL_Buffer buf;
|
||||||
size_t a, b, i;
|
size_t a, b, i;
|
||||||
const char* str_a = luaL_checklstring(L, 1, &a);
|
const char *str_a = luaL_checklstring(L, 1, &a);
|
||||||
const char* str_b = luaL_checklstring(L, 2, &b);
|
const char *str_b = luaL_checklstring(L, 2, &b);
|
||||||
|
|
||||||
luaL_buffinit(L, &buf);
|
luaL_buffinit(L, &buf);
|
||||||
|
|
||||||
|
@ -27,19 +27,22 @@ int strop_and(lua_State* L) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *cbuf = luaL_buffinitsize(L, &buf, a);
|
||||||
|
|
||||||
for(i = 0; i < a; i++) {
|
for(i = 0; i < a; i++) {
|
||||||
luaL_addchar(&buf, str_a[i] & str_b[i % b]);
|
cbuf[i] = str_a[i] & str_b[i % b];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
luaL_addsize(&buf, a);
|
||||||
luaL_pushresult(&buf);
|
luaL_pushresult(&buf);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int strop_or(lua_State* L) {
|
int strop_or(lua_State *L) {
|
||||||
luaL_Buffer buf;
|
luaL_Buffer buf;
|
||||||
size_t a, b, i;
|
size_t a, b, i;
|
||||||
const char* str_a = luaL_checklstring(L, 1, &a);
|
const char *str_a = luaL_checklstring(L, 1, &a);
|
||||||
const char* str_b = luaL_checklstring(L, 2, &b);
|
const char *str_b = luaL_checklstring(L, 2, &b);
|
||||||
|
|
||||||
luaL_buffinit(L, &buf);
|
luaL_buffinit(L, &buf);
|
||||||
|
|
||||||
|
@ -48,31 +51,35 @@ int strop_or(lua_State* L) {
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *cbuf = luaL_buffinitsize(L, &buf, a);
|
||||||
|
|
||||||
for(i = 0; i < a; i++) {
|
for(i = 0; i < a; i++) {
|
||||||
luaL_addchar(&buf, str_a[i] | str_b[i % b]);
|
cbuf[i] = str_a[i] | str_b[i % b];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
luaL_addsize(&buf, a);
|
||||||
luaL_pushresult(&buf);
|
luaL_pushresult(&buf);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int strop_xor(lua_State* L) {
|
int strop_xor(lua_State *L) {
|
||||||
luaL_Buffer buf;
|
luaL_Buffer buf;
|
||||||
size_t a, b, i;
|
size_t a, b, i;
|
||||||
const char* str_a = luaL_checklstring(L, 1, &a);
|
const char *str_a = luaL_checklstring(L, 1, &a);
|
||||||
const char* str_b = luaL_checklstring(L, 2, &b);
|
const char *str_b = luaL_checklstring(L, 2, &b);
|
||||||
|
|
||||||
luaL_buffinit(L, &buf);
|
|
||||||
|
|
||||||
if(a == 0 || b == 0) {
|
if(a == 0 || b == 0) {
|
||||||
lua_settop(L, 1);
|
lua_settop(L, 1);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
char *cbuf = luaL_buffinitsize(L, &buf, a);
|
||||||
|
|
||||||
for(i = 0; i < a; i++) {
|
for(i = 0; i < a; i++) {
|
||||||
luaL_addchar(&buf, str_a[i] ^ str_b[i % b]);
|
cbuf[i] = str_a[i] ^ str_b[i % b];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
luaL_addsize(&buf, a);
|
||||||
luaL_pushresult(&buf);
|
luaL_pushresult(&buf);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue