summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--dev-lang/lua/ChangeLog11
-rw-r--r--dev-lang/lua/files/5.1.3/09_all_string_byte_fix_upstream.patch12
-rw-r--r--dev-lang/lua/files/5.1.3/10_all_gc_loop_fix.upstream.patch19
-rw-r--r--dev-lang/lua/files/5.1.3/11_all_module.upstream.patch16
-rw-r--r--dev-lang/lua/files/5.1.3/12_all_svalue.upstream.patch11
-rw-r--r--dev-lang/lua/lua-5.1.3-r4.ebuild112
6 files changed, 180 insertions, 1 deletions
diff --git a/dev-lang/lua/ChangeLog b/dev-lang/lua/ChangeLog
index d827de629dce..5ddaadf1176d 100644
--- a/dev-lang/lua/ChangeLog
+++ b/dev-lang/lua/ChangeLog
@@ -1,6 +1,15 @@
# ChangeLog for dev-lang/lua
# Copyright 2002-2008 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/dev-lang/lua/ChangeLog,v 1.107 2008/05/27 22:11:43 mabi Exp $
+# $Header: /var/cvsroot/gentoo-x86/dev-lang/lua/ChangeLog,v 1.108 2008/08/10 12:51:31 mabi Exp $
+
+*lua-5.1.3-r4 (10 Aug 2008)
+
+ 10 Aug 2008; Matti Bickel <mabi@gentoo.org>
+ +files/5.1.3/09_all_string_byte_fix_upstream.patch,
+ +files/5.1.3/10_all_gc_loop_fix.upstream.patch,
+ +files/5.1.3/11_all_module.upstream.patch,
+ +files/5.1.3/12_all_svalue.upstream.patch, +lua-5.1.3-r4.ebuild:
+ bump to include more upstream patches
*lua-5.1.3-r3 (27 May 2008)
diff --git a/dev-lang/lua/files/5.1.3/09_all_string_byte_fix_upstream.patch b/dev-lang/lua/files/5.1.3/09_all_string_byte_fix_upstream.patch
new file mode 100644
index 000000000000..392fa6b75739
--- /dev/null
+++ b/dev-lang/lua/files/5.1.3/09_all_string_byte_fix_upstream.patch
@@ -0,0 +1,12 @@
+--- lua-5.1.3.orig/src/lstrlib.c 2008-05-15 09:24:32.000000000 +0200
++++ lua-5.1.3/src/lstrlib.c 2008-08-10 14:21:00.000000000 +0200
+@@ -35,7 +35,8 @@
+
+ static ptrdiff_t posrelat (ptrdiff_t pos, size_t len) {
+ /* relative string position: negative means back from end */
+- return (pos>=0) ? pos : (ptrdiff_t)len+pos+1;
++ if (pos < 0) pos += (ptrdiff_t)len + 1;
++ return (pos >= 0) ? pos : 0;
+ }
+
+
diff --git a/dev-lang/lua/files/5.1.3/10_all_gc_loop_fix.upstream.patch b/dev-lang/lua/files/5.1.3/10_all_gc_loop_fix.upstream.patch
new file mode 100644
index 000000000000..83b706d709d6
--- /dev/null
+++ b/dev-lang/lua/files/5.1.3/10_all_gc_loop_fix.upstream.patch
@@ -0,0 +1,19 @@
+--- lua-5.1.3.orig/src/lapi.c 2008-05-15 09:24:32.000000000 +0200
++++ lua-5.1.3/src/lapi.c 2008-08-10 14:26:42.000000000 +0200
+@@ -930,10 +930,13 @@
+ g->GCthreshold = g->totalbytes - a;
+ else
+ g->GCthreshold = 0;
+- while (g->GCthreshold <= g->totalbytes)
++ while (g->GCthreshold <= g->totalbytes) {
+ luaC_step(L);
+- if (g->gcstate == GCSpause) /* end of cycle? */
+- res = 1; /* signal it */
++ if (g->gcstate == GCSpause) { /* end of cycle? */
++ res = 1; /* signal it */
++ break;
++ }
++ }
+ break;
+ }
+ case LUA_GCSETPAUSE: {
diff --git a/dev-lang/lua/files/5.1.3/11_all_module.upstream.patch b/dev-lang/lua/files/5.1.3/11_all_module.upstream.patch
new file mode 100644
index 000000000000..f6231f5fc49a
--- /dev/null
+++ b/dev-lang/lua/files/5.1.3/11_all_module.upstream.patch
@@ -0,0 +1,16 @@
+--- lua-5.1.3.orig/src/loadlib.c 2008-05-15 09:24:32.000000000 +0200
++++ lua-5.1.3/src/loadlib.c 2008-08-10 14:29:32.000000000 +0200
+@@ -506,8 +506,11 @@
+
+ static void setfenv (lua_State *L) {
+ lua_Debug ar;
+- lua_getstack(L, 1, &ar);
+- lua_getinfo(L, "f", &ar);
++ if (lua_getstack(L, 1, &ar) == 0 ||
++ lua_getinfo(L, "f", &ar) == 0 || /* get calling function */
++ lua_iscfunction(L, -1))
++ luaL_error(L, "function " LUA_QL("module")
++ " not called from a Lua function");
+ lua_pushvalue(L, -2);
+ lua_setfenv(L, -2);
+ lua_pop(L, 1);
diff --git a/dev-lang/lua/files/5.1.3/12_all_svalue.upstream.patch b/dev-lang/lua/files/5.1.3/12_all_svalue.upstream.patch
new file mode 100644
index 000000000000..cec667b28e46
--- /dev/null
+++ b/dev-lang/lua/files/5.1.3/12_all_svalue.upstream.patch
@@ -0,0 +1,11 @@
+--- lua-5.1.3.orig/src/lobject.h 2008-05-15 09:24:32.000000000 +0200
++++ lua-5.1.3/src/lobject.h 2008-08-10 14:32:26.000000000 +0200
+@@ -208,7 +208,7 @@
+
+
+ #define getstr(ts) cast(const char *, (ts) + 1)
+-#define svalue(o) getstr(tsvalue(o))
++#define svalue(o) getstr(rawtsvalue(o))
+
+
+
diff --git a/dev-lang/lua/lua-5.1.3-r4.ebuild b/dev-lang/lua/lua-5.1.3-r4.ebuild
new file mode 100644
index 000000000000..ede21e1be252
--- /dev/null
+++ b/dev-lang/lua/lua-5.1.3-r4.ebuild
@@ -0,0 +1,112 @@
+# Copyright 1999-2008 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/dev-lang/lua/lua-5.1.3-r4.ebuild,v 1.1 2008/08/10 12:51:31 mabi Exp $
+
+EAPI="1"
+
+inherit eutils portability versionator
+
+DESCRIPTION="A powerful light-weight programming language designed for extending applications"
+HOMEPAGE="http://www.lua.org/"
+SRC_URI="http://www.lua.org/ftp/${P}.tar.gz"
+
+LICENSE="MIT"
+SLOT="0"
+KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86"
+IUSE="+deprecated readline static"
+
+DEPEND="readline? ( sys-libs/readline )"
+
+src_unpack() {
+ local PATCH_PV=$(get_version_component_range 1-2)
+ unpack ${A}
+ cd "${S}"
+
+ epatch "${FILESDIR}"/${PN}-${PATCH_PV}-make.patch
+ epatch "${FILESDIR}"/${PN}-${PATCH_PV}-module_paths.patch
+
+ EPATCH_SOURCE="${FILESDIR}/${PV}" EPATCH_SUFFIX="upstream.patch" epatch
+
+ # correct lua versioning
+ sed -i -e 's/\(LIB_VERSION = \)6:1:1/\16:3:1/' src/Makefile
+
+ sed -i -e 's:\(/README\)\("\):\1.gz\2:g' doc/readme.html
+
+ if ! use deprecated ; then
+ epatch "${FILESDIR}"/${P}-deprecated.patch
+ epatch "${FILESDIR}"/${P}-test.patch
+ fi
+
+ if ! use readline ; then
+ epatch "${FILESDIR}"/${PN}-${PATCH_PV}-readline.patch
+ fi
+
+ # Using dynamic linked lua is not recommended upstream for performance
+ # reasons. http://article.gmane.org/gmane.comp.lang.lua.general/18519
+ # Mainly, this is of concern if your arch is poor with GPRs, like x86
+ # Not that this only affects the interpreter binary (named lua), not the lua
+ # compiler (built statically) nor the lua libraries (both shared and static
+ # are installed)
+ if use static ; then
+ epatch "${FILESDIR}"/${PN}-${PATCH_PV}-make_static.patch
+ fi
+
+ # We want packages to find our things...
+ sed -i -e 's:/usr/local:/usr:' etc/lua.pc
+}
+
+src_compile() {
+ myflags=
+ # what to link to liblua
+ liblibs="-lm"
+ mycflags="${mycflags} -DLUA_USE_LINUX"
+ liblibs="${liblibs} $(dlopen_lib)"
+
+ # what to link to the executables
+ mylibs=
+ if use readline; then
+ mylibs="-lreadline"
+ fi
+
+ cd src
+ emake CFLAGS="${mycflags} ${CFLAGS}" \
+ RPATH="/usr/$(get_libdir)/" \
+ LUA_LIBS="${mylibs}" \
+ LIB_LIBS="${liblibs}" \
+ V=${PV} \
+ gentoo_all || die "emake failed"
+
+ mv lua_test ../test/lua.static
+}
+
+src_install() {
+ emake INSTALL_TOP="${D}/usr/" INSTALL_LIB="${D}/usr/$(get_libdir)/" \
+ V=${PV} gentoo_install \
+ || die "emake install gentoo_install failed"
+
+ dodoc HISTORY README
+ dohtml doc/*.html doc/*.gif
+
+ insinto /usr/share/pixmaps
+ doins etc/lua.ico
+ insinto /usr/$(get_libdir)/pkgconfig
+ doins etc/lua.pc
+
+ doman doc/lua.1 doc/luac.1
+}
+
+src_test() {
+ local positive="bisect cf echo env factorial fib fibfor hello printf sieve
+ sort trace-calls trace-globals"
+ local negative="readonly"
+ local test
+
+ cd "${S}"
+ for test in ${positive}; do
+ test/lua.static test/${test}.lua || die "test $test failed"
+ done
+
+ for test in ${negative}; do
+ test/lua.static test/${test}.lua && die "test $test failed"
+ done
+}