luasocket: moved to github
git-svn-id: svn://svn.openwrt.org/openwrt/packages@41755 3c298f89-4303-0410-b956-a3cf2f4a3e73
This commit is contained in:
parent
c2fed92005
commit
9a2115b502
@ -1,61 +0,0 @@
|
||||
#
|
||||
# Copyright (C) 2009-2013 OpenWrt.org
|
||||
#
|
||||
# This is free software, licensed under the GNU General Public License v2.
|
||||
# See /LICENSE for more information.
|
||||
#
|
||||
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=luasocket
|
||||
PKG_SOURCE_VERSION:=6d5e40c324c84d9c1453ae88e0ad5bdd0a631448
|
||||
PKG_VERSION:=3.0-rc1-20130909
|
||||
PKG_RELEASE:=2
|
||||
|
||||
PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2
|
||||
PKG_SOURCE_URL:=https://github.com/diegonehab/luasocket.git
|
||||
PKG_SOURCE_PROTO:=git
|
||||
PKG_SOURCE_SUBDIR:=$(PKG_NAME)-$(PKG_VERSION)
|
||||
|
||||
include $(INCLUDE_DIR)/package.mk
|
||||
|
||||
define Package/luasocket
|
||||
SUBMENU:=Lua
|
||||
SECTION:=lang
|
||||
CATEGORY:=Languages
|
||||
TITLE:=LuaSocket
|
||||
URL:=http://luasocket.luaforge.net/
|
||||
DEPENDS:=+lua
|
||||
endef
|
||||
|
||||
define Package/luasocket/description
|
||||
LuaSocket is the most comprehensive networking support
|
||||
library for the Lua language. It provides easy access to
|
||||
TCP, UDP, DNS, SMTP, FTP, HTTP, MIME and much more.
|
||||
endef
|
||||
|
||||
define Build/Configure
|
||||
endef
|
||||
|
||||
define Build/Compile
|
||||
$(MAKE) -C $(PKG_BUILD_DIR)/ \
|
||||
LIBDIR="$(TARGET_LDFLAGS)" \
|
||||
CC="$(TARGET_CC) $(TARGET_CFLAGS) $(TARGET_CPPFLAGS) -std=gnu99" \
|
||||
LD="$(TARGET_CROSS)ld -shared" \
|
||||
all
|
||||
endef
|
||||
|
||||
|
||||
define Package/luasocket/install
|
||||
$(INSTALL_DIR) $(1)/usr/lib/lua
|
||||
$(INSTALL_DATA) $(PKG_BUILD_DIR)/src/{ltn12,mime,socket}.lua $(1)/usr/lib/lua
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/src/mime.so.1.0.3 $(1)/usr/lib/lua
|
||||
$(INSTALL_BIN) $(PKG_BUILD_DIR)/src/socket.so.3.0-rc1 $(1)/usr/lib/lua
|
||||
$(INSTALL_DIR) $(1)/usr/lib/lua/mime
|
||||
ln -sf ../mime.so.1.0.3 $(1)/usr/lib/lua/mime/core.so
|
||||
$(INSTALL_DIR) $(1)/usr/lib/lua/socket
|
||||
$(INSTALL_DATA) $(PKG_BUILD_DIR)/src/{ftp,http,smtp,tp,url,headers}.lua $(1)/usr/lib/lua/socket
|
||||
ln -sf ../socket.so.3.0-rc1 $(1)/usr/lib/lua/socket/core.so
|
||||
endef
|
||||
|
||||
$(eval $(call BuildPackage,luasocket))
|
@ -1,237 +0,0 @@
|
||||
From 96fdf07acf78ecfc9be76a8b0591f38fe6f1a875 Mon Sep 17 00:00:00 2001
|
||||
From: Steven Barth <steven@midlink.org>
|
||||
Date: Sat, 9 Nov 2013 12:01:42 +0100
|
||||
Subject: [PATCH] Add interface resolving
|
||||
|
||||
---
|
||||
src/if.c | 113 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
|
||||
src/if.h | 27 ++++++++++++++
|
||||
src/luasocket.c | 2 +
|
||||
src/makefile | 2 +
|
||||
src/options.c | 9 +++++
|
||||
5 files changed, 153 insertions(+)
|
||||
create mode 100644 src/if.c
|
||||
create mode 100644 src/if.h
|
||||
|
||||
diff --git a/src/if.c b/src/if.c
|
||||
new file mode 100644
|
||||
index 0000000..db231aa
|
||||
--- /dev/null
|
||||
+++ b/src/if.c
|
||||
@@ -0,0 +1,113 @@
|
||||
+/*
|
||||
+ * $Id: if.c $
|
||||
+ *
|
||||
+ * Author: Markus Stenberg <fingon@iki.fi>
|
||||
+ *
|
||||
+ * Copyright (c) 2012 cisco Systems, Inc.
|
||||
+ *
|
||||
+ * Created: Tue Dec 4 14:50:34 2012 mstenber
|
||||
+ * Last modified: Wed Dec 5 18:51:08 2012 mstenber
|
||||
+ * Edit time: 24 min
|
||||
+ *
|
||||
+ */
|
||||
+
|
||||
+#include <sys/types.h>
|
||||
+#include <sys/socket.h>
|
||||
+#include <net/if.h>
|
||||
+
|
||||
+#include "if.h"
|
||||
+
|
||||
+#include "lauxlib.h"
|
||||
+
|
||||
+static int if_global_indextoname(lua_State *L);
|
||||
+static int if_global_nametoindex(lua_State *L);
|
||||
+static int if_global_nameindex(lua_State *L);
|
||||
+
|
||||
+static luaL_Reg func[] = {
|
||||
+ { "indextoname", if_global_indextoname},
|
||||
+ { "nametoindex", if_global_nametoindex},
|
||||
+ { "nameindex", if_global_nameindex},
|
||||
+ { NULL, NULL}
|
||||
+};
|
||||
+
|
||||
+int if_open(lua_State *L)
|
||||
+{
|
||||
+ lua_pushstring(L, "iface");
|
||||
+ lua_newtable(L);
|
||||
+ luaL_openlib(L, NULL, func, 0);
|
||||
+ lua_settable(L, -3);
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
+int if_global_indextoname(lua_State *L)
|
||||
+{
|
||||
+ unsigned int ifnumber;
|
||||
+ const char *name;
|
||||
+ char buf[IF_NAMESIZE+1];
|
||||
+
|
||||
+ if (!lua_isnumber(L, 1))
|
||||
+ {
|
||||
+ lua_pushnil(L);
|
||||
+ lua_pushstring(L, "indextoname expects only number argument");
|
||||
+ return 2;
|
||||
+ }
|
||||
+ ifnumber = lua_tonumber(L, 1);
|
||||
+ if (!(name = if_indextoname(ifnumber, buf)))
|
||||
+ {
|
||||
+ lua_pushnil(L);
|
||||
+ lua_pushstring(L, "nonexistent interface");
|
||||
+ return 2;
|
||||
+ }
|
||||
+ lua_pushstring(L, name);
|
||||
+ return 1;
|
||||
+}
|
||||
+
|
||||
+int if_global_nametoindex(lua_State *L)
|
||||
+{
|
||||
+ unsigned int ifnumber;
|
||||
+ if (!lua_isstring(L, 1))
|
||||
+ {
|
||||
+ lua_pushnil(L);
|
||||
+ lua_pushstring(L, "nametoindex expects only string argument");
|
||||
+ return 2;
|
||||
+ }
|
||||
+ if (!(ifnumber = if_nametoindex(lua_tostring(L, 1))))
|
||||
+ {
|
||||
+ lua_pushnil(L);
|
||||
+ lua_pushstring(L, "nonexistent interface");
|
||||
+ return 2;
|
||||
+ }
|
||||
+ lua_pushnumber(L, ifnumber);
|
||||
+ return 1;
|
||||
+}
|
||||
+
|
||||
+int if_global_nameindex(lua_State *L)
|
||||
+{
|
||||
+ struct if_nameindex *ni, *oni;
|
||||
+ int i = 1;
|
||||
+ oni = ni = if_nameindex();
|
||||
+ lua_newtable(L);
|
||||
+ while (ni && ni->if_index && *(ni->if_name))
|
||||
+ {
|
||||
+ /* at result[i], we store.. */
|
||||
+ lua_pushnumber(L, i);
|
||||
+
|
||||
+ /* new table with two items - index, name*/
|
||||
+ lua_newtable(L);
|
||||
+ lua_pushstring(L, "index");
|
||||
+ lua_pushnumber(L, ni->if_index);
|
||||
+ lua_settable(L, -3);
|
||||
+
|
||||
+ lua_pushstring(L, "name");
|
||||
+ lua_pushstring(L, ni->if_name);
|
||||
+ lua_settable(L, -3);
|
||||
+
|
||||
+ /* Then, actually store it */
|
||||
+ lua_settable(L, -3);
|
||||
+
|
||||
+ i++;
|
||||
+ ni++;
|
||||
+ }
|
||||
+ if_freenameindex(oni);
|
||||
+ return 1;
|
||||
+}
|
||||
diff --git a/src/if.h b/src/if.h
|
||||
new file mode 100644
|
||||
index 0000000..dc7faf8
|
||||
--- /dev/null
|
||||
+++ b/src/if.h
|
||||
@@ -0,0 +1,27 @@
|
||||
+/*
|
||||
+ * $Id: if.h $
|
||||
+ *
|
||||
+ * Author: Markus Stenberg <fingon@iki.fi>
|
||||
+ *
|
||||
+ * Copyright (c) 2012 cisco Systems, Inc.
|
||||
+ *
|
||||
+ * Created: Tue Dec 4 14:37:24 2012 mstenber
|
||||
+ * Last modified: Tue Dec 4 14:51:43 2012 mstenber
|
||||
+ * Edit time: 7 min
|
||||
+ *
|
||||
+ */
|
||||
+
|
||||
+/* This module provides Lua wrapping for the advanced socket API
|
||||
+ * defined in RFC3542, or mainly, the access to the system's interface
|
||||
+ * list. It is necessary for use of recvmsg/sendmsg.
|
||||
+ *
|
||||
+ * TODO - Do something clever with Windows?
|
||||
+ */
|
||||
+#ifndef IF_H
|
||||
+#define IF_H
|
||||
+
|
||||
+#include "lua.h"
|
||||
+
|
||||
+int if_open(lua_State *L);
|
||||
+
|
||||
+#endif /* IF_H */
|
||||
diff --git a/src/luasocket.c b/src/luasocket.c
|
||||
index e6ee747..85d41a6 100644
|
||||
--- a/src/luasocket.c
|
||||
+++ b/src/luasocket.c
|
||||
@@ -31,6 +31,7 @@
|
||||
#include "tcp.h"
|
||||
#include "udp.h"
|
||||
#include "select.h"
|
||||
+#include "if.h"
|
||||
|
||||
/*-------------------------------------------------------------------------*\
|
||||
* Internal function prototypes
|
||||
@@ -51,6 +52,7 @@ static const luaL_Reg mod[] = {
|
||||
{"tcp", tcp_open},
|
||||
{"udp", udp_open},
|
||||
{"select", select_open},
|
||||
+ {"iface", if_open},
|
||||
{NULL, NULL}
|
||||
};
|
||||
|
||||
diff --git a/src/makefile b/src/makefile
|
||||
index 8d3521e..09d4882 100644
|
||||
--- a/src/makefile
|
||||
+++ b/src/makefile
|
||||
@@ -262,6 +262,7 @@ SOCKET_OBJS= \
|
||||
auxiliar.$(O) \
|
||||
options.$(O) \
|
||||
inet.$(O) \
|
||||
+ if.$(O) \
|
||||
$(SOCKET) \
|
||||
except.$(O) \
|
||||
select.$(O) \
|
||||
@@ -387,6 +388,7 @@ auxiliar.$(O): auxiliar.c auxiliar.h
|
||||
buffer.$(O): buffer.c buffer.h io.h timeout.h
|
||||
except.$(O): except.c except.h
|
||||
inet.$(O): inet.c inet.h socket.h io.h timeout.h usocket.h
|
||||
+if.$(O): if.c if.h
|
||||
io.$(O): io.c io.h timeout.h
|
||||
luasocket.$(O): luasocket.c luasocket.h auxiliar.h except.h \
|
||||
timeout.h buffer.h io.h inet.h socket.h usocket.h tcp.h \
|
||||
diff --git a/src/options.c b/src/options.c
|
||||
index 8ac2a14..1c73e6f 100644
|
||||
--- a/src/options.c
|
||||
+++ b/src/options.c
|
||||
@@ -3,6 +3,9 @@
|
||||
* LuaSocket toolkit
|
||||
\*=========================================================================*/
|
||||
#include <string.h>
|
||||
+#include <sys/types.h>
|
||||
+#include <sys/socket.h>
|
||||
+#include <net/if.h>
|
||||
|
||||
#include "lauxlib.h"
|
||||
|
||||
@@ -285,6 +288,12 @@ static int opt_ip6_setmembership(lua_State *L, p_socket ps, int level, int name)
|
||||
if (!lua_isnil(L, -1)) {
|
||||
if (lua_isnumber(L, -1)) {
|
||||
val.ipv6mr_interface = (unsigned int) lua_tonumber(L, -1);
|
||||
+ } else if (lua_isstring(L, -1)) {
|
||||
+ if (!(val.ipv6mr_interface = if_nametoindex(lua_tostring(L, -1)))) {
|
||||
+ lua_pushnil(L);
|
||||
+ lua_pushstring(L, "nonexistent interface");
|
||||
+ return 2;
|
||||
+ }
|
||||
} else
|
||||
luaL_argerror(L, -1, "number 'interface' field expected");
|
||||
}
|
||||
--
|
||||
1.8.4.rc3
|
||||
|
Loading…
x
Reference in New Issue
Block a user