X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=client_common.c;h=d13892599cd4b503c50164f9a7010ab40c6d2016;hp=c738079b6b1f92ab47435bfea9eb6185aa52eef2;hb=be0b6d883628d8ff9043107f1ddd780838facd3d;hpb=55d88deacdb93185b326b2fe968e6f11d26af46d diff --git a/client_common.c b/client_common.c index c738079b..d1389259 100644 --- a/client_common.c +++ b/client_common.c @@ -295,29 +295,32 @@ int client_open(struct private_client_data *pcd) struct hostent *he; struct sockaddr_in their_addr; + pcd->fd = -1; ret = get_host_info(pcd->conf.hostname_arg, &he); if (ret < 0) - goto out; + goto err_out; /* get new socket */ ret = get_socket(); if (ret < 0) - goto out; + goto err_out; pcd->fd = ret; /* init their_addr */ init_sockaddr(&their_addr, pcd->conf.server_port_arg, he); ret = para_connect(pcd->fd, &their_addr); if (ret < 0) - goto out; + goto err_out; pcd->status = CL_CONNECTED; ret = mark_fd_nonblock(pcd->fd); if (ret < 0) - goto out; + goto err_out; pcd->task.pre_select = client_pre_select; pcd->task.post_select = client_post_select; pcd->task.private_data = pcd; sprintf(pcd->task.status, "client"); register_task(&pcd->task); - ret = 1; -out: + return 1; +err_out: + if (pcd->fd >= 0) + close(pcd->fd); return ret; }