Corretto titolo della sezione IPC, e iniziato a scrivere funzione generica
[gapil.git] / sources / sockconn.c
1 /* sockconn.c
2  * 
3  * Copyright (C) 2004 Simone Piccardi
4  * 
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 2 of the License, or (at
8  * your option) any later version.
9  * 
10  * This program is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13  * General Public License for more details.
14  * 
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
18  */
19 /****************************************************************
20  *
21  * Routine sockconn
22  * Return a connected socket given hostname, service, and socket type
23  *
24  * Author: Simone Piccardi
25  * Dec. 2004
26  *
27  * $Id$ 
28  *
29  ****************************************************************/
30 #include <arpa/inet.h>
31 #include <sys/socket.h>
32 #include <netinet/in.h>
33 #include <errno.h>
34
35 int sockconn(char *host, char *serv, int prot, int type) 
36 {
37     struct addrinfo hint, *addr;
38     int res;
39     int sock
40     /* initialize hint */
41     memset(&hint, 0, sizeof(hint)); 
42     hint.ai_family = PF_UNSPEC;
43     hint.ai_protocol = prot;
44     hint.ai_socktype = type;
45     res = getaddrinfo(host, serv, &hint, &addr);
46     if (res != 0) {
47         printf("sockconn cannot resolve host %s, service %s,
48                 protocol %d: %s\n", host, serv, prot, gai_strerror(res));
49         errno = 0;
50         return -1;
51     }
52     sock = socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
53     if (sock < 0) {
54         perror("sockconn cannot create socket\n");
55         return sock;
56     }
57     res = connect(sock, addr->ai_addr, addr->ai_addrlen);
58     if (res < 0) {
59         perror("sockconn cannot connect socket\n");
60         return res;
61     }
62     freeaddrinfo(addr);
63     return sock;
64 }
65