summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTony Garnock-Jones <tonyg@rabbitmq.com>2010-07-11 14:11:11 +1200
committerTony Garnock-Jones <tonyg@rabbitmq.com>2010-07-11 14:11:11 +1200
commit252e5ac851fe74ed6cbac0f456e2067efbdaac7c (patch)
tree4bfb5570efaed64619ddaa1495210fec9e501ab8
parentd2fb070fe6e36075de389f59729ff4b022eed9a0 (diff)
downloadrabbitmq-c-github-ask-bug22931.tar.gz
Dedup error handling codebug22931
-rw-r--r--librabbitmq/amqp_socket.c12
1 files changed, 3 insertions, 9 deletions
diff --git a/librabbitmq/amqp_socket.c b/librabbitmq/amqp_socket.c
index d62f744..35e9c3d 100644
--- a/librabbitmq/amqp_socket.c
+++ b/librabbitmq/amqp_socket.c
@@ -75,6 +75,7 @@ int amqp_open_socket(char const *hostname,
int sockfd;
struct sockaddr_in addr;
struct hostent *he;
+ int one = 1; /* used as a buffer by setsockopt below */
he = gethostbyname(hostname);
if (he == NULL) {
@@ -90,16 +91,9 @@ int amqp_open_socket(char const *hostname,
return -errno;
}
+ if ((setsockopt(sockfd, IPPROTO_TCP, TCP_NODELAY, &one, sizeof(one)) < 0) ||
+ (connect(sockfd, (struct sockaddr *) &addr, sizeof(addr)) < 0))
{
- int one = 1;
- if (setsockopt(sockfd, IPPROTO_TCP, TCP_NODELAY, &one, sizeof(one)) < 0) {
- int result = -errno;
- close(sockfd);
- return result;
- }
- }
-
- if (connect(sockfd, (struct sockaddr *) &addr, sizeof(addr)) < 0) {
int result = -errno;
close(sockfd);
return result;