commit:     0570c40b967f641612469d97bc7627637f888fe8
Author:     William Hubbs <williamh <AT> gentoo <DOT> org>
AuthorDate: Tue Dec 29 19:55:15 2020 +0000
Commit:     William Hubbs <williamh <AT> gentoo <DOT> org>
CommitDate: Tue Dec 29 19:56:50 2020 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0570c40b

dev-lang/lua: 5.1.5-r106 revbump

- drop static use flag
- do not install liblua.{a,la}

Signed-off-by: William Hubbs <williamh <AT> gentoo.org>

 dev-lang/lua/files/lua-5.1.5-make.patch |  97 ++++++++++++++++++++
 dev-lang/lua/lua-5.1.5-r106.ebuild      | 151 ++++++++++++++++++++++++++++++++
 2 files changed, 248 insertions(+)

diff --git a/dev-lang/lua/files/lua-5.1.5-make.patch 
b/dev-lang/lua/files/lua-5.1.5-make.patch
new file mode 100644
index 00000000000..032652c0a5e
--- /dev/null
+++ b/dev-lang/lua/files/lua-5.1.5-make.patch
@@ -0,0 +1,97 @@
+diff -ru lua-5.1.5.orig/Makefile lua-5.1.5/Makefile
+--- lua-5.1.5.orig/Makefile    2014-04-15 17:43:34.845435031 +0200
++++ lua-5.1.5/Makefile 2014-04-15 19:05:08.669304987 +0200
+@@ -11,7 +11,7 @@
+ # so take care if INSTALL_TOP is not an absolute path.
+ INSTALL_TOP= /usr/local
+ INSTALL_BIN= $(INSTALL_TOP)/bin
+-INSTALL_INC= $(INSTALL_TOP)/include
++INSTALL_INC= $(INSTALL_TOP)/include/lua$V
+ INSTALL_LIB= $(INSTALL_TOP)/lib
+ INSTALL_MAN= $(INSTALL_TOP)/man/man1
+ #
+@@ -126,3 +126,21 @@
+ .PHONY: all $(PLATS) clean test install local none dummy echo pecho lecho
+ 
+ # (end of Makefile)
++
++# Use libtool for binary installs, etc.
++
++export V
++export LIBTOOL = libtool --quiet --tag=CC
++# See libtool manual about how to set this
++
++gentoo_clean:
++      cd src; $(MAKE) $@
++
++gentoo_test: gentoo_linux
++      test/lua.static test/hello.lua
++
++gentoo_install:
++      mkdir -p $(INSTALL_BIN) $(INSTALL_INC) $(INSTALL_LIB)
++      cd src; $(LIBTOOL) --mode=install $(INSTALL_EXEC) lua$V luac$V 
$(INSTALL_BIN)
++      cd src; $(INSTALL_DATA) $(TO_INC) $(INSTALL_INC)
++      cd src; $(LIBTOOL) --mode=install $(INSTALL_DATA) liblua$V.la 
$(INSTALL_LIB)
+diff -ru lua-5.1.5.orig/src/Makefile lua-5.1.5/src/Makefile
+--- lua-5.1.5.orig/src/Makefile        2014-04-15 17:43:34.844435031 +0200
++++ lua-5.1.5/src/Makefile     2014-04-15 18:07:21.427397122 +0200
+@@ -29,10 +29,10 @@
+ LIB_O=        lauxlib.o lbaselib.o ldblib.o liolib.o lmathlib.o loslib.o 
ltablib.o \
+       lstrlib.o loadlib.o linit.o
+ 
+-LUA_T=        lua
++LUA_T= lua$V
+ LUA_O=        lua.o
+ 
+-LUAC_T=       luac
++LUAC_T=       luac$V
+ LUAC_O=       luac.o print.o
+ 
+ ALL_O= $(CORE_O) $(LIB_O) $(LUA_O) $(LUAC_O)
+@@ -51,10 +51,10 @@
+       $(AR) $@ $(CORE_O) $(LIB_O)     # DLL needs all object files
+       $(RANLIB) $@
+ 
+-$(LUA_T): $(LUA_O) $(LUA_A)
++origin$(LUA_T): $(LUA_O) $(LUA_A)
+       $(CC) -o $@ $(MYLDFLAGS) $(LUA_O) $(LUA_A) $(LIBS)
+ 
+-$(LUAC_T): $(LUAC_O) $(LUA_A)
++origin$(LUAC_T): $(LUAC_O) $(LUA_A)
+       $(CC) -o $@ $(MYLDFLAGS) $(LUAC_O) $(LUA_A) $(LIBS)
+ 
+ clean:
+@@ -180,3 +180,33 @@
+   ltm.h lzio.h lmem.h lopcodes.h lundump.h
+ 
+ # (end of Makefile)
++
++export LIBTOOL = libtool --tag=CC
++export LIB_VERSION = 5:1:5
++
++# The following rules use libtool for compiling and linking in order to
++# provide shared library support.
++
++LIB_NAME = liblua$V.la
++LIB_OBJS = $(CORE_O:.o=.lo) $(LIB_O:.o=.lo)
++
++%.lo %.o: %.c
++      $(LIBTOOL) --mode=compile $(CC) -c $(CPPFLAGS) $(CFLAGS) -o $@ $<
++
++$(LIB_NAME): $(LIB_OBJS)
++      $(LIBTOOL) --mode=link $(CC) -version-info 0:0:0 \
++            -rpath $(RPATH) $(LDFLAGS) -o $(LIB_NAME) $(LIB_OBJS) $(LIB_LIBS)
++
++$(LUA_T): $(LUA_O:.o=.lo) $(LIB_NAME)
++      $(LIBTOOL) --mode=link $(CC) -static -export-dynamic $(LDFLAGS) -o $@ 
$(LUA_O:.o=.lo) $(LIB_NAME) $(LUA_LIBS)
++
++lua_test: $(LUA_O:.o=.lo) $(LIB_NAME)
++      $(LIBTOOL) --mode=link $(CC) -static -export-dynamic $(LDFLAGS) -o $@ 
$(LUA_O:.o=.lo) $(LIB_NAME) $(LUA_LIBS)
++
++$(LUAC_T): $(LUAC_O:.o=.lo) $(LIB_NAME)
++      $(LIBTOOL) --mode=link $(CC) -static $(LDFLAGS) -o $@ $(LUAC_O:.o=.lo) 
$(LIB_NAME)
++
++gentoo_clean:
++      $(LIBTOOL) --mode=clean $(RM) $(ALL_O:.o=.lo) $(LIB_NAME) lua$V luac$V
++
++gentoo_all: $(LIB_NAME) $(LUA_T) lua_test $(LUAC_T)

diff --git a/dev-lang/lua/lua-5.1.5-r106.ebuild 
b/dev-lang/lua/lua-5.1.5-r106.ebuild
new file mode 100644
index 00000000000..7ed88b37032
--- /dev/null
+++ b/dev-lang/lua/lua-5.1.5-r106.ebuild
@@ -0,0 +1,151 @@
+# Copyright 1999-2020 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+inherit multilib multilib-minimal portability toolchain-funcs
+
+DESCRIPTION="A powerful light-weight programming language designed for 
extending applications"
+HOMEPAGE="https://www.lua.org/";
+SRC_URI="https://www.lua.org/ftp/${P}.tar.gz";
+
+LICENSE="MIT"
+SLOT="5.1"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sparc 
~x86 ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~sparc-solaris 
~sparc64-solaris ~x64-solaris ~x86-solaris"
+IUSE="+deprecated readline"
+
+COMMON_DEPEND="
+       >=app-eselect/eselect-lua-3
+       readline? ( >=sys-libs/readline-6.2_p5-r1:0=[${MULTILIB_USEDEP}] )
+       !dev-lang/lua:0"
+DEPEND="${COMMON_DEPEND}"
+RDEPEND="${COMMON_DEPEND}"
+BDEPEND="sys-devel/libtool"
+
+MULTILIB_WRAPPED_HEADERS=(
+       /usr/include/lua${SLOT}/luaconf.h
+)
+
+src_prepare() {
+       PATCHES=(
+               "${FILESDIR}/lua-5.1.5-make.patch"
+               "${FILESDIR}/${PN}-$(ver_cut 1-2)-module_paths.patch"
+       )
+       if ! use deprecated ; then
+               # patches from 5.1.4 still apply
+               PATCHES+=(
+                       "${FILESDIR}"/${PN}-5.1.4-deprecated.patch
+                       "${FILESDIR}"/${PN}-5.1.4-test.patch
+               )
+       fi
+       if ! use readline ; then
+               PATCHES+=(
+                       "${FILESDIR}"/${PN}-$(ver_cut 1-2)-readline.patch
+               )
+       fi
+
+       default
+
+       # use glibtool on Darwin (versus Apple libtool)
+       if [[ ${CHOST} == *-darwin* ]] ; then
+               sed -i -e '/LIBTOOL = /s:libtool:glibtool:' \
+                       Makefile src/Makefile || die
+       fi
+
+       # correct lua versioning
+       sed -i -e 's/\(LIB_VERSION = \)6:1:1/\16:5:1/' src/Makefile
+
+       sed -i -e 's:\(/README\)\("\):\1.gz\2:g' doc/readme.html
+
+       # Using dynamic linked lua is not recommended 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
+       # Note that this only affects the interpreter binary (named lua), not 
the lua
+       # compiler (built statically) nor the lua libraries.
+
+       # A slotted Lua uses different directories for headers & names for
+       # libraries, and pkgconfig should reflect that.
+       sed -r -i \
+               -e "/^INSTALL_INC=/s,(/include)$,\1/lua${SLOT}," \
+               -e "/^includedir=/s,(/include)$,\1/lua${SLOT}," \
+               -e "/^Libs:/s,((-llua)($| )),\2${SLOT}\3," \
+               "${S}"/etc/lua.pc
+
+       # custom Makefiles
+       multilib_copy_sources
+}
+
+multilib_src_configure() {
+       # We want packages to find our things...
+       sed -i \
+               -e 's:/usr/local:'${EPREFIX}'/usr:' \
+               -e "s:\([/\"]\)\<lib\>:\1$(get_libdir):g" \
+               etc/lua.pc src/luaconf.h || die
+}
+
+multilib_src_compile() {
+       tc-export CC
+       myflags=
+       # what to link to liblua
+       liblibs="-lm"
+       liblibs="${liblibs} $(dlopen_lib)"
+
+       # what to link to the executables
+       mylibs=
+       if use readline; then
+               mylibs="-lreadline"
+       fi
+
+       cd src
+       emake CC="${CC}" CFLAGS="-DLUA_USE_LINUX ${CFLAGS}" \
+                       RPATH="${EPREFIX}/usr/$(get_libdir)/" \
+                       LUA_LIBS="${mylibs}" \
+                       LIB_LIBS="${liblibs}" \
+                       V=$(ver_cut 1-2) \
+                       gentoo_all
+
+       mv lua_test ../test/lua.static
+}
+
+multilib_src_install() {
+       emake INSTALL_TOP="${ED}/usr" INSTALL_LIB="${ED}/usr/$(get_libdir)" \
+                       V=${SLOT} gentoo_install
+
+       insinto /usr/$(get_libdir)/pkgconfig
+       newins etc/lua.pc lua${SLOT}.pc
+}
+
+multilib_src_install_all() {
+       DOCS="HISTORY README"
+       HTML_DOCS="doc/*.html doc/*.png doc/*.css doc/*.gif"
+       einstalldocs
+       newman doc/lua.1 lua${SLOT}.1
+       newman doc/luac.1 luac${SLOT}.1
+       find "${ED}" -name '*.la' -delete || die
+       find "${ED}" -name 'liblua*.a' -delete || die
+}
+
+multilib_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 "${BUILD_DIR}" || die
+       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
+}
+
+pkg_postinst() {
+       eselect lua set --if-unset "${PN}${SLOT}"
+
+       if has_version "app-editor/emacs"; then
+               if ! has_version "app-emacs/lua-mode"; then
+                       einfo "Install app-emacs/lua-mode for lua support for 
emacs"
+               fi
+       fi
+}

Reply via email to