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.
 
 
 
 
 
 

179 lines
3.0 KiB

// Copyright (c) 1998 Microsoft Corporation
// templates.h
#ifndef __TEMPLATES_H__
#define __TEMPLATES_H__
#include <windows.h>
template< class T > T* List_Cat( T* p1, T* p2 )
{
T* pScan;
if( p1 == NULL )
{
return p2;
}
for( pScan = p1 ; pScan->pNext != NULL ; pScan = (T*)pScan->pNext );
pScan->pNext = p2;
return p1;
}
template< class T > DWORD List_Len( T* p )
{
DWORD dw;
for( dw = 0 ; p != NULL ; p = (T*)p->pNext )
{
++dw;
}
return dw;
}
template< class T > BOOL inlist( T* lst, T* p )
{
if( p == NULL )
{
return TRUE;
}
for( ; lst != NULL ; lst = (T*)lst->pNext )
{
if( p == lst )
{
return TRUE;
}
}
return FALSE;
}
template< class T > T* List_Index( T* lst, DWORD dwIndex )
{
T* pScan;
for( pScan = lst ; dwIndex > 0 && pScan != NULL && pScan->pNext != NULL ; --dwIndex, pScan = (T*)pScan->pNext );
return pScan;
}
template< class T > T* List_Insert( T* lst, T* p, DWORD dwIndex )
{
T* pPrev;
if( lst == NULL || dwIndex == 0 )
{
p->pNext = lst;
lst = p;
}
else
{
pPrev = List_Index( lst, dwIndex - 1 );
p->pNext = pPrev->pNext;
pPrev->pNext = p;
}
return lst;
}
template< class T > T* List_Remove( T* lst, T* p )
{
if( lst != NULL )
{
if( lst == p )
{
lst = (T*)lst->pNext;
p->pNext = NULL;
}
else
{
T* pScan;
for( pScan = lst ; pScan->pNext != p && pScan->pNext != NULL ; pScan = (T*)pScan->pNext );
if( pScan->pNext != NULL )
{
pScan->pNext = pScan->pNext->pNext;
p->pNext = NULL;
}
}
}
return lst;
}
template< class T > long List_Position( T* lst, T* p )
{
long lPos;
lPos = 0;
while( lst != NULL && lst != p )
{
lst = lst->pNext;
++lPos;
}
if( lst == NULL )
{
return -1;
}
return lPos;
}
template< class T > T* List_Clone( T* lst )
{
T* pPrev;
T* lstClone;
T* pCopy;
lstClone = NULL;
pPrev = NULL;
for( ; lst ; lst = (T*)lst->pNext )
{
pCopy = new T;
if( pCopy != NULL )
{
memcpy( pCopy, lst, sizeof( T ) );
pCopy->pNext = NULL;
if( pPrev != NULL )
{
pPrev->pNext = pCopy;
}
else
{
lstClone = pCopy;
}
pPrev = pCopy;
}
}
return lstClone;
}
template< class T > void List_Free( T* lst )
{
T* pNext;
for( ; lst != NULL ; lst = pNext )
{
pNext = (T*)lst->pNext;
delete lst;
}
}
template< class T > T* Clone( T* p )
{
T* pCopy;
pCopy = new T;
if( pCopy != NULL )
{
memcpy( pCopy, p, sizeof( T ) );
pCopy->pNext = NULL;
}
return pCopy;
}
#endif // __TEMPLATES_H__