REDIRECTCLOSE Callback Function
#include "l_bitmap.h"
L_INT L_FAR L_EXPORT YourClose(FD, pUserData)
L_INT FD; |
/* file handle */ |
/* pointer to additional parameters */ |
Replaces the normal LEADTOOLS function for closing a file.
Parameter |
Description |
FD |
Identifies the file to be closed. The file handle is returned by the REDIRECTOPEN callback function. |
pUserData |
A void pointer that you can use to access a variable or structure containing data that your callback function needs. This gives you a way to receive data indirectly from the function that uses this callback function. (This is the same pointer that you pass in the pUserData parameter of the calling function.) |
|
Keep in mind that this is a void pointer, which must be cast to the appropriate data type within your callback function. |
Returns
0 |
The file was closed. |
-1 |
The function failed. |
Comments
For information about using this type of callback, refer to L_RedirectIO.
Example
To see how the following function is defined and called, refer to L_RedirectIO.
/* This procedure is a replacement to the built in Close procedure.
This may be called many times, especially by L_FileInfo, so
we need to reset the internal data structure to the defaults. */
/************************** Global Declarations **********************************/
typedef struct tagUSERDATA
{
L_INT32 dwSize; |
/* Size of the buffer. */ |
L_INT32 dwUsed; |
/* Number of bytes used. */ |
L_CHAR L_HUGE *pData; |
/* Pointer to the buffer. */ |
L_CHAR L_HUGE *pCurData; |
/* Current pointer location. */ |
} USERDATA, L_FAR * LPUSERDATA; |
/* Pointer to DATA structure */ |
/******************************************************************************/
L_INT L_FAR L_EXPORT WindowsClose (L_INT FD)
{
UNREFERENCED_PARAMETER (FD);
UserData.pCurData = UserData.pData;
UserData.dwUsed = 0;
return (TRUE);
}