pkgsrc-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[pkgsrc/trunk]: pkgsrc/net/libquvi Fix missing functions with Lua 5.3. Bump r...



details:   https://anonhg.NetBSD.org/pkgsrc/rev/959601662f18
branches:  trunk
changeset: 427170:959601662f18
user:      joerg <joerg%pkgsrc.org@localhost>
date:      Sun Apr 12 19:48:20 2020 +0000

description:
Fix missing functions with Lua 5.3. Bump revision.

diffstat:

 net/libquvi/Makefile                              |   4 +-
 net/libquvi/distinfo                              |   3 +-
 net/libquvi/patches/patch-src_libquvi_lua__wrap.c |  66 +++++++++++++++++++++++
 3 files changed, 70 insertions(+), 3 deletions(-)

diffs (96 lines):

diff -r 0d8c578a394a -r 959601662f18 net/libquvi/Makefile
--- a/net/libquvi/Makefile      Sun Apr 12 19:45:51 2020 +0000
+++ b/net/libquvi/Makefile      Sun Apr 12 19:48:20 2020 +0000
@@ -1,8 +1,8 @@
-# $NetBSD: Makefile,v 1.29 2020/03/20 11:58:08 nia Exp $
+# $NetBSD: Makefile,v 1.30 2020/04/12 19:48:20 joerg Exp $
 #
 
 DISTNAME=      libquvi-0.4.1
-PKGREVISION=   22
+PKGREVISION=   23
 CATEGORIES=    net
 MASTER_SITES=  ${MASTER_SITE_SOURCEFORGE:=quvi/}
 EXTRACT_SUFX=  .tar.bz2
diff -r 0d8c578a394a -r 959601662f18 net/libquvi/distinfo
--- a/net/libquvi/distinfo      Sun Apr 12 19:45:51 2020 +0000
+++ b/net/libquvi/distinfo      Sun Apr 12 19:48:20 2020 +0000
@@ -1,6 +1,7 @@
-$NetBSD: distinfo,v 1.3 2015/11/04 00:35:09 agc Exp $
+$NetBSD: distinfo,v 1.4 2020/04/12 19:48:20 joerg Exp $
 
 SHA1 (libquvi-0.4.1.tar.bz2) = b7ac371185c35a1a9a2135ef4ee61c86c48f78f4
 RMD160 (libquvi-0.4.1.tar.bz2) = 38535a867bef195b32a81b5bdadf927110f79603
 SHA512 (libquvi-0.4.1.tar.bz2) = a5cc2c837c1a767dc5f543c7cf0b5611a92b7e397b532c1d6afd023f10831865b793193fe1ba5d14006308f2b1f0a575447c47dd383cb307ea6130ca6fab8078
 Size (libquvi-0.4.1.tar.bz2) = 308126 bytes
+SHA1 (patch-src_libquvi_lua__wrap.c) = ae032ca04cdaeaf3d7025faabeedb84f5aa3399b
diff -r 0d8c578a394a -r 959601662f18 net/libquvi/patches/patch-src_libquvi_lua__wrap.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/net/libquvi/patches/patch-src_libquvi_lua__wrap.c Sun Apr 12 19:48:20 2020 +0000
@@ -0,0 +1,66 @@
+$NetBSD: patch-src_libquvi_lua__wrap.c,v 1.1 2020/04/12 19:48:20 joerg Exp $
+
+Inline part of the Lua 5.1/5.2 compat code.
+
+--- src/libquvi/lua_wrap.c.orig        2020-04-12 16:02:28.082417799 +0000
++++ src/libquvi/lua_wrap.c
+@@ -410,17 +410,58 @@ static int lua_files_only(const struct d
+ }
+ 
+ /* Init. */
++static const char *my_luaL_findtable (lua_State *L, int idx,
++                                   const char *fname, int szhint) {
++  const char *e;
++  if (idx) lua_pushvalue(L, idx);
++  do {
++    e = strchr(fname, '.');
++    if (e == NULL) e = fname + strlen(fname);
++    lua_pushlstring(L, fname, e - fname);
++    if (lua_rawget(L, -2) == LUA_TNIL) {  /* no such field? */
++      lua_pop(L, 1);  /* remove this nil */
++      lua_createtable(L, 0, (*e == '.' ? 1 : szhint)); /* new table for field */
++      lua_pushlstring(L, fname, e - fname);
++      lua_pushvalue(L, -2);
++      lua_settable(L, -4);  /* set new table into field */
++    }
++    else if (!lua_istable(L, -1)) {  /* field has a non-table value? */
++      lua_pop(L, 2);  /* remove table and value */
++      return fname;  /* return problematic part of the name */
++    }
++    lua_remove(L, -2);  /* remove previous table */
++    fname = e + 1;
++  } while (*e == '.');
++  return NULL;
++}
+ 
+ int init_lua(_quvi_t quvi)
+ {
+   QUVIcode rc;
++  int size;
++  const luaL_Reg *l;
+ 
+   quvi->lua = luaL_newstate();
+   if (!quvi->lua)
+     return (QUVI_LUAINIT);
+ 
+   luaL_openlibs(quvi->lua);
+-  luaL_openlib(quvi->lua, "quvi", reg_meth, 1);
++
++  for (l = reg_meth, size = 0; l && l->name; l++) size++;
++  my_luaL_findtable(quvi->lua, LUA_REGISTRYINDEX, LUA_LOADED_TABLE, 1);
++  if (lua_getfield(quvi->lua, -1, "quvi") != LUA_TTABLE) {  /* no LOADED["quvi"]? */
++    lua_pop(quvi->lua, 1);  /* remove previous result */
++    /* try global variable (and create one if it does not exist) */
++    lua_pushglobaltable(quvi->lua);
++    if (my_luaL_findtable(quvi->lua, 0, "quvi", size) != NULL)
++      luaL_error(quvi->lua, "name conflict for module '%s'", "quvi");
++    lua_pushvalue(quvi->lua, -1);
++    lua_setfield(quvi->lua, -3, "quvi");  /* LOADED["quvi"] = new table */
++  }
++  lua_remove(quvi->lua, -2);  /* remove LOADED table */
++
++  lua_insert(quvi->lua, -2);
++  luaL_setfuncs(quvi->lua, reg_meth, 1);
+ 
+   rc = scan_known_dirs(&quvi->util_scripts, "lua/util", lua_files_only);
+ 



Home | Main Index | Thread Index | Old Index