summaryrefslogtreecommitdiffhomepage
path: root/libs/nixio
diff options
context:
space:
mode:
authorSteven Barth <steven@midlink.org>2009-03-13 12:10:33 +0000
committerSteven Barth <steven@midlink.org>2009-03-13 12:10:33 +0000
commitedda19be9a6b5210523b54d87224f885232c847f (patch)
tree481dd77bdc629ef47d522739952a43164df4ede5 /libs/nixio
parent5fa29b1c5a6f50817e3280ff9eb638f9ce0669ad (diff)
nixio: More sockopts
Diffstat (limited to 'libs/nixio')
-rw-r--r--libs/nixio/src/sockopt.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/libs/nixio/src/sockopt.c b/libs/nixio/src/sockopt.c
index 5965eaefe..2d68d12ef 100644
--- a/libs/nixio/src/sockopt.c
+++ b/libs/nixio/src/sockopt.c
@@ -108,6 +108,8 @@ static int nixio__gso_timev(lua_State *L, int fd, int level, int opt, int set) {
return nixio__perror(L);
}
+#ifdef SO_BINDTODEVICE
+
static int nixio__gso_b(lua_State *L, int fd, int level, int opt, int set) {
if (!set) {
socklen_t optlen = IFNAMSIZ;
@@ -128,6 +130,8 @@ static int nixio__gso_b(lua_State *L, int fd, int level, int opt, int set) {
return nixio__perror(L);
}
+#endif /* SO_BINDTODEVICE */
+
/**
* get/setsockopt() helper
*/
@@ -156,6 +160,10 @@ static int nixio__getsetsockopt(lua_State *L, int set) {
return nixio__gso_int(L, sock->fd, SOL_SOCKET, SO_BROADCAST, set);
} else if (!strcmp(option, "dontroute")) {
return nixio__gso_int(L, sock->fd, SOL_SOCKET, SO_DONTROUTE, set);
+ } else if (!strcmp(option, "error")) {
+ return nixio__gso_int(L, sock->fd, SOL_SOCKET, SO_ERROR, set);
+ } else if (!strcmp(option, "oobinline")) {
+ return nixio__gso_int(L, sock->fd, SOL_SOCKET, SO_OOBINLINE, set);
} else if (!strcmp(option, "linger")) {
return nixio__gso_ling(L, sock->fd, SOL_SOCKET, SO_LINGER, set);
} else if (!strcmp(option, "sndtimeo")) {
@@ -163,11 +171,15 @@ static int nixio__getsetsockopt(lua_State *L, int set) {
} else if (!strcmp(option, "rcvtimeo")) {
return nixio__gso_timev(L, sock->fd, SOL_SOCKET, SO_RCVTIMEO, set);
} else if (!strcmp(option, "bindtodevice")) {
+#ifdef SO_BINDTODEVICE
return nixio__gso_b(L, sock->fd, SOL_SOCKET, SO_BINDTODEVICE, set);
+#else
+ return nixio__pstatus(L, !(errno = ENOPROTOOPT));
+#endif
} else {
return luaL_argerror(L, 3, "supported values: keepalive, reuseaddr,"
" sndbuf, rcvbuf, priority, broadcast, linger, sndtimeo, rcvtimeo,"
- " dontroute, bindtodevice"
+ " dontroute, bindtodevice, error, oobinline"
);
}
} else if (!strcmp(level, "tcp")) {