Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

773 lines
14 KiB

#ifndef __REDBLACKTREE_CPP
#define __REDBLACKTREE_CPP
/*
* Class:
*
* WmiAllocator
*
* Description:
*
* Provides abstraction above heap allocation functions
*
* Version:
*
* Initial
*
* Last Changed:
*
* See Source Depot for change history
*
*/
#if 0
#include <precomp.h>
#include <windows.h>
#include <stdio.h>
#include <RedBlackTree.h>
#endif
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiRedBlackTree <WmiKey,WmiElement> :: WmiRedBlackTree <WmiKey,WmiElement> (
WmiAllocator &a_Allocator
) : m_Allocator ( a_Allocator ) ,
m_Size ( 0 ) ,
m_Root ( NULL )
{
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiRedBlackTree <WmiKey,WmiElement> :: ~WmiRedBlackTree <WmiKey,WmiElement> ()
{
WmiStatusCode t_StatusCode = UnInitialize () ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: Initialize ()
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: UnInitialize ()
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
if ( m_Root )
{
t_StatusCode = RecursiveUnInitialize ( m_Root ) ;
m_Root = NULL ;
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: RecursiveUnInitialize ( WmiRedBlackNode *a_Node )
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
WmiRedBlackNode *t_Left = a_Node->m_Left ;
if ( t_Left )
{
t_StatusCode = RecursiveUnInitialize ( t_Left ) ;
t_Left->~WmiRedBlackNode () ;
WmiStatusCode t_StatusCode = m_Allocator.Delete (
( void * ) t_Left
) ;
t_Left = NULL ;
}
WmiRedBlackNode *t_Right = a_Node->m_Right ;
if ( t_Right )
{
t_StatusCode = RecursiveUnInitialize ( t_Right ) ;
t_Right->~WmiRedBlackNode () ;
WmiStatusCode t_StatusCode = m_Allocator.Delete (
( void * ) t_Right
) ;
t_Right = NULL ;
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: Insert (
const WmiKey &a_Key ,
const WmiElement &a_Element ,
Iterator &a_Iterator
)
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
WmiRedBlackNode *t_AllocNode = NULL ;
t_StatusCode = m_Allocator.New (
( void ** ) & t_AllocNode ,
sizeof ( WmiRedBlackNode )
) ;
if ( t_StatusCode == e_StatusCode_Success )
{
:: new ( ( void* ) t_AllocNode ) WmiRedBlackNode () ;
try
{
t_AllocNode->m_Element = a_Element ;
t_AllocNode->m_Key = a_Key ;
}
catch ( Wmi_Heap_Exception &a_Exception )
{
t_AllocNode->~WmiRedBlackNode () ;
WmiStatusCode t_StatusCode = m_Allocator.Delete (
( void * ) t_AllocNode
) ;
return e_StatusCode_OutOfMemory ;
}
catch ( ... )
{
t_AllocNode->~WmiRedBlackNode () ;
WmiStatusCode t_StatusCode = m_Allocator.Delete (
( void * ) t_AllocNode
) ;
return e_StatusCode_Unknown ;
}
a_Iterator = Iterator ( t_AllocNode ) ;
if ( m_Root )
{
t_StatusCode = RecursiveInsert (
m_Root ,
t_AllocNode
) ;
if ( t_StatusCode == e_StatusCode_Success )
{
m_Size ++ ;
}
else
{
t_AllocNode->~WmiRedBlackNode () ;
WmiStatusCode t_StatusCode = m_Allocator.Delete (
( void * ) t_AllocNode
) ;
}
}
else
{
m_Root = t_AllocNode ;
m_Size ++ ;
}
}
else
{
a_Iterator = Iterator () ;
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: Delete (
const WmiKey &a_Key
)
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
if ( m_Root )
{
t_StatusCode = RecursiveDelete ( m_Root , a_Key ) ;
if ( t_StatusCode == e_StatusCode_Success )
{
m_Size -- ;
}
}
else
{
t_StatusCode = e_StatusCode_NotFound ;
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: Find (
const WmiKey &a_Key ,
Iterator &a_Iterator
)
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
if ( m_Root )
{
t_StatusCode = RecursiveFind ( m_Root , a_Key , a_Iterator ) ;
}
else
{
return e_StatusCode_NotFound ;
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: FindNext (
const WmiKey &a_Key ,
Iterator &a_Iterator
)
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
if ( m_Root )
{
t_StatusCode = RecursiveFindNext ( m_Root , a_Key , a_Iterator ) ;
}
else
{
return e_StatusCode_NotFound ;
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: RecursiveDelete (
WmiRedBlackNode *a_Node ,
const WmiKey &a_Key
)
{
WmiStatusCode t_StatusCode = e_StatusCode_NotFound ;
LONG t_Compare = CompareElement ( a_Key , a_Node->m_Key ) ;
if ( t_Compare == 0 )
{
t_StatusCode = DeleteFixup ( a_Node ) ;
}
else
{
if ( t_Compare < 0 )
{
WmiRedBlackNode *t_Left = a_Node->m_Left ;
if ( t_Left )
{
t_StatusCode = RecursiveDelete ( t_Left , a_Key ) ;
}
}
else
{
WmiRedBlackNode *t_Right = a_Node->m_Right ;
if ( t_Right )
{
t_StatusCode = RecursiveDelete ( t_Right , a_Key ) ;
}
}
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: RecursiveInsert (
WmiRedBlackNode *a_Node ,
WmiRedBlackNode *a_Element
)
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
LONG t_Compare = CompareElement ( a_Element->m_Key , a_Node->m_Key ) ;
if ( t_Compare == 0 )
{
t_StatusCode = e_StatusCode_AlreadyExists ;
}
else
{
if ( t_Compare < 0 )
{
WmiRedBlackNode *t_Left = a_Node->m_Left ;
if ( t_Left )
{
t_StatusCode = RecursiveInsert ( t_Left , a_Element ) ;
}
else
{
a_Element->m_Parent = a_Node ;
a_Node->m_Left = a_Element ;
}
}
else
{
WmiRedBlackNode *t_Right = a_Node->m_Right ;
if ( t_Right )
{
t_StatusCode = RecursiveInsert ( t_Right , a_Element ) ;
}
else
{
a_Element->m_Parent = a_Node ;
a_Node->m_Right = a_Element ;
}
}
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: RecursiveFind (
WmiRedBlackNode *a_Node ,
const WmiKey &a_Key ,
Iterator &a_Iterator
)
{
WmiStatusCode t_StatusCode = e_StatusCode_NotFound ;
LONG t_Compare = CompareElement ( a_Key , a_Node->m_Key ) ;
if ( t_Compare == 0 )
{
a_Iterator = Iterator ( a_Node ) ;
t_StatusCode = e_StatusCode_Success ;
}
else
{
if ( t_Compare < 0 )
{
WmiRedBlackNode *t_Left = a_Node->m_Left ;
if ( t_Left )
{
t_StatusCode = RecursiveFind ( t_Left , a_Key , a_Iterator ) ;
}
}
else
{
WmiRedBlackNode *t_Right = a_Node->m_Right ;
if ( t_Right )
{
t_StatusCode = RecursiveFind ( t_Right , a_Key , a_Iterator ) ;
}
}
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: RecursiveFindNext (
WmiRedBlackNode *a_Node ,
const WmiKey &a_Key ,
Iterator &a_Iterator
)
{
WmiStatusCode t_StatusCode = e_StatusCode_NotFound ;
LONG t_Compare = CompareElement ( a_Key , a_Node->m_Key ) ;
if ( t_Compare == 0 )
{
a_Iterator = Iterator ( a_Node ).Increment () ;
t_StatusCode = e_StatusCode_Success ;
}
else
{
if ( t_Compare < 0 )
{
WmiRedBlackNode *t_Left = a_Node->m_Left ;
if ( t_Left )
{
t_StatusCode = RecursiveFindNext ( t_Left , a_Key , a_Iterator ) ;
}
else
{
a_Iterator = Iterator ( a_Node ).Increment () ;
t_StatusCode = e_StatusCode_Success ;
}
}
else
{
WmiRedBlackNode *t_Right = a_Node->m_Right ;
if ( t_Right )
{
t_StatusCode = RecursiveFindNext ( t_Right , a_Key , a_Iterator ) ;
}
else
{
a_Iterator = Iterator ( a_Node ).Increment () ;
t_StatusCode = e_StatusCode_Success ;
}
}
}
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: LeftRotate ( WmiRedBlackNode *a_Node )
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: RightRotate ( WmiRedBlackNode *a_Node )
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: DeleteFixup ( WmiRedBlackNode *a_Node )
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
WmiRedBlackNode *t_Left = a_Node->m_Left ;
WmiRedBlackNode *t_Right = a_Node->m_Right ;
WmiRedBlackNode *t_Parent = a_Node->m_Parent ;
if ( t_Left && t_Right )
{
Iterator t_Iterator ( a_Node ) ;
t_Iterator.Increment () ;
WmiRedBlackNode *t_Successor = t_Iterator.m_Node ;
if ( t_Parent )
{
if ( t_Parent->m_Left == a_Node )
{
t_Parent->m_Left = t_Successor ;
}
else
{
t_Parent->m_Right = t_Successor;
}
}
else
{
m_Root = t_Successor ;
}
if ( t_Successor->m_Parent != a_Node )
{
if ( a_Node->m_Left )
{
a_Node->m_Left->m_Parent = t_Successor ;
}
if ( a_Node->m_Right )
{
a_Node->m_Right->m_Parent = t_Successor ;
}
WmiRedBlackNode *t_Node = t_Successor->m_Parent ;
t_Successor->m_Parent->m_Left = t_Successor->m_Right ;
if ( t_Successor->m_Left )
{
t_Successor->m_Left->m_Parent = t_Successor->m_Parent ;
}
if ( t_Successor->m_Right )
{
t_Successor->m_Right->m_Parent = t_Successor->m_Parent ;
}
t_Successor->m_Left = a_Node->m_Left ;
t_Successor->m_Right = a_Node->m_Right ;
t_Successor->m_Parent = a_Node->m_Parent ;
}
else
{
if ( a_Node->m_Left )
{
a_Node->m_Left->m_Parent = t_Successor ;
}
if ( a_Node->m_Right )
{
a_Node->m_Right->m_Parent = t_Successor ;
}
t_Successor->m_Left = a_Node->m_Left ;
t_Successor->m_Parent = a_Node->m_Parent ;
}
}
else
{
if ( t_Left )
{
t_Left->m_Parent = a_Node->m_Parent ;
}
else if ( t_Right )
{
t_Right->m_Parent = a_Node->m_Parent ;
}
if ( t_Parent )
{
if ( t_Parent->m_Left == a_Node )
{
t_Parent->m_Left = t_Left ? t_Left : t_Right ;
}
else
{
t_Parent->m_Right = t_Left ? t_Left : t_Right ;
}
}
else
{
m_Root = a_Node->m_Left ? a_Node->m_Left : a_Node->m_Right ;
}
}
a_Node->~WmiRedBlackNode () ;
t_StatusCode = m_Allocator.Delete (
( void * ) a_Node
) ;
return t_StatusCode ;
}
/******************************************************************************
*
* Name:
*
*
* Description:
*
*
*****************************************************************************/
template <class WmiKey,class WmiElement>
WmiStatusCode WmiRedBlackTree <WmiKey,WmiElement> :: Merge (
WmiRedBlackTree <WmiKey,WmiElement> &a_Tree
)
{
WmiStatusCode t_StatusCode = e_StatusCode_Success ;
Iterator t_Iterator = a_Tree.Root ();
while ( ! t_Iterator.Null () )
{
Iterator t_InsertIterator ;
WmiStatusCode t_StatusCode = Insert ( t_Iterator.GetKey () , t_Iterator.GetElement () , t_InsertIterator ) ;
if ( t_StatusCode )
{
t_StatusCode = a_Tree.Delete ( t_Iterator.GetKey () ) ;
}
t_Iterator = a_Tree.Root () ;
}
return t_StatusCode ;
}
#endif __REDBLACKTREE_CPP