From 71044fa7abec4ae5dc6665b32da90082aa541c33 Mon Sep 17 00:00:00 2001 From: Poul-Henning Kamp Date: Wed, 2 Apr 1997 17:05:30 +0000 Subject: [PATCH] Allow "modern" syntax: route add -net 192.168.64.0/20 bla bla bla --- sbin/route/route.c | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/sbin/route/route.c b/sbin/route/route.c index 91d7b17a11de..46c1e91df0be 100644 --- a/sbin/route/route.c +++ b/sbin/route/route.c @@ -43,7 +43,7 @@ static const char copyright[] = static char sccsid[] = "@(#)route.c 8.3 (Berkeley) 3/19/94"; */ static const char rcsid[] = - "$Id: route.c,v 1.22 1997/02/22 14:33:10 peter Exp $"; + "$Id: route.c,v 1.23 1997/04/02 16:52:45 phk Exp $"; #endif /* not lint */ #include @@ -692,8 +692,8 @@ newroute(argc, argv) } void -inet_makenetandmask(net, sin) - u_long net; +inet_makenetandmask(net, sin, bits) + u_long net, bits; register struct sockaddr_in *sin; { u_long addr, mask = 0; @@ -702,7 +702,10 @@ inet_makenetandmask(net, sin) rtm_addrs |= RTA_NETMASK; if (net == 0) mask = addr = 0; - else if (net < 128) { + else if (bits) { + addr = net; + mask = 0xffffffff << (32 - bits); + } else if (net < 128) { addr = net << IN_CLASSA_NSHIFT; mask = IN_CLASSA_NET; } else if (net < 65536) { @@ -750,6 +753,7 @@ getaddr(which, s, hpp) struct hostent *hp; struct netent *np; u_long val; + char *q,qs; if (af == 0) { af = AF_INET; @@ -879,6 +883,18 @@ getaddr(which, s, hpp) if (hpp == NULL) hpp = &hp; *hpp = NULL; + + q = strchr(s,'/'); + if (q && which == RTA_DST) { + qs = *q; + *q = '\0'; + if (((val = inet_addr(s)) != INADDR_NONE)) { + inet_makenetandmask( + htonl(val), &su->sin, strtoul(q+1, 0, 0)); + return (0); + } + *q =qs; + } if (((val = inet_addr(s)) != INADDR_NONE) && (which != RTA_DST || forcenet == 0)) { su->sin.sin_addr.s_addr = val; @@ -894,7 +910,7 @@ getaddr(which, s, hpp) (val = np->n_net) != 0)) { netdone: if (which == RTA_DST) - inet_makenetandmask(val, &su->sin); + inet_makenetandmask(val, &su->sin, 0); return (0); } hp = gethostbyname(s);