trygetif.c revision 1.1 1 1.1 gwr /*
2 1.1 gwr * trygetif.c - test program for getif.c
3 1.1 gwr */
4 1.1 gwr
5 1.1 gwr #include <sys/types.h>
6 1.1 gwr #include <sys/socket.h>
7 1.1 gwr
8 1.1 gwr #if defined(SUNOS) || defined(SVR4)
9 1.1 gwr #include <sys/sockio.h>
10 1.1 gwr #endif
11 1.1 gwr
12 1.1 gwr #include <net/if.h> /* for struct ifreq */
13 1.1 gwr #include <netinet/in.h>
14 1.1 gwr #include <arpa/inet.h> /* inet_ntoa */
15 1.1 gwr
16 1.1 gwr #include <netdb.h>
17 1.1 gwr #include <stdio.h>
18 1.1 gwr #include <ctype.h>
19 1.1 gwr #include <errno.h>
20 1.1 gwr
21 1.1 gwr #include "getif.h"
22 1.1 gwr
23 1.1 gwr int debug = 0;
24 1.1 gwr char *progname;
25 1.1 gwr
26 1.1 gwr main(argc, argv)
27 1.1 gwr char **argv;
28 1.1 gwr {
29 1.1 gwr struct hostent *hep;
30 1.1 gwr struct sockaddr ea; /* Ethernet address */
31 1.1 gwr struct sockaddr_in *sip; /* Interface address */
32 1.1 gwr struct ifreq *ifr;
33 1.1 gwr struct in_addr dst_addr;
34 1.1 gwr struct in_addr *dap;
35 1.1 gwr int i, s;
36 1.1 gwr
37 1.1 gwr progname = argv[0]; /* for report */
38 1.1 gwr
39 1.1 gwr dap = NULL;
40 1.1 gwr if (argc > 1) {
41 1.1 gwr dap = &dst_addr;
42 1.1 gwr if (isdigit(argv[1][0]))
43 1.1 gwr dst_addr.s_addr = inet_addr(argv[1]);
44 1.1 gwr else {
45 1.1 gwr hep = gethostbyname(argv[1]);
46 1.1 gwr if (!hep) {
47 1.1 gwr printf("gethostbyname(%s)\n", argv[1]);
48 1.1 gwr exit(1);
49 1.1 gwr }
50 1.1 gwr memcpy(&dst_addr, hep->h_addr, sizeof(dst_addr));
51 1.1 gwr }
52 1.1 gwr }
53 1.1 gwr s = socket(AF_INET, SOCK_DGRAM, 0);
54 1.1 gwr if (s < 0) {
55 1.1 gwr perror("socket open");
56 1.1 gwr exit(1);
57 1.1 gwr }
58 1.1 gwr ifr = getif(s, dap);
59 1.1 gwr if (!ifr) {
60 1.1 gwr printf("no interface for address\n");
61 1.1 gwr exit(1);
62 1.1 gwr }
63 1.1 gwr printf("Intf-name:%s\n", ifr->ifr_name);
64 1.1 gwr sip = (struct sockaddr_in *) &(ifr->ifr_addr);
65 1.1 gwr printf("Intf-addr:%s\n", inet_ntoa(sip->sin_addr));
66 1.1 gwr
67 1.1 gwr exit(0);
68 1.1 gwr }
69