# HG changeset patch # User Thomas Harning Jr # Date 1189136446 14400 # Node ID 0d82e4f49a56c9a60d806ddab2f0c032f3041e40 # Parent a117895e867c66ec3edcd63b1e2b3c00195dfdb2 Updated changelog. event_buffer learned `get_data`,`length`,`drain`,`close`,`new` diff -r a117895e867c -r 0d82e4f49a56 CHANGELOG --- a/CHANGELOG Thu Sep 06 23:22:55 2007 -0400 +++ b/CHANGELOG Thu Sep 06 23:40:46 2007 -0400 @@ -1,3 +1,11 @@ +0.2.0 - 2007-*-* + + Reorganized project to better fit GIT + + Refactored and cleaned sources + * Broke event_callback into its own source file + + Added timer/timeout capabilities + minor test + + Added event_buffer object + * Can 'add' a sequence of strings/event_buffers + * Can 'get_data', 'length','drain','close' and create new instances ====== 0.1.2 - 2007-08-18 + Setup system to use new coro management as described in COROUTINE_MANAGEMENT diff -r a117895e867c -r 0d82e4f49a56 src/event_buffer.c --- a/src/event_buffer.c Thu Sep 06 23:22:55 2007 -0400 +++ b/src/event_buffer.c Thu Sep 06 23:40:46 2007 -0400 @@ -11,6 +11,12 @@ static le_buffer* event_buffer_get(lua_State* L, int idx) { return (le_buffer*)luaL_checkudata(L, idx, EVENT_BUFFER_MT); } +static void event_buffer_check(lua_State* L, int idx) { + le_buffer* buf = (le_buffer*)luaL_checkudata(L, idx, EVENT_BUFFER_MT); + if(!buf->buffer) + luaL_argerror(L, idx, "Attempt to use closed event_buffer object"); + return buf; +} static int is_event_buffer(lua_State* L, int idx) { int ret; lua_getmetatable(L, idx); @@ -20,14 +26,36 @@ return ret; } +/* TODO: Use lightuserdata mapping to locate hanging object instances */ +static int event_buffer_push(lua_State* L, struct evbuffer* buffer) { + le_buffer *buf = (le_buffer*)lua_newuserdata(L, sizeof(le_buffer)); + buf->buffer = buffer; + luaL_getmetatable(L, EVENT_BUFFER_MT); + lua_setmetatable(L, -2); + return 1; +} + +static int event_buffer_push_new(lua_State* L) { + return event_buffer_push(L, evbuffer_new()); +} + +static int event_buffer_gc(lua_State* L) { + le_buffer* buf = event_buffer_get(L, 1); + if(buf->buffer) { + evbuffer_free(buf->buffer); + buf->buffer = NULL; + } + return 0; +} + /* LUA: buffer:add(...) progressively adds items to the buffer if arg[*] is string, treat as a string:format call if arg[*] is a buffer, perform event_add_buffer returns number of bytes added */ -int event_buffer_add(lua_State* L) { - le_buffer* buf = event_buffer_get(L, 1); +static int event_buffer_add(lua_State* L) { + le_buffer* buf = event_buffer_check(L, 1); struct evbuffer* buffer = buf->buffer; int oldLength = EVBUFFER_LENGTH(buffer); int last = lua_top(L); @@ -46,7 +74,7 @@ if(0 != evbuffer_add(buffer, data, len)) luaL_error(L, "Failed to add data to the buffer"); } else { - le_buffer* buf2 = event_buffer_get(L, i); + le_buffer* buf2 = event_buffer_check(L, i); if(0 != evbuffer_add_buffer(buffer, buf2->buffer)) luaL_error(L, "Failed to move buffer-data to the buffer"); } @@ -55,16 +83,43 @@ return 1; } +static int event_buffer_get_length(lua_State* L) { + le_buffer* buf = event_buffer_check(L, 1); + lua_pushinteger(L, EVBUFFER_LENGTH(buf->buffer)); + return 1; +} + +/* MAYBE: Could add caching */ +static int event_buffer_get_data(lua_State* L) { + le_buffer* buf = event_buffer_check(L, 1); + lua_pushlstring(L, EVBUFFER_DATA(buf->buffer), EVBUFFER_LENGTH(buf->buffer)); + return 1; +} + +static int event_buffer_drain(lua_State* L) { + le_buffer* buf = event_buffer_check(L, 1); + size_t len = luaL_checkinteger(L, 2); + evbuffer_drain(buf->buffer, len); + return 0; +} + static luaL_Reg buffer_funcs[] = { {"add",event_buffer_add}, + {"length",event_buffer_get_length}, + {"get_data",event_buffer_get_data}, + {"drain",event_buffer_drain}, + {"close",event_buffer_gc}, {NULL, NULL} }; static luaL_Ref funcs[] = { + {"new",event_buffer_push_new}, {NULL, NULL} }; int event_buffer_register(lua_State* L) { luaL_newmetatable(L, EVENT_BUFFER_MT); + lua_pushcfunction(L, event_buffer_gc); + lua_setfield(L, -2, "__gc"); lua_newtable(L); luaL_register(L, NULL, buffer_funcs); lua_setfield(L, -2, "__index");