X-Git-Url: http://git.hungrycats.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=hacks%2Fglx%2Fsonar-icmp.c;h=e74e45d1dc34f70094f38f8c389794233bac1fc9;hb=5f9c47ca98dd43d8f59b7c27d3fde6edfde4fe21;hp=b389f5e2ec700ce1c8d8aeedb0efcb867cf001d0;hpb=7b34ef992563d7bcbb64cc5597dc45fa24470b05;p=xscreensaver diff --git a/hacks/glx/sonar-icmp.c b/hacks/glx/sonar-icmp.c index b389f5e2..e74e45d1 100644 --- a/hacks/glx/sonar-icmp.c +++ b/hacks/glx/sonar-icmp.c @@ -1,4 +1,4 @@ -/* sonar, Copyright (c) 1998-2008 Jamie Zawinski and Stephen Martin +/* sonar, Copyright (c) 1998-2009 Jamie Zawinski and Stephen Martin * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that @@ -60,7 +60,7 @@ #ifndef HAVE_PING sonar_sensor_data * -init_ping (Display *dpy, const char *subnet, int timeout, +init_ping (Display *dpy, char **error_ret, const char *subnet, int timeout, Bool resolve_p, Bool times_p, Bool debug_p) { if (! (!subnet || !*subnet || !strcmp(subnet, "default"))) @@ -205,11 +205,30 @@ resolve_bogie_hostname (ping_data *pd, sonar_bogie *sb, Bool resolve_p) strlen (sb->name) >= 80) return 0; + /* .ssh/known_hosts sometimes contains weirdness like "[host]:port". + Ignore it. */ + if (strchr (sb->name, '[')) + { + if (pd->debug_p) + fprintf (stderr, "%s: ignoring bogus address \"%s\"\n", + progname, sb->name); + return 0; + } + + /* If the name contains a colon, it's probably IPv6. */ + if (strchr (sb->name, ':')) + { + if (pd->debug_p) + fprintf (stderr, "%s: ignoring ipv6 address \"%s\"\n", + progname, sb->name); + return 0; + } + hent = gethostbyname (sb->name); if (!hent) { if (pd->debug_p) - fprintf (stderr, "%s: could not resolve host: %s\n", + fprintf (stderr, "%s: could not resolve host: %s\n", progname, sb->name); return 0; } @@ -327,7 +346,7 @@ read_hosts_file (sonar_sensor_data *ssd, const char *filename) if (!fp) { char buf[1024]; - sprintf(buf, "%s: %s", progname, filename); + sprintf(buf, "%s: %s", progname, filename); #ifdef HAVE_COCOA if (pd->debug_p) /* on OSX don't syslog this */ #endif @@ -347,7 +366,6 @@ read_hosts_file (sonar_sensor_data *ssd, const char *filename) /* Get the name and address */ - name = addr = 0; if ((addr = strtok(buf, " ,;\t\n"))) name = strtok(0, " ,;\t\n"); else @@ -595,7 +613,6 @@ send_ping (ping_data *pd, const sonar_bogie *b) ping_bogie *pb = (ping_bogie *) b->closure; u_char *packet; struct ICMP *icmph; - int result; const char *token = "org.jwz.xscreensaver.sonar"; int pcktsiz = (sizeof(struct ICMP) + sizeof(struct timeval) + @@ -634,8 +651,8 @@ send_ping (ping_data *pd, const sonar_bogie *b) /* Send it */ - if ((result = sendto(pd->icmpsock, packet, pcktsiz, 0, - &pb->address, sizeof(pb->address))) + if (sendto(pd->icmpsock, packet, pcktsiz, 0, + &pb->address, sizeof(pb->address)) != pcktsiz) { #if 0 @@ -1037,7 +1054,7 @@ parse_mode (sonar_sensor_data *ssd, char **error_ret, if (new) { sonar_bogie *nn = new; - while (nn && nn->next) + while (nn->next) nn = nn->next; nn->next = hostlist; hostlist = new;