2020-09-30 17:12:32 +02:00

137 lines
2.2 KiB
C++

/*++
Copyright (c) 1997 Microsoft Corporation
Module Name:
priolist.cxx
Abstract:
Contains prioritized, serialized list class implementation
Contents:
CPriorityList::Insert
CPriorityList::Remove
Author:
Richard L Firth (rfirth) 03-May-1997
Notes:
Properly, the CPriorityList class should extend a CSerializedList class, but
we don't currently have one, just a serialized list type (common\serialst.cxx).
WARNING: Code in this module makes assumptions about the contents of a
SERIALIZED_LIST
Revision History:
03-May-1997 rfirth
Created
--*/
#include <wininetp.h>
// class methods
VOID
CPriorityList::Insert(
IN CPriorityListEntry * pEntry
)
/*++
Routine Description:
Insert prioritized list entry into prioritized, serialized list
Arguments:
pEntry - pointer to prioritized list entry to add
Return Value:
None.
--*/
{
DEBUG_ENTER((DBG_UTIL,
None,
"CPriorityList::Insert",
"{%#x} %#x",
this,
pEntry
));
Acquire();
INET_ASSERT(!IsOnSerializedList(&m_List, pEntry->List()));
INET_ASSERT(pEntry->Next() == NULL);
INET_ASSERT(pEntry->Prev() == NULL);
CPriorityListEntry * pCur;
for (pCur = (CPriorityListEntry *)m_List.List.Flink;
pCur != (CPriorityListEntry *)&m_List.List.Flink;
pCur = (CPriorityListEntry *)pCur->Next()) {
if (pCur->GetPriority() < pEntry->GetPriority()) {
break;
}
}
InsertHeadList(pCur->Prev(), pEntry->List());
++m_List.ElementCount;
Release();
DEBUG_LEAVE(0);
}
VOID
CPriorityList::Remove(
IN CPriorityListEntry * pEntry
)
/*++
Routine Description:
Remove entry from prioritized serialized list
Arguments:
pEntry - address of entry to remove
Return Value:
None.
--*/
{
DEBUG_ENTER((DBG_UTIL,
None,
"CPriorityList::Remove",
"{%#x} %#x",
this,
pEntry
));
Acquire();
INET_ASSERT(IsOnSerializedList(&m_List, pEntry->List()));
pEntry->Remove();
--m_List.ElementCount;
Release();
DEBUG_LEAVE(0);
}