Mavl Merge!
FossilOrigin-Name: cf0bc1c9997eab989a461edd199db8615c5272b04b9141a4855716a636984c8c
This commit is contained in:
parent
3ba95015a4
commit
8dd6faf09f
51
src/capwap/mavl_merge.c
Normal file
51
src/capwap/mavl_merge.c
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
#include "mavl.h"
|
||||||
|
|
||||||
|
|
||||||
|
#include "dbg.h" //Tube
|
||||||
|
#include "mbag.h"
|
||||||
|
|
||||||
|
static void mavlnode_move(mavl_t m,mavl_t t, struct mavlnode *n)
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
struct mavlnode * mn = mavl_get_node(m,n->data);
|
||||||
|
if (mn) {
|
||||||
|
DBGX("replacing !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!","");
|
||||||
|
if (m->del) {
|
||||||
|
m->del(mn->data);
|
||||||
|
}
|
||||||
|
mn->data=n->data;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
DBGX("ODDING replacing !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!","");
|
||||||
|
mavl_add(m,n->data);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
free(n);
|
||||||
|
t->count--;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static void mavl_merge0(mavl_t m, mavl_t t ,struct mavlnode * n)
|
||||||
|
{
|
||||||
|
if (!n)
|
||||||
|
return;
|
||||||
|
mavl_merge0(m,t,n->left);
|
||||||
|
mavl_merge0(m,t,n->right);
|
||||||
|
|
||||||
|
mbag_item_t *i = n->data;
|
||||||
|
DBGX("MBAG I %s",i->id);
|
||||||
|
|
||||||
|
mavlnode_move(m,t,n);
|
||||||
|
}
|
||||||
|
|
||||||
|
void mavl_merge(mavl_t m, mavl_t t)
|
||||||
|
{
|
||||||
|
mavl_merge0(m,t,t->root);
|
||||||
|
t->root=0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user