Leaked source code of windows server 2003
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.
|
|
/*++
Copyright (c) 1991 Microsoft Corporation
Module Name:
list.hxx
Abstract:
This class is an implementation of the SEQUENTIAL_CONTAINER protocol. The specific implementation is that of a doubly linked list.
Environment:
ULIB, User Mode
--*/
#if !defined( _LIST_DEFN_ )
#define _LIST_DEFN_
#include "seqcnt.hxx"
#include "membmgr.hxx"
struct OBJECT_LIST_NODE { OBJECT_LIST_NODE* next; OBJECT_LIST_NODE* prev; POBJECT data; };
DEFINE_POINTER_AND_REFERENCE_TYPES( OBJECT_LIST_NODE );
DECLARE_CLASS( LIST );
class LIST : public SEQUENTIAL_CONTAINER {
FRIEND class LIST_ITERATOR;
public:
ULIB_EXPORT DECLARE_CONSTRUCTOR( LIST );
VIRTUAL ULIB_EXPORT ~LIST( );
NONVIRTUAL ULIB_EXPORT BOOLEAN Initialize( );
VIRTUAL ULONG QueryMemberCount( ) CONST;
VIRTUAL ULIB_EXPORT BOOLEAN Put( IN OUT POBJECT Member );
VIRTUAL POBJECT Remove( IN OUT PITERATOR Position );
VIRTUAL ULIB_EXPORT PITERATOR QueryIterator( ) CONST;
NONVIRTUAL ULIB_EXPORT BOOLEAN Insert( IN OUT POBJECT Member, IN OUT PITERATOR Position );
private:
POBJECT_LIST_NODE _head; POBJECT_LIST_NODE _tail; ULONG _count; MEM_BLOCK_MGR _mem_block_mgr;
NONVIRTUAL VOID Construct( );
NONVIRTUAL VOID Destroy( );
};
#endif // _LIST_DEFN_
|