1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81
|
#include "lst.h"
/*************************
* lstAppend
*
* 1. APPEND TO BASE LIST IF hLst IS A CURSOR
* 2. APPEND REF TO THIS LIST
*************************/
int lstAppend( HLST hLst, void *pData )
{
HLSTITEM hItem;
if ( !hLst )
return LST_ERROR;
/**********************
* CREATE AN ITEM
**********************/
hItem = (HLSTITEM) malloc( sizeof(LSTITEM) );
if ( !hItem )
return LST_ERROR;
hItem->bDelete = false;
hItem->bHide = false;
hItem->hLst = hLst;
hItem->nRefs = 0;
hItem->pData = NULL;
hItem->pNext = NULL;
hItem->pPrev = NULL;
if ( hLst->hLstBase )
{
/**********************
* WE ARE A CURSOR LIST SO...
* 1. ADD TO BASE LIST
* 2. ADD TO THIS LIST (ref to base list)
**********************/
lstAppend( hLst->hLstBase, pData );
hItem->pData = hLst->hLstBase->hCurrent;
hLst->hLstBase->hCurrent->nRefs++;
_lstAppend( hLst, hItem );
}
else
{
/**********************
* WE ARE THE ROOT SO...
* 1. ADD TO THIS LIST
**********************/
hItem->pData = pData;
_lstAppend( hLst, hItem );
}
return LST_SUCCESS;
}
/*************************
* SIMPLY CONNECTS THE LINKS/POINTERS AND SETS CURRENT
*************************/
int _lstAppend( HLST hLst, HLSTITEM hItem )
{
if ( hLst->hFirst )
{
hItem->pPrev = hLst->hLast;
hLst->hLast->pNext = hItem;
hLst->hLast = hItem;
}
else
{
hItem->pPrev = NULL;
hLst->hFirst = hItem;
hLst->hLast = hItem;
}
hLst->hCurrent = hItem;
hLst->nItems++;
return LST_SUCCESS;
}
|