windows-nt/Source/XPSP1/NT/inetsrv/iis/iisrearc/ul/drv/notify.h
2020-09-26 16:20:57 +08:00

128 lines
2.1 KiB
C

/*++
Copyright (c) 2000-2001 Microsoft Corporation
Module Name:
notify.h
Abstract:
This module contains the notification list utilities.
A notification list is optionally synchronized with
a user specified UL_ERESOURCE, and provides an iterator
called UlNotifyAllEntries.
Author:
Michael Courage (mcourage) 25-Jan-2000
Revision History:
--*/
#ifndef _NOTIFY_H_
#define _NOTIFY_H_
#ifdef __cplusplus
extern "C" {
#endif
//
// forwards
//
typedef struct _UL_NOTIFY_ENTRY *PUL_NOTIFY_ENTRY;
//
// Notification function prototype.
// Invoked on a list notification.
//
// Arguments:
// pEntry - the entry that is being notified
// pv - "anything" parameter from UlNotifyEntries caller
//
// Return Value:
// Function returns TRUE to continue iterating through the list
// or FALSE to stop iterating.
//
typedef
BOOLEAN
(*PUL_NOTIFY_FUNC)(
IN PUL_NOTIFY_ENTRY pEntry,
IN PVOID pHost,
IN PVOID pv
);
//
// The head of a notification list
//
typedef struct _UL_NOTIFY_HEAD
{
//
// A list of UL_NOTIFY_ENTRYs
//
LIST_ENTRY ListHead;
PUL_ERESOURCE pResource;
} UL_NOTIFY_HEAD, *PUL_NOTIFY_HEAD;
//
// An entry in the notification list.
//
typedef struct _UL_NOTIFY_ENTRY
{
//
// List information.
//
LIST_ENTRY ListEntry;
PUL_NOTIFY_HEAD pHead;
//
// A pointer to the object containting this entry
//
PVOID pHost;
} UL_NOTIFY_ENTRY, *PUL_NOTIFY_ENTRY;
//
// Notification List functions
//
VOID
UlInitializeNotifyHead(
IN PUL_NOTIFY_HEAD pHead,
IN PUL_ERESOURCE pResource OPTIONAL
);
VOID
UlInitializeNotifyEntry(
IN PUL_NOTIFY_ENTRY pEntry,
IN PVOID pHost
);
VOID
UlAddNotifyEntry(
IN PUL_NOTIFY_HEAD pHead,
IN PUL_NOTIFY_ENTRY pEntry
);
VOID
UlRemoveNotifyEntry(
IN PUL_NOTIFY_ENTRY pEntry
);
VOID
UlNotifyAllEntries(
IN PUL_NOTIFY_FUNC pFunction,
IN PUL_NOTIFY_HEAD pHead,
IN PVOID pv OPTIONAL
);
#ifdef __cplusplus
}; // extern "C"
#endif
#endif // _NOTIFY_H_