summaryrefslogtreecommitdiffhomepage
path: root/libs/nixio/src/address.c
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2010-03-28 19:42:09 +0000
committerSteven Barth <steven@midlink.org>2010-03-28 19:42:09 +0000
commit53f812b11a63dd5c47f6bfefc0611238269f4ae9 (patch)
tree1298668bf8fb634c394097bc5240c9eed4c2ef8c /libs/nixio/src/address.c
parent61b9022e51798f389739d1aaf68a0e0231fc4ea7 (diff)
nixio: Fix interface data for layer 3+ interfaces
Diffstat (limited to 'libs/nixio/src/address.c')
-rw-r--r--libs/nixio/src/address.c74
1 files changed, 42 insertions, 32 deletions
diff --git a/libs/nixio/src/address.c b/libs/nixio/src/address.c
index 41c6b8ae8..eff05e3a0 100644
--- a/libs/nixio/src/address.c
+++ b/libs/nixio/src/address.c
@@ -391,9 +391,11 @@ static int nixio_getifaddrs(lua_State *L) {
lua_setfield(L, -2, "multicast");
lua_setfield(L, -2, "flags");
- if (c->ifa_addr && !nixio__addr_parse(&addr, c->ifa_addr)) {
- lua_pushstring(L, addr.host);
- lua_setfield(L, -2, "addr");
+ if (c->ifa_addr) {
+ if (!nixio__addr_parse(&addr, c->ifa_addr)) {
+ lua_pushstring(L, addr.host);
+ lua_setfield(L, -2, "addr");
+ }
if (c->ifa_addr->sa_family == AF_INET) {
lua_pushliteral(L, "inet");
@@ -415,47 +417,55 @@ static int nixio_getifaddrs(lua_State *L) {
lua_pushinteger(L, addr.prefix);
lua_setfield(L, -2, "hatype");
+ }
+#endif
+ }
- if (c->ifa_data) {
- lua_createtable(L, 0, 10);
- struct nixio__nds *stats = c->ifa_data;
+#ifdef __linux__
+ if (c->ifa_data && (!c->ifa_addr
+ || c->ifa_addr->sa_family == AF_PACKET)) {
+ if (!c->ifa_addr) {
+ lua_pushliteral(L, "packet");
+ lua_setfield(L, -2, "family");
+ }
- lua_pushnumber(L, stats->rx_packets);
- lua_setfield(L, -2, "rx_packets");
+ lua_createtable(L, 0, 10);
+ struct nixio__nds *stats = c->ifa_data;
- lua_pushnumber(L, stats->tx_packets);
- lua_setfield(L, -2, "tx_packets");
+ lua_pushnumber(L, stats->rx_packets);
+ lua_setfield(L, -2, "rx_packets");
- lua_pushnumber(L, stats->rx_bytes);
- lua_setfield(L, -2, "rx_bytes");
+ lua_pushnumber(L, stats->tx_packets);
+ lua_setfield(L, -2, "tx_packets");
- lua_pushnumber(L, stats->tx_bytes);
- lua_setfield(L, -2, "tx_bytes");
+ lua_pushnumber(L, stats->rx_bytes);
+ lua_setfield(L, -2, "rx_bytes");
- lua_pushnumber(L, stats->rx_errors);
- lua_setfield(L, -2, "rx_errors");
+ lua_pushnumber(L, stats->tx_bytes);
+ lua_setfield(L, -2, "tx_bytes");
- lua_pushnumber(L, stats->tx_errors);
- lua_setfield(L, -2, "tx_errors");
+ lua_pushnumber(L, stats->rx_errors);
+ lua_setfield(L, -2, "rx_errors");
- lua_pushnumber(L, stats->rx_dropped);
- lua_setfield(L, -2, "rx_dropped");
+ lua_pushnumber(L, stats->tx_errors);
+ lua_setfield(L, -2, "tx_errors");
- lua_pushnumber(L, stats->tx_dropped);
- lua_setfield(L, -2, "tx_dropped");
+ lua_pushnumber(L, stats->rx_dropped);
+ lua_setfield(L, -2, "rx_dropped");
- lua_pushnumber(L, stats->multicast);
- lua_setfield(L, -2, "multicast");
+ lua_pushnumber(L, stats->tx_dropped);
+ lua_setfield(L, -2, "tx_dropped");
- lua_pushnumber(L, stats->collisions);
- lua_setfield(L, -2, "collisions");
- } else {
- lua_newtable(L);
- }
- lua_setfield(L, -2, "data");
- }
-#endif
+ lua_pushnumber(L, stats->multicast);
+ lua_setfield(L, -2, "multicast");
+
+ lua_pushnumber(L, stats->collisions);
+ lua_setfield(L, -2, "collisions");
+ } else {
+ lua_newtable(L);
}
+ lua_setfield(L, -2, "data");
+#endif
if (c->ifa_netmask && !nixio__addr_parse(&addr, c->ifa_netmask)) {
lua_pushstring(L, addr.host);