diff options
author | Sreeram Ramachandran <sreeram@google.com> | 2014-05-13 23:50:44 -0700 |
---|---|---|
committer | Lorenzo Colitti <lorenzo@google.com> | 2014-05-14 04:12:42 -0700 |
commit | d887641f64cb6395e22d8f5d7ece01c8d3d1e951 (patch) | |
tree | 834da4a581b41f95f825e8d0fae141a497576441 /libnetd_client | |
parent | 0c2dfc3950181001e060c2b47abe967ce34b878d (diff) | |
download | system_core-d887641f64cb6395e22d8f5d7ece01c8d3d1e951.zip system_core-d887641f64cb6395e22d8f5d7ece01c8d3d1e951.tar.gz system_core-d887641f64cb6395e22d8f5d7ece01c8d3d1e951.tar.bz2 |
Use a function instead of a macro.
Change-Id: If5359c26a1474de0c278193fd2f09168f3184dee
Diffstat (limited to 'libnetd_client')
-rw-r--r-- | libnetd_client/NetdClient.cpp | 20 |
1 files changed, 9 insertions, 11 deletions
diff --git a/libnetd_client/NetdClient.cpp b/libnetd_client/NetdClient.cpp index f7e8cc2..8deea1e 100644 --- a/libnetd_client/NetdClient.cpp +++ b/libnetd_client/NetdClient.cpp @@ -20,15 +20,15 @@ #include <sys/socket.h> #include <unistd.h> -#define CLOSE_FD_AND_RESTORE_ERRNO(fd) \ - do { \ - int error = errno; \ - close(fd); \ - errno = error; \ - } while (0) - namespace { +int closeFdAndRestoreErrno(int fd) { + int error = errno; + close(fd); + errno = error; + return -1; +} + typedef int (*ConnectFunctionType)(int, const sockaddr*, socklen_t); typedef int (*AcceptFunctionType)(int, sockaddr*, socklen_t*); @@ -54,16 +54,14 @@ int netdClientAccept(int sockfd, sockaddr* addr, socklen_t* addrlen) { if (!addr) { socklen_t socketAddressLen = sizeof(socketAddress); if (getsockname(acceptedSocket, &socketAddress, &socketAddressLen) == -1) { - CLOSE_FD_AND_RESTORE_ERRNO(acceptedSocket); - return -1; + return closeFdAndRestoreErrno(acceptedSocket); } addr = &socketAddress; } if (FwmarkClient::shouldSetFwmark(acceptedSocket, addr)) { char data[] = {FWMARK_COMMAND_ON_ACCEPT}; if (!FwmarkClient().send(data, sizeof(data), acceptedSocket)) { - CLOSE_FD_AND_RESTORE_ERRNO(acceptedSocket); - return -1; + return closeFdAndRestoreErrno(acceptedSocket); } } return acceptedSocket; |