diff options
Diffstat (limited to 'sbin/sysctl/sysctl.c')
-rw-r--r-- | sbin/sysctl/sysctl.c | 59 |
1 files changed, 33 insertions, 26 deletions
diff --git a/sbin/sysctl/sysctl.c b/sbin/sysctl/sysctl.c index cfc4b581b04..d6335fec45d 100644 --- a/sbin/sysctl/sysctl.c +++ b/sbin/sysctl/sysctl.c @@ -1,4 +1,4 @@ -/* $OpenBSD: sysctl.c,v 1.16 1997/08/19 05:32:57 millert Exp $ */ +/* $OpenBSD: sysctl.c,v 1.17 1997/08/19 05:53:12 millert Exp $ */ /* $NetBSD: sysctl.c,v 1.9 1995/09/30 07:12:50 thorpej Exp $ */ /* @@ -44,7 +44,7 @@ static char copyright[] = #if 0 static char sccsid[] = "@(#)sysctl.c 8.1 (Berkeley) 6/6/93"; #else -static char *rcsid = "$OpenBSD: sysctl.c,v 1.16 1997/08/19 05:32:57 millert Exp $"; +static char *rcsid = "$OpenBSD: sysctl.c,v 1.17 1997/08/19 05:53:12 millert Exp $"; #endif #endif /* not lint */ @@ -362,24 +362,24 @@ parse(string, flags) in_port_t port; special |= BADDYNAMIC; - if (newval != NULL) { - (void)memset((void *)&newbaddynamic, 0, - sizeof(newbaddynamic)); - while (newval && - (cp = strsep((char **)&newval, - ", \t")) && *cp) { - port = atoi(cp); - if (port < IPPORT_RESERVED/2 || - port >= IPPORT_RESERVED) - errx(1, "invalid port, " - "range is %d to %d", - IPPORT_RESERVED/2, - IPPORT_RESERVED-1); - DP_SET(newbaddynamic, port); - } - newval = (void *)newbaddynamic; - newsize = sizeof(newbaddynamic); + if (newval == NULL); + break; + + (void)memset((void *)&newbaddynamic, 0, + sizeof(newbaddynamic)); + while (newval && (cp = strsep((char **)&newval, + ", \t")) && *cp) { + port = atoi(cp); + if (port < IPPORT_RESERVED/2 || + port >= IPPORT_RESERVED) + errx(1, "invalid port, " + "range is %d to %d", + IPPORT_RESERVED/2, + IPPORT_RESERVED-1); + DP_SET(newbaddynamic, port); } + newval = (void *)newbaddynamic; + newsize = sizeof(newbaddynamic); } break; } @@ -515,22 +515,29 @@ parse(string, flags) return; } if (special & BADDYNAMIC) { - in_port_t port; + in_port_t port, lastport; u_int32_t *baddynamic = (u_int32_t *)buf; if (!nflag) - printf("%s%s", string, newsize ? ":" : " ="); + printf("%s%s", string, newsize ? ": " : " = "); + lastport = 0; for (port = IPPORT_RESERVED/2; port < IPPORT_RESERVED; port++) - if (DP_ISSET(baddynamic, port)) - printf(" %hd", port); + if (DP_ISSET(baddynamic, port)) { + printf("%s%hd", lastport ? "," : "", port); + lastport = port; + } if (newsize != 0) { if (!nflag) - fputs(" ->", stdout); + fputs(" -> ", stdout); baddynamic = (u_int32_t *)newval; + lastport = 0; for (port = IPPORT_RESERVED/2; port < IPPORT_RESERVED; port++) - if (DP_ISSET(baddynamic, port)) - printf(" %hd", port); + if (DP_ISSET(baddynamic, port)) { + printf("%s%hd", lastport ? "," : "", + port); + lastport = port; + } } putchar('\n'); return; |