Use a function instead of a macro.

(cherry picked from commit f3e4a8bb245afe874561eb7275f49dae0e7e55dd)

Change-Id: If5359c26a1474de0c278193fd2f09168f3184dee
This commit is contained in:
Sreeram Ramachandran 2014-05-13 23:50:44 -07:00
parent b87b17a895
commit 6af621f792

View file

@ -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;