Date: Tue, 25 Aug 2009 10:33:47 +0200 From: Robert Nagy <robert@openbsd.org> To: pgollucci@freebsd.org Cc: freebsd-ports@freebsd.org Subject: Re: luasocket namespace clash with lighttpd mod_magnet Message-ID: <20090825083347.GA15471@bsd.hu> In-Reply-To: <20090822202653.GA3713@bsd.hu> References: <20090822202653.GA3713@bsd.hu>
next in thread | previous in thread | raw e-mail | index | archive | help
? On (2009-08-22 22:26), Robert Nagy wrote: > > Hey, > > Basically - luasocket defines buffer_init(); which is common enough to be defined > elsewhere and it is defined in mod_magnet, so you end up with a SIGSEGV. > The attatched patch solves the issue by renaming the buffer_* funcs to ls_buffer_*. > Its a totally safe diff that does not affect anything else and fixes a problem. > > I've commited this to OpenBSD already, but I need it on FreeBSD too. > > http://www.freebsd.org/cgi/query-pr.cgi?pr=138055 contains a wrong diff, > sorry for that. > > Index: Makefile > =================================================================== > RCS file: /home/ncvs/ports/net/luasocket/Makefile,v > retrieving revision 1.12 > diff -u -r1.12 Makefile > --- Makefile 9 Jul 2009 03:57:57 -0000 1.12 > +++ Makefile 22 Aug 2009 20:25:53 -0000 > @@ -7,6 +7,7 @@ > > PORTNAME= luasocket > PORTVERSION= 2.0.2 > +PORTREVISION= 1 > CATEGORIES= net > MASTER_SITES= http://luaforge.net/frs/download.php/2664/ > PKGNAMEPREFIX= ${LUA_PKGNAMEPREFIX} > Index: files/patch-config > =================================================================== > RCS file: /home/ncvs/ports/net/luasocket/files/patch-config,v > retrieving revision 1.3 > diff -u -r1.3 patch-config > --- files/patch-config 28 Oct 2007 19:43:49 -0000 1.3 > +++ files/patch-config 22 Aug 2009 20:25:53 -0000 > @@ -1,6 +1,6 @@ > ---- config.orig Sun Oct 14 12:44:03 2007 > -+++ config Sun Oct 14 13:54:39 2007 > -@@ -18,11 +18,13 @@ > +--- config.orig 2007-10-15 06:21:05.000000000 +0200 > ++++ config 2009-08-22 22:23:45.000000000 +0200 > +@@ -18,11 +18,13 @@ UNIX_SO=unix.$(EXT) > #LUAINC=-I/usr/local/include/lua50 > #LUAINC=-I/usr/local/include/lua5.1 > #LUAINC=-Ilua-5.1.1/src > @@ -14,7 +14,7 @@ > > #------ > # Top of your Lua installation > -@@ -30,11 +32,11 @@ > +@@ -30,11 +32,11 @@ UNIX_SO=unix.$(EXT) > # > #INSTALL_TOP_SHARE=/usr/local/share/lua/5.0 > #INSTALL_TOP_LIB=/usr/local/lib/lua/5.0 > @@ -30,7 +30,7 @@ > > #------ > # Compiler and linker settings > -@@ -49,11 +51,11 @@ > +@@ -49,11 +51,11 @@ INSTALL_EXEC=cp > #------ > # Compiler and linker settings > # for Linux > Index: files/patch-src_buffer_c > =================================================================== > RCS file: files/patch-src_buffer_c > diff -N files/patch-src_buffer_c > --- /dev/null 1 Jan 1970 00:00:00 -0000 > +++ files/patch-src_buffer_c 22 Aug 2009 20:25:53 -0000 > @@ -0,0 +1,100 @@ > +$OpenBSD: patch-src_buffer_c,v 1.1 2005/11/25 15:09:44 pedro Exp $ > +--- src/buffer.c.orig 2007-10-15 06:21:05.000000000 +0200 > ++++ src/buffer.c 2009-08-22 22:25:16.000000000 +0200 > +@@ -33,7 +33,7 @@ static int sendraw(p_buffer buf, const c > + /*-------------------------------------------------------------------------*\ > + * Initializes module > + \*-------------------------------------------------------------------------*/ > +-int buffer_open(lua_State *L) { > ++int ls_buffer_open(lua_State *L) { > + (void) L; > + return 0; > + } > +@@ -41,7 +41,7 @@ int buffer_open(lua_State *L) { > + /*-------------------------------------------------------------------------*\ > + * Initializes C structure > + \*-------------------------------------------------------------------------*/ > +-void buffer_init(p_buffer buf, p_io io, p_timeout tm) { > ++void ls_buffer_init(p_buffer buf, p_io io, p_timeout tm) { > + buf->first = buf->last = 0; > + buf->io = io; > + buf->tm = tm; > +@@ -52,7 +52,7 @@ void buffer_init(p_buffer buf, p_io io, > + /*-------------------------------------------------------------------------*\ > + * object:getstats() interface > + \*-------------------------------------------------------------------------*/ > +-int buffer_meth_getstats(lua_State *L, p_buffer buf) { > ++int ls_buffer_meth_getstats(lua_State *L, p_buffer buf) { > + lua_pushnumber(L, buf->received); > + lua_pushnumber(L, buf->sent); > + lua_pushnumber(L, timeout_gettime() - buf->birthday); > +@@ -62,7 +62,7 @@ int buffer_meth_getstats(lua_State *L, p > + /*-------------------------------------------------------------------------*\ > + * object:setstats() interface > + \*-------------------------------------------------------------------------*/ > +-int buffer_meth_setstats(lua_State *L, p_buffer buf) { > ++int ls_buffer_meth_setstats(lua_State *L, p_buffer buf) { > + buf->received = (long) luaL_optnumber(L, 2, buf->received); > + buf->sent = (long) luaL_optnumber(L, 3, buf->sent); > + if (lua_isnumber(L, 4)) buf->birthday = timeout_gettime() - lua_tonumber(L, 4); > +@@ -73,14 +73,16 @@ int buffer_meth_setstats(lua_State *L, p > + /*-------------------------------------------------------------------------*\ > + * object:send() interface > + \*-------------------------------------------------------------------------*/ > +-int buffer_meth_send(lua_State *L, p_buffer buf) { > ++int ls_buffer_meth_send(lua_State *L, p_buffer buf) { > + int top = lua_gettop(L); > + int err = IO_DONE; > + size_t size = 0, sent = 0; > + const char *data = luaL_checklstring(L, 2, &size); > + long start = (long) luaL_optnumber(L, 3, 1); > + long end = (long) luaL_optnumber(L, 4, -1); > ++#ifdef LUASOCKET_DEBUG > + p_timeout tm = timeout_markstart(buf->tm); > ++#endif > + if (start < 0) start = (long) (size+start+1); > + if (end < 0) end = (long) (size+end+1); > + if (start < 1) start = (long) 1; > +@@ -106,12 +108,14 @@ int buffer_meth_send(lua_State *L, p_buf > + /*-------------------------------------------------------------------------*\ > + * object:receive() interface > + \*-------------------------------------------------------------------------*/ > +-int buffer_meth_receive(lua_State *L, p_buffer buf) { > ++int ls_buffer_meth_receive(lua_State *L, p_buffer buf) { > + int err = IO_DONE, top = lua_gettop(L); > + luaL_Buffer b; > + size_t size; > + const char *part = luaL_optlstring(L, 3, "", &size); > ++#ifdef LUASOCKET_DEBUG > + p_timeout tm = timeout_markstart(buf->tm); > ++#endif > + /* initialize buffer with optional extra prefix > + * (useful for concatenating previous partial results) */ > + luaL_buffinit(L, &b); > +@@ -149,7 +153,7 @@ int buffer_meth_receive(lua_State *L, p_ > + /*-------------------------------------------------------------------------*\ > + * Determines if there is any data in the read buffer > + \*-------------------------------------------------------------------------*/ > +-int buffer_isempty(p_buffer buf) { > ++int ls_buffer_isempty(p_buffer buf) { > + return buf->first >= buf->last; > + } > + > +@@ -244,7 +248,7 @@ static int recvline(p_buffer buf, luaL_B > + static void buffer_skip(p_buffer buf, size_t count) { > + buf->received += count; > + buf->first += count; > +- if (buffer_isempty(buf)) > ++ if (ls_buffer_isempty(buf)) > + buf->first = buf->last = 0; > + } > + > +@@ -256,7 +260,7 @@ static int buffer_get(p_buffer buf, cons > + int err = IO_DONE; > + p_io io = buf->io; > + p_timeout tm = buf->tm; > +- if (buffer_isempty(buf)) { > ++ if (ls_buffer_isempty(buf)) { > + size_t got; > + err = io->recv(io->ctx, buf->data, BUF_SIZE, &got, tm); > + buf->first = 0; > Index: files/patch-src_buffer_h > =================================================================== > RCS file: files/patch-src_buffer_h > diff -N files/patch-src_buffer_h > --- /dev/null 1 Jan 1970 00:00:00 -0000 > +++ files/patch-src_buffer_h 22 Aug 2009 20:25:53 -0000 > @@ -0,0 +1,23 @@ > +$OpenBSD$ > +--- src/buffer.h.orig Thu Apr 27 05:23:22 2006 > ++++ src/buffer.h Sat Aug 22 22:19:02 2009 > +@@ -36,12 +36,12 @@ typedef struct t_buffer_ { > + } t_buffer; > + typedef t_buffer *p_buffer; > + > +-int buffer_open(lua_State *L); > +-void buffer_init(p_buffer buf, p_io io, p_timeout tm); > +-int buffer_meth_send(lua_State *L, p_buffer buf); > +-int buffer_meth_receive(lua_State *L, p_buffer buf); > +-int buffer_meth_getstats(lua_State *L, p_buffer buf); > +-int buffer_meth_setstats(lua_State *L, p_buffer buf); > +-int buffer_isempty(p_buffer buf); > ++int ls_buffer_open(lua_State *L); > ++void ls_buffer_init(p_buffer buf, p_io io, p_timeout tm); > ++int ls_buffer_meth_send(lua_State *L, p_buffer buf); > ++int ls_buffer_meth_receive(lua_State *L, p_buffer buf); > ++int ls_buffer_meth_getstats(lua_State *L, p_buffer buf); > ++int ls_buffer_meth_setstats(lua_State *L, p_buffer buf); > ++int ls_buffer_isempty(p_buffer buf); > + > + #endif /* BUF_H */ > Index: files/patch-src_luasocket_c > =================================================================== > RCS file: files/patch-src_luasocket_c > diff -N files/patch-src_luasocket_c > --- /dev/null 1 Jan 1970 00:00:00 -0000 > +++ files/patch-src_luasocket_c 22 Aug 2009 20:25:53 -0000 > @@ -0,0 +1,11 @@ > +--- src/luasocket.c.orig 2007-10-15 06:21:05.000000000 +0200 > ++++ src/luasocket.c 2009-08-22 22:23:45.000000000 +0200 > +@@ -51,7 +51,7 @@ static const luaL_reg mod[] = { > + {"auxiliar", auxiliar_open}, > + {"except", except_open}, > + {"timeout", timeout_open}, > +- {"buffer", buffer_open}, > ++ {"buffer", ls_buffer_open}, > + {"inet", inet_open}, > + {"tcp", tcp_open}, > + {"udp", udp_open}, > Index: files/patch-src_tcp_c > =================================================================== > RCS file: files/patch-src_tcp_c > diff -N files/patch-src_tcp_c > --- /dev/null 1 Jan 1970 00:00:00 -0000 > +++ files/patch-src_tcp_c 22 Aug 2009 20:25:53 -0000 > @@ -0,0 +1,57 @@ > +$OpenBSD$ > +--- src/tcp.c.orig Thu Apr 27 05:23:21 2006 > ++++ src/tcp.c Sat Aug 22 22:19:02 2009 > +@@ -104,22 +104,22 @@ int tcp_open(lua_State *L) > + \*-------------------------------------------------------------------------*/ > + static int meth_send(lua_State *L) { > + p_tcp tcp = (p_tcp) auxiliar_checkclass(L, "tcp{client}", 1); > +- return buffer_meth_send(L, &tcp->buf); > ++ return ls_buffer_meth_send(L, &tcp->buf); > + } > + > + static int meth_receive(lua_State *L) { > + p_tcp tcp = (p_tcp) auxiliar_checkclass(L, "tcp{client}", 1); > +- return buffer_meth_receive(L, &tcp->buf); > ++ return ls_buffer_meth_receive(L, &tcp->buf); > + } > + > + static int meth_getstats(lua_State *L) { > + p_tcp tcp = (p_tcp) auxiliar_checkclass(L, "tcp{client}", 1); > +- return buffer_meth_getstats(L, &tcp->buf); > ++ return ls_buffer_meth_getstats(L, &tcp->buf); > + } > + > + static int meth_setstats(lua_State *L) { > + p_tcp tcp = (p_tcp) auxiliar_checkclass(L, "tcp{client}", 1); > +- return buffer_meth_setstats(L, &tcp->buf); > ++ return ls_buffer_meth_setstats(L, &tcp->buf); > + } > + > + /*-------------------------------------------------------------------------*\ > +@@ -152,7 +152,7 @@ static int meth_setfd(lua_State *L) > + static int meth_dirty(lua_State *L) > + { > + p_tcp tcp = (p_tcp) auxiliar_checkgroup(L, "tcp{any}", 1); > +- lua_pushboolean(L, !buffer_isempty(&tcp->buf)); > ++ lua_pushboolean(L, !ls_buffer_isempty(&tcp->buf)); > + return 1; > + } > + > +@@ -176,7 +176,7 @@ static int meth_accept(lua_State *L) > + io_init(&clnt->io, (p_send) socket_send, (p_recv) socket_recv, > + (p_error) socket_ioerror, &clnt->sock); > + timeout_init(&clnt->tm, -1, -1); > +- buffer_init(&clnt->buf, &clnt->io, &clnt->tm); > ++ ls_buffer_init(&clnt->buf, &clnt->io, &clnt->tm); > + return 1; > + } else { > + lua_pushnil(L); > +@@ -329,7 +329,7 @@ static int global_create(lua_State *L) > + io_init(&tcp->io, (p_send) socket_send, (p_recv) socket_recv, > + (p_error) socket_ioerror, &tcp->sock); > + timeout_init(&tcp->tm, -1, -1); > +- buffer_init(&tcp->buf, &tcp->io, &tcp->tm); > ++ ls_buffer_init(&tcp->buf, &tcp->io, &tcp->tm); > + return 1; > + } else { > + lua_pushnil(L); > Index: files/patch-src_unix_c > =================================================================== > RCS file: files/patch-src_unix_c > diff -N files/patch-src_unix_c > --- /dev/null 1 Jan 1970 00:00:00 -0000 > +++ files/patch-src_unix_c 22 Aug 2009 20:25:53 -0000 > @@ -0,0 +1,57 @@ > +$OpenBSD$ > +--- src/unix.c.orig Thu Apr 27 05:23:21 2006 > ++++ src/unix.c Sat Aug 22 22:19:02 2009 > +@@ -105,22 +105,22 @@ int luaopen_socket_unix(lua_State *L) { > + \*-------------------------------------------------------------------------*/ > + static int meth_send(lua_State *L) { > + p_unix un = (p_unix) auxiliar_checkclass(L, "unix{client}", 1); > +- return buffer_meth_send(L, &un->buf); > ++ return ls_buffer_meth_send(L, &un->buf); > + } > + > + static int meth_receive(lua_State *L) { > + p_unix un = (p_unix) auxiliar_checkclass(L, "unix{client}", 1); > +- return buffer_meth_receive(L, &un->buf); > ++ return ls_buffer_meth_receive(L, &un->buf); > + } > + > + static int meth_getstats(lua_State *L) { > + p_unix un = (p_unix) auxiliar_checkclass(L, "unix{client}", 1); > +- return buffer_meth_getstats(L, &un->buf); > ++ return ls_buffer_meth_getstats(L, &un->buf); > + } > + > + static int meth_setstats(lua_State *L) { > + p_unix un = (p_unix) auxiliar_checkclass(L, "unix{client}", 1); > +- return buffer_meth_setstats(L, &un->buf); > ++ return ls_buffer_meth_setstats(L, &un->buf); > + } > + > + /*-------------------------------------------------------------------------*\ > +@@ -149,7 +149,7 @@ static int meth_setfd(lua_State *L) { > + > + static int meth_dirty(lua_State *L) { > + p_unix un = (p_unix) auxiliar_checkgroup(L, "unix{any}", 1); > +- lua_pushboolean(L, !buffer_isempty(&un->buf)); > ++ lua_pushboolean(L, !ls_buffer_isempty(&un->buf)); > + return 1; > + } > + > +@@ -172,7 +172,7 @@ static int meth_accept(lua_State *L) { > + io_init(&clnt->io, (p_send)socket_send, (p_recv)socket_recv, > + (p_error) socket_ioerror, &clnt->sock); > + timeout_init(&clnt->tm, -1, -1); > +- buffer_init(&clnt->buf, &clnt->io, &clnt->tm); > ++ ls_buffer_init(&clnt->buf, &clnt->io, &clnt->tm); > + return 1; > + } else { > + lua_pushnil(L); > +@@ -346,7 +346,7 @@ static int global_create(lua_State *L) { > + io_init(&un->io, (p_send) socket_send, (p_recv) socket_recv, > + (p_error) socket_ioerror, &un->sock); > + timeout_init(&un->tm, -1, -1); > +- buffer_init(&un->buf, &un->io, &un->tm); > ++ ls_buffer_init(&un->buf, &un->io, &un->tm); > + return 1; > + } else { > + lua_pushnil(L); > _______________________________________________ > freebsd-ports@freebsd.org mailing list > http://lists.freebsd.org/mailman/listinfo/freebsd-ports > To unsubscribe, send any mail to "freebsd-ports-unsubscribe@freebsd.org"
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20090825083347.GA15471>