* Copyright (c) 1986, 1988 Regents of the University of California.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by the University of
* California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
static char sccsid
[] = "@(#)db_glue.c 4.4 (Berkeley) 6/1/90";
#include <arpa/nameser.h>
struct valuelist
*next
, *prev
;
} *servicelist
, *protolist
;
while (sp
= getservent()) {
slp
= (struct valuelist
*)malloc(sizeof(struct valuelist
));
slp
->name
= savestr(sp
->s_name
);
slp
->proto
= savestr(sp
->s_proto
);
slp
->port
= ntohs((u_short
)sp
->s_port
);
while (pp
= getprotoent()) {
slp
= (struct valuelist
*)malloc(sizeof(struct valuelist
));
slp
->name
= savestr(pp
->p_name
);
* Convert service name or (ascii) number to int.
return (findservice(p
, &servicelist
));
* Convert protocol name or (ascii) number to int.
return (findservice(p
, &protolist
));
register struct valuelist
**list
;
register struct valuelist
*lp
= *list
;
for (; lp
!= NULL
; lp
= lp
->next
)
if (strcasecmp(lp
->name
, s
) == 0) {
lp
->prev
->next
= lp
->next
;
lp
->next
->prev
= lp
->prev
;
if (sscanf(s
, "%d", &n
) != 1 || n
<= 0)
cgetservbyport(port
, proto
)
register struct valuelist
**list
= &servicelist
;
register struct valuelist
*lp
= *list
;
static struct servent serv
;
for (; lp
!= NULL
; lp
= lp
->next
) {
if (strcasecmp(lp
->proto
, proto
) == 0) {
lp
->prev
->next
= lp
->next
;
lp
->next
->prev
= lp
->prev
;
serv
.s_port
= htons((u_short
)lp
->port
);
serv
.s_proto
= lp
->proto
;
register struct valuelist
**list
= &protolist
;
register struct valuelist
*lp
= *list
;
static struct protoent prot
;
for (; lp
!= NULL
; lp
= lp
->next
)
lp
->prev
->next
= lp
->next
;
lp
->next
->prev
= lp
->prev
;
pp
= cgetprotobynumber(num
);
(void) sprintf(number
, "%d", num
);
ss
= cgetservbyport(htons(port
), proto
);
(void) sprintf(number
, "%d", port
);