AfterCleanupFile Event

Fires after a file or directory handle is closed.

Syntax

ANSI (Cross Platform)
virtual int FireAfterCleanupFile(CBFilterAfterCleanupFileEventParams *e);
typedef struct {
const char *FileName;
void *FileContext;
void *HandleContext;
int ResultCode; int reserved; } CBFilterAfterCleanupFileEventParams; Unicode (Windows) virtual INT FireAfterCleanupFile(CBFilterAfterCleanupFileEventParams *e);
typedef struct {
LPCWSTR FileName;
LPVOID FileContext;
LPVOID HandleContext;
INT ResultCode; INT reserved; } CBFilterAfterCleanupFileEventParams;
#define EID_CBFILTER_AFTERCLEANUPFILE 2

virtual INT CBFSFILTER_CALL FireAfterCleanupFile(LPWSTR &lpszFileName, LPVOID &lpFileContext, LPVOID &lpHandleContext, INT &iResultCode);

Remarks

This event fires after a handle to the file or directory specified by FileName is closed. This event differs from AfterCloseFile in that AfterCleanupFile fires immediately after an open handle to the specified file or directory is closed by a process, whereas AfterCloseFile may be fired much later when the OS itself decides that the file or directory can be formally closed.

Other events may fire for the file or directory in the time between when this event fires and when the AfterCloseFile event fires. For example, system components such as the memory manager or cache manager may cause the AfterReadFile and AfterWriteFile events to fire.

Applications only need to handle this event if they've added a standard filter rule that includes the FS_CE_AFTER_CLEANUP flag.

The FileContext and HandleContext parameters are placeholders for application-defined data associated with the file and specific handle, respectively. Please refer to the Contexts topic for more information.

The ResultCode parameter will always be 0 when the event is fired. If the event cannot be handled in a "successful" manner for some reason (e.g., a resource isn't available, security checks failed, etc.), set it to a non-zero value to report an appropriate error. Please refer to the Error Reporting and Handling topic for more information.

This event is fired synchronously; please refer to the Event Types topic for more information.

Copyright (c) 2022 Callback Technologies, Inc. - All rights reserved.
CBFS Filter 2020 C++ Edition - Version 20.0 [Build 8317]