DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - metrics - download
Index: T l

⟦051b1a4d2⟧ TextFile

    Length: 2238 (0x8be)
    Types: TextFile
    Names: »list_bpt.c«

Derivation

└─⟦2d1937cfd⟧ Bits:30007241 EUUGD22: P.P 5.0
    └─⟦dc59850a2⟧ »EurOpenD22/pp5.0/pp-5.tar.Z« 
        └─⟦e5a54fb17⟧ 
            └─⟦this⟧ »pp-5.0/Lib/pp/list_bpt.c« 

TextFile

/* list_bpt.c: utility routines for Body Part Types */

# ifndef lint
static char Rcsid[] = "@(#)$Header: /cs/research/pp/hubris/pp-beta/Lib/pp/RCS/list_bpt.c,v 5.0 90/09/20 16:11:04 pp Exp Locker: pp $";
# endif

/*
 * $Header: /cs/research/pp/hubris/pp-beta/Lib/pp/RCS/list_bpt.c,v 5.0 90/09/20 16:11:04 pp Exp Locker: pp $
 *
 * $Log:	list_bpt.c,v $
 * Revision 5.0  90/09/20  16:11:04  pp
 * rcsforce : 5.0 public release
 * 
 */



#include "util.h"
#include "list_bpt.h"




/* ---------------------  Begin  Routines  -------------------------------- */




/*
Creates a new list structure
*/

LIST_BPT* list_bpt_new (value)
char    *value;
{
	LIST_BPT        *list;


	PP_DBG (("Lib/pp/list_bpt_new (%s)", value));

	if (value == NULLCP)
		return (NULLIST_BPT);

	list = list_bpt_malloc ();

	if (list == NULLIST_BPT)
		return (NULLIST_BPT);

	list -> li_name = strdup (value);

	return (list);

}




/*
Duplicates
*/

LIST_BPT  *list_bpt_dup (list)
LIST_BPT                *list;
{
	LIST_BPT        *retlist = NULLIST_BPT,
			*new;

	for (; list != NULLIST_BPT; list = list->li_next) {
		if ((new = list_bpt_malloc()) == NULLIST_BPT)
			return (NULLIST_BPT);

		new->li_name = strdup (list->li_name);
		list_bpt_add (&retlist, new);
	}

	return (retlist);
}

/*
Adds item onto the end of base
*/

void list_bpt_add (base, new)
LIST_BPT                **base,
			*new;
{
	LIST_BPT        *ep = *base;

	if (ep == NULLIST_BPT)
		*base = new;
	else {
		while (ep->li_next != NULLIST_BPT)
			ep = ep->li_next;
		ep->li_next = new;
	}
}


/*
Finds a specified item within a list
*/

LIST_BPT  *list_bpt_find (list, item)
LIST_BPT        *list;
char            *item;
{
	LIST_BPT        *lp;

	PP_DBG (("Lib/pp/list_bpt_find (%s)", item));

	for (lp = list; lp != NULLIST_BPT; lp = lp->li_next)
		if (lexequ (lp -> li_name, item) == 0)
			return (lp);

	return (NULLIST_BPT);
}

void list_bpt_free (list)
LIST_BPT    *list;
{
	if (list == NULLIST_BPT)  return;
	list_bpt_free (list->li_next);
	if (list -> li_name)
		free (list->li_name);
	free ((char *)list);
}



LIST_BPT *list_bpt_malloc()
{
	LIST_BPT    *new;

	new = (LIST_BPT *) smalloc (sizeof (LIST_BPT));
	new->li_name = NULLCP;
	new->li_next = NULLIST_BPT;
	return (new);
}