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 r

⟦4f39f4d4f⟧ TextFile

    Length: 1097 (0x449)
    Types: TextFile
    Names: »rdn_merge.c«

Derivation

└─⟦2d1937cfd⟧ Bits:30007241 EUUGD22: P.P 5.0
    └─⟦35176feda⟧ »EurOpenD22/isode/isode-6.tar.Z« 
        └─⟦de7628f85⟧ 
            └─⟦this⟧ »isode-6.0/dsap/common/rdn_merge.c« 

TextFile

#include "quipu/util.h"
#include "quipu/name.h"

RDN rdn_merge (a,b)
RDN a,b;
{
register RDN aptr, bptr, result, trail;

	if ( a == NULLRDN )
		return (b);
	if ( b == NULLRDN )
		return (a);

	/* start sequence off, make sure 'a' is the first */
	switch (rdn_cmp_comp (a,b)) {
		case 0: /* equal */
			result = a;
			aptr = a->rdn_next;
			rdn_comp_free (b);
			bptr = b->rdn_next;
			break;
		case -1:
			result = b;
			aptr = a;
			bptr = b->rdn_next;
			break;
		case 1:
			result = a;
			aptr = a->rdn_next;
			bptr = b;
			break;
		}

	trail = result;
	while (  (aptr != NULLRDN) && (bptr != NULLRDN) ) {

	   switch (rdn_cmp_comp (aptr,bptr)) {
		case 0: /* equal */
			trail->rdn_next = aptr;
			trail = aptr;
			rdn_comp_free (bptr);
			aptr = aptr->rdn_next;
			bptr = bptr->rdn_next;
			break;
		case -1:
			trail->rdn_next = bptr;
			trail = bptr;
			bptr = bptr->rdn_next;
			break;
		case 1:
			trail->rdn_next = aptr;
			trail = aptr;
			aptr = aptr->rdn_next;
			break;
	    }
	}
	if (aptr == NULLRDN)
		trail->rdn_next = bptr;
	else
		trail->rdn_next = aptr;

	return (result);
}