|
|
//
// cache.h: Declares data, defines and struct types for the
// cache list module.
//
//
#ifndef __CACHE_H__
#define __CACHE_H__
/////////////////////////////////////////////////////////////
//
// Generic cache structures
//
/////////////////////////////////////////////////////////////
typedef void (CALLBACK *PFNFREEVALUE)(void * pv, HWND hwndOwner);
typedef struct tagCACHE { CRITICAL_SECTION cs; HDSA hdsa; // Actual list of CITEMs
HDPA hdpa; // Sorted ptr list
HDPA hdpaFree; // Free list
int iPrev; // Index into hdpa. Used by FindFirst/FindNext
int atomPrev; } CACHE;
// Generic cache APIs
//
BOOL PUBLIC Cache_Init (CACHE * pcache); void PUBLIC Cache_InitCS(CACHE * pcache); void PUBLIC Cache_Term (CACHE * pcache, HWND hwndOwner, PFNFREEVALUE pfnFree); void PUBLIC Cache_DeleteCS(CACHE * pcache); BOOL PUBLIC Cache_AddItem (CACHE * pcache, int atomKey, LPVOID pvValue); int PUBLIC Cache_DeleteItem (CACHE * pcache, int atomKey, BOOL bNuke, HWND hwndOwner, PFNFREEVALUE pfnFree); BOOL PUBLIC Cache_ReplaceItem (CACHE * pcache, int atomKey, LPVOID pvBuf, int cbBuf); LPVOID PUBLIC Cache_GetPtr (CACHE * pcache, int atomKey); BOOL PUBLIC Cache_GetItem(CACHE * pcache, int atomKey, LPVOID pvBuf, int cbBuf); int PUBLIC Cache_FindFirstKey(CACHE * pcache); int PUBLIC Cache_FindNextKey(CACHE * pcache, int atomPrev); UINT PUBLIC Cache_GetRefCount(CACHE * pcache, int atomKey);
/////////////////////////////////////////////////////////////
//
// Cached briefcase handle list
//
/////////////////////////////////////////////////////////////
// Cache briefcase structure
//
typedef struct tagCBS { int atomBrf; // Useful for reference
HBRFCASE hbrf; // Opened on add, closed on delete
HWND hwndParent; // Volatile
PABORTEVT pabortevt; // Abort event object
UINT uFlags; // One of CBSF_ flags
} CBS, * PCBS;
#define CBSF_LFNDRIVE 0x0002
extern CACHE g_cacheCBS; // Briefcase structure cache
void CALLBACK CBS_Free(LPVOID lpv, HWND hwnd);
DEBUG_CODE( void PUBLIC CBS_DumpAll(); )
// BOOL CBS_Init(void);
//
#define CBS_Init() Cache_Init(&g_cacheCBS)
// void CBS_InitCS(void);
//
#define CBS_InitCS() Cache_InitCS(&g_cacheCBS)
// void CBS_Term(HWND hwndOwner);
//
#define CBS_Term(hwndOwner) Cache_Term(&g_cacheCBS, hwndOwner, CBS_Free)
// void CBS_DeleteCS(void);
//
#define CBS_DeleteCS() Cache_DeleteCS(&g_cacheCBS)
// HRESULT CBS_Add(PCBS * ppcbs, int atomPath, HWND hwndOwner);
// Must call CBS_Delete for each call to this guy.
//
HRESULT PUBLIC CBS_Add(PCBS * ppcbs, int atomPath, HWND hwndOwner);
// CBS FAR * CBS_Get(int atomPath);
// Must call CBS_Delete for each call to this guy.
//
#define CBS_Get(atomPath) Cache_GetPtr(&g_cacheCBS, atomPath)
// int CBS_Delete(int atomPath, HWND hwndOwner);
// Returns reference count (0 if deleted)
//
#define CBS_Delete(atomPath, hwndOwner) Cache_DeleteItem(&g_cacheCBS, atomPath, FALSE, hwndOwner, CBS_Free)
// int CBS_Nuke(int atomPath, HWND hwndOwner);
// Returns 0
//
#define CBS_Nuke(atomPath, hwndOwner) Cache_DeleteItem(&g_cacheCBS, atomPath, TRUE, hwndOwner, CBS_Free)
/////////////////////////////////////////////////////////////
//
// Cached reclist
//
/////////////////////////////////////////////////////////////
// Cache reclist structure
//
typedef struct tagCRL { int atomPath; // Inside path for this CRL
int atomOutside; // Outside path of the sync copy pair
UINT idsStatus; // resource ID for status string
PABORTEVT pabortevt; // Abort event object, owned by CBS
HBRFCASE hbrf; // Briefcase this reclist belongs to
int atomBrf; PRECLIST lprl; // Created
PFOLDERTWINLIST lpftl; // Created. May be NULL
UINT ucUse; // Use count (dirty entry is not cleaned until
// ucUse == 0)
UINT uFlags; // CRLF_* flags
} CRL, * PCRL;
// Flags for CRL
#define CRLF_DIRTY 0x00000001 // cache item is dirty
#define CRLF_NUKE 0x00000002 // nuke when use count is 0
#define CRLF_SUBFOLDERTWIN 0x00000004 // folder is subfolder of subtree twin
#define CRLF_ISFOLDER 0x00000008 // atomPath is a folder
#define CRLF_ISLFNDRIVE 0x00000010 // is on an LFN drive
#define CRLF_ORPHAN 0x00000020 // item is orphan
extern CACHE g_cacheCRL; // Reclist cache
void CALLBACK CRL_Free(LPVOID lpv, HWND hwndOwner);
DEBUG_CODE( void PUBLIC CRL_DumpAll(); )
#define CRL_IsOrphan(pcrl) IsFlagSet((pcrl)->uFlags, CRLF_ORPHAN)
#define CRL_IsSubfolderTwin(pcrl) IsFlagSet((pcrl)->uFlags, CRLF_SUBFOLDERTWIN)
#define CRL_IsFolder(pcrl) IsFlagSet((pcrl)->uFlags, CRLF_ISFOLDER)
// BOOL CRL_Init(void);
//
#define CRL_Init() Cache_Init(&g_cacheCRL)
// void CRL_InitCS(void);
//
#define CRL_InitCS() Cache_InitCS(&g_cacheCRL)
// void CRL_Term(void);
//
#define CRL_Term() Cache_Term(&g_cacheCRL, NULL, CRL_Free)
// void CRL_DeleteCS(void);
//
#define CRL_DeleteCS() Cache_DeleteCS(&g_cacheCRL)
BOOL PUBLIC IsSubfolderTwin(HBRFCASE hbrf, LPCTSTR pcszPath);
// HRESULT CRL_Add(PCBS pcbs, int atomPath);
// Must call CRL_Delete for each call to this function.
//
HRESULT PUBLIC CRL_Add(PCBS pcbs, int atomPath);
// HRESULT CRL_Get(int atomPath, PCRL * ppcrl);
// Must call CRL_Delete for each successful call to this function.
//
HRESULT PUBLIC CRL_Get(int atomPath, PCRL * ppcrl);
// HRESULT CRL_Replace(int atomPath);
//
HRESULT PUBLIC CRL_Replace(int atomPath);
// void CRL_Delete(int atomPath);
//
void PUBLIC CRL_Delete(int atomPath);
// int CRL_Nuke(int atomPath);
//
void PUBLIC CRL_Nuke(int atomPath);
// BOOL CRL_Dirty(int atomPath);
BOOL PUBLIC CRL_Dirty(int atomPath, int atomCabinetFolder, LONG lEvent, LPBOOL pbRefresh);
// void CRL_DirtyAll(int atomBrf);
//
void PUBLIC CRL_DirtyAll(int atomBrf);
/////////////////////////////////////////////////////////////
//
// Cached briefcase paths
//
/////////////////////////////////////////////////////////////
typedef struct tagCPATH { int atomPath; // Useful for reference
} CPATH;
extern CACHE g_cacheCPATH; // Volume ID cache
void CALLBACK CPATH_Free(LPVOID lpv, HWND hwndOwner);
DEBUG_CODE( void PUBLIC CPATH_DumpAll(); )
// BOOL CPATH_Init(void);
//
#define CPATH_Init() Cache_Init(&g_cacheCPATH)
// void CPATH_InitCS(void);
//
#define CPATH_InitCS() Cache_InitCS(&g_cacheCPATH)
// void CPATH_Term();
//
#define CPATH_Term() Cache_Term(&g_cacheCPATH, NULL, CPATH_Free)
// void CPATH_DeleteCS(void);
//
#define CPATH_DeleteCS() Cache_DeleteCS(&g_cacheCPATH)
// CPATH FAR * CPATH_Replace(int atomPath);
// Must call CPATH_Delete for each call to this function.
//
CPATH * PUBLIC CPATH_Replace(int atomPath);
// UINT CPATH_GetLocality(LPCSTR pszPath, LPSTR pszBuf);
//
UINT PUBLIC CPATH_GetLocality(LPCTSTR pszPath, LPTSTR pszBuf);
#endif // __CACHE_H__
|