Convert from CIRCLEQ to TAILQ.

This commit is contained in:
Poul-Henning Kamp 2000-12-29 20:33:28 +00:00
parent fabacd3a11
commit c5e5cd90bd
2 changed files with 44 additions and 46 deletions

View File

@ -79,11 +79,11 @@ struct dbent {
int flags;
};
static CIRCLEQ_HEAD(circlehead, circleq_entry) qhead;
static TAILQ_HEAD(circlehead, circleq_entry) qhead;
struct circleq_entry {
struct dbent *dbptr;
CIRCLEQ_ENTRY(circleq_entry) links;
TAILQ_ENTRY(circleq_entry) links;
};
/*
@ -91,7 +91,7 @@ struct circleq_entry {
*/
void yp_init_dbs()
{
CIRCLEQ_INIT(&qhead);
TAILQ_INIT(&qhead);
return;
}
@ -166,8 +166,8 @@ static void yp_flush()
{
register struct circleq_entry *qptr;
qptr = qhead.cqh_last;
CIRCLEQ_REMOVE(&qhead, qptr, links);
qptr = TAILQ_LAST(&qhead, circlehead);
TAILQ_REMOVE(&qhead, qptr, links);
yp_free_qent(qptr);
numdbs--;
@ -181,9 +181,9 @@ void yp_flush_all()
{
register struct circleq_entry *qptr;
while(qhead.cqh_first != (void *)&qhead) {
qptr = qhead.cqh_first; /* save this */
CIRCLEQ_REMOVE(&qhead, qhead.cqh_first, links);
while(!TAILQ_EMPTY(&qhead)) {
qptr = TAILQ_FIRST(&qhead); /* save this */
TAILQ_REMOVE(&qhead, qptr, links);
yp_free_qent(qptr);
}
numdbs = 0;
@ -232,8 +232,7 @@ int yp_testflag(map, domain, flag)
strcat(buf, "/");
strcat(buf, map);
for (qptr = qhead.cqh_first; qptr != (void *)&qhead;
qptr = qptr->links.cqe_next) {
TAILQ_FOREACH(qptr, &qhead, links) {
if (!strcmp(qptr->dbptr->name, buf)) {
if (qptr->dbptr->flags & flag)
return(1);
@ -245,7 +244,7 @@ int yp_testflag(map, domain, flag)
if (yp_open_db_cache(domain, map, NULL, 0) == NULL)
return(0);
if (qhead.cqh_first->dbptr->flags & flag)
if (TAILQ_FIRST(&qhead)->dbptr->flags & flag)
return(1);
return(0);
@ -286,7 +285,7 @@ static int yp_cache_db(dbp, name, size)
qptr->dbptr->flags = yp_setflags(dbp);
CIRCLEQ_INSERT_HEAD(&qhead, qptr, links);
TAILQ_INSERT_HEAD(&qhead, qptr, links);
numdbs++;
return(0);
@ -325,8 +324,7 @@ static DB *yp_find_db(name, key, size)
{
register struct circleq_entry *qptr;
for (qptr = qhead.cqh_first; qptr != (void *)&qhead;
qptr = qptr->links.cqe_next) {
TAILQ_FOREACH(qptr, &qhead, links) {
if (!strcmp(qptr->dbptr->name, name)) {
if (size) {
if (size != qptr->dbptr->size ||
@ -336,9 +334,9 @@ static DB *yp_find_db(name, key, size)
if (qptr->dbptr->size)
continue;
}
if (qptr != qhead.cqh_first) {
CIRCLEQ_REMOVE(&qhead, qptr, links);
CIRCLEQ_INSERT_HEAD(&qhead, qptr, links);
if (qptr != TAILQ_FIRST(&qhead)) {
TAILQ_REMOVE(&qhead, qptr, links);
TAILQ_INSERT_HEAD(&qhead, qptr, links);
}
return(qptr->dbptr->dbp);
}
@ -496,7 +494,7 @@ int yp_get_record(domain,map,key,data,allow)
if ((rval = (dbp->get)(dbp, key, data, 0)) != 0) {
#ifdef DB_CACHE
qhead.cqh_first->dbptr->size = 0;
TAILQ_FIRST(&qhead)->dbptr->size = 0;
#else
(void)(dbp->close)(dbp);
#endif
@ -511,9 +509,9 @@ int yp_get_record(domain,map,key,data,allow)
key->size, key->data, data->size, data->data);
#ifdef DB_CACHE
if (qhead.cqh_first->dbptr->size) {
qhead.cqh_first->dbptr->key = "";
qhead.cqh_first->dbptr->size = 0;
if (TAILQ_FIRST(&qhead)->dbptr->size) {
TAILQ_FIRST(&qhead)->dbptr->key = "";
TAILQ_FIRST(&qhead)->dbptr->size = 0;
}
#else
bcopy((char *)data->data, (char *)&buf, data->size);
@ -540,7 +538,7 @@ int yp_first_record(dbp,key,data,allow)
if ((rval = (dbp->seq)(dbp,key,data,R_FIRST)) != 0) {
#ifdef DB_CACHE
qhead.cqh_first->dbptr->size = 0;
TAILQ_FIRST(&qhead)->dbptr->size = 0;
#endif
if (rval == 1)
return(YP_NOKEY);
@ -552,7 +550,7 @@ int yp_first_record(dbp,key,data,allow)
while (!strncmp(key->data, "YP_", 3) && !allow) {
if ((rval = (dbp->seq)(dbp,key,data,R_NEXT)) != 0) {
#ifdef DB_CACHE
qhead.cqh_first->dbptr->size = 0;
TAILQ_FIRST(&qhead)->dbptr->size = 0;
#endif
if (rval == 1)
return(YP_NOKEY);
@ -566,9 +564,9 @@ int yp_first_record(dbp,key,data,allow)
key->size, key->data, data->size, data->data);
#ifdef DB_CACHE
if (qhead.cqh_first->dbptr->size) {
qhead.cqh_first->dbptr->key = key->data;
qhead.cqh_first->dbptr->size = key->size;
if (TAILQ_FIRST(&qhead)->dbptr->size) {
TAILQ_FIRST(&qhead)->dbptr->key = key->data;
TAILQ_FIRST(&qhead)->dbptr->size = key->size;
}
#else
bcopy((char *)data->data, (char *)&buf, data->size);
@ -599,8 +597,8 @@ int yp_next_record(dbp,key,data,all,allow)
return(YP_NOMORE);
else {
#ifdef DB_CACHE
qhead.cqh_first->dbptr->key = key->data;
qhead.cqh_first->dbptr->size = key->size;
TAILQ_FIRST(&qhead)->dbptr->key = key->data;
TAILQ_FIRST(&qhead)->dbptr->size = key->size;
#endif
return(rval);
}
@ -612,7 +610,7 @@ int yp_next_record(dbp,key,data,all,allow)
if (!all) {
#ifdef DB_CACHE
if (qhead.cqh_first->dbptr->key == NULL) {
if (TAILQ_FIRST(&qhead)->dbptr->key == NULL) {
#endif
(dbp->seq)(dbp,&lkey,&ldata,R_FIRST);
while (key->size != lkey.size ||
@ -620,7 +618,7 @@ int yp_next_record(dbp,key,data,all,allow)
(int)key->size))
if ((dbp->seq)(dbp,&lkey,&ldata,R_NEXT)) {
#ifdef DB_CACHE
qhead.cqh_first->dbptr->size = 0;
TAILQ_FIRST(&qhead)->dbptr->size = 0;
#endif
return(YP_NOKEY);
}
@ -632,7 +630,7 @@ int yp_next_record(dbp,key,data,all,allow)
if ((dbp->seq)(dbp,key,data,R_NEXT)) {
#ifdef DB_CACHE
qhead.cqh_first->dbptr->size = 0;
TAILQ_FIRST(&qhead)->dbptr->size = 0;
#endif
return(YP_NOMORE);
}
@ -641,7 +639,7 @@ int yp_next_record(dbp,key,data,all,allow)
while (!strncmp(key->data, "YP_", 3) && !allow)
if ((dbp->seq)(dbp,key,data,R_NEXT)) {
#ifdef DB_CACHE
qhead.cqh_first->dbptr->size = 0;
TAILQ_FIRST(&qhead)->dbptr->size = 0;
#endif
return(YP_NOMORE);
}
@ -651,9 +649,9 @@ int yp_next_record(dbp,key,data,all,allow)
key->size, key->data, data->size, data->data);
#ifdef DB_CACHE
if (qhead.cqh_first->dbptr->size) {
qhead.cqh_first->dbptr->key = key->data;
qhead.cqh_first->dbptr->size = key->size;
if (TAILQ_FIRST(&qhead)->dbptr->size) {
TAILQ_FIRST(&qhead)->dbptr->key = key->data;
TAILQ_FIRST(&qhead)->dbptr->size = key->size;
}
#else
bcopy((char *)key->data, (char *)&keybuf, key->size);

View File

@ -105,7 +105,7 @@ static char *parse(hp)
extern struct hostent *__dns_getanswer __P((char *, int, char *, int));
static CIRCLEQ_HEAD(dns_qhead, circleq_dnsentry) qhead;
static TAILQ_HEAD(dns_qhead, circleq_dnsentry) qhead;
struct circleq_dnsentry {
SVCXPRT *xprt;
@ -119,14 +119,14 @@ struct circleq_dnsentry {
char **domain;
char *name;
struct in_addr addr;
CIRCLEQ_ENTRY(circleq_dnsentry) links;
TAILQ_ENTRY(circleq_dnsentry) links;
};
static int pending = 0;
int yp_init_resolver()
{
CIRCLEQ_INIT(&qhead);
TAILQ_INIT(&qhead);
if (!(_res.options & RES_INIT) && res_init() == -1) {
yp_error("res_init failed");
return(1);
@ -201,7 +201,7 @@ static struct circleq_dnsentry *yp_find_dnsqent(id, type)
{
register struct circleq_dnsentry *q;
for (q = qhead.cqh_first; q != (void *)&qhead; q = q->links.cqe_next) {
TAILQ_FOREACH(q, &qhead, links) {
switch(type) {
case BY_RPC_XID:
if (id == q->xid)
@ -318,12 +318,12 @@ void yp_prune_dnsq()
{
register struct circleq_dnsentry *q, *n;
q = qhead.cqh_first;
while(q != (void *)&qhead) {
q = TAILQ_FIRST(&qhead);
while(q != NULL) {
q->ttl--;
n = q->links.cqe_next;
n = TAILQ_NEXT(q, links);
if (!q->ttl) {
CIRCLEQ_REMOVE(&qhead, q, links);
TAILQ_REMOVE(&qhead, q, links);
free(q->name);
free(q);
pending--;
@ -412,7 +412,7 @@ void yp_run_dnsq()
/* Got an answer ready for a client -- send it off. */
yp_send_dns_reply(q, parse(hent));
pending--;
CIRCLEQ_REMOVE(&qhead, q, links);
TAILQ_REMOVE(&qhead, q, links);
free(q->name);
free(q);
@ -466,7 +466,7 @@ ypstat yp_async_lookup_name(rqstp, name)
}
q->name = strdup(name);
CIRCLEQ_INSERT_HEAD(&qhead, q, links);
TAILQ_INSERT_HEAD(&qhead, q, links);
pending++;
if (debug)
@ -531,7 +531,7 @@ ypstat yp_async_lookup_addr(rqstp, addr)
inet_aton(addr, &q->addr);
q->name = strdup(buf);
CIRCLEQ_INSERT_HEAD(&qhead, q, links);
TAILQ_INSERT_HEAD(&qhead, q, links);
pending++;
if (debug)