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.
 
 
 
 
 
 

215 lines
5.2 KiB

//---------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation 1993-1994
//
// File: cpath.c
//
// This files contains code for the cached briefcase paths.
//
// History:
// 01-31-94 ScottH Created
//
//---------------------------------------------------------------------------
///////////////////////////////////////////////////// INCLUDES
#include "brfprv.h" // common headers
CACHE g_cacheCPATH = {0, 0, 0}; // Briefcase path cache
#define CPATH_EnterCS() EnterCriticalSection(&g_cacheCPATH.cs)
#define CPATH_LeaveCS() LeaveCriticalSection(&g_cacheCPATH.cs)
#ifdef DEBUG
/*----------------------------------------------------------
Purpose: Dumps a CPATH entry
Returns:
Cond: --
*/
void PRIVATE CPATH_DumpEntry(
CPATH * pcpath)
{
ASSERT(pcpath);
TRACE_MSG(TF_ALWAYS, TEXT("CPATH: Atom %d: %s"), pcpath->atomPath, Atom_GetName(pcpath->atomPath));
TRACE_MSG(TF_ALWAYS, TEXT(" Ref [%u] "),
Cache_GetRefCount(&g_cacheCPATH, pcpath->atomPath));
}
/*----------------------------------------------------------
Purpose: Dumps all CPATH cache
Returns:
Cond: --
*/
void PUBLIC CPATH_DumpAll()
{
CPATH * pcpath;
int atom;
BOOL bDump;
ENTEREXCLUSIVE()
{
bDump = IsFlagSet(g_uDumpFlags, DF_CPATH);
}
LEAVEEXCLUSIVE()
if (!bDump)
return ;
atom = Cache_FindFirstKey(&g_cacheCPATH);
while (atom != ATOM_ERR)
{
pcpath = Cache_GetPtr(&g_cacheCPATH, atom);
ASSERT(pcpath);
if (pcpath)
{
CPATH_DumpEntry(pcpath);
Cache_DeleteItem(&g_cacheCPATH, atom, FALSE, NULL, CPATH_Free); // Decrement count
}
atom = Cache_FindNextKey(&g_cacheCPATH, atom);
}
}
#endif
/*----------------------------------------------------------
Purpose: Release the volume ID handle
Returns: --
Cond: hwndOwner is not used.
This function is serialized by the caller (Cache_Term or
Cache_DeleteItem).
*/
void CALLBACK CPATH_Free(
LPVOID lpv,
HWND hwndOwner)
{
CPATH * pcpath = (CPATH *)lpv;
DEBUG_CODE( TRACE_MSG(TF_CACHE, TEXT("CPATH Freeing Briefcase path %s"), Atom_GetName(pcpath->atomPath)); )
// Delete the atom one extra time, because we explicitly added
// it for this cache.
Atom_Delete(pcpath->atomPath);
SharedFree(&pcpath);
}
/*----------------------------------------------------------
Purpose: Add the atomPath to the cache.
If atomPath is already in the cache, we replace it
with a newly obtained path.
Returns: Pointer to CPATH
NULL on OOM
Cond: --
*/
CPATH * PUBLIC CPATH_Replace(
int atomPath)
{
CPATH * pcpath;
BOOL bJustAllocd;
CPATH_EnterCS();
{
pcpath = Cache_GetPtr(&g_cacheCPATH, atomPath);
if (pcpath)
bJustAllocd = FALSE;
else
{
// Allocate using commctrl's Alloc, so the structure will be in
// shared heap space across processes.
pcpath = SharedAllocType(CPATH);
bJustAllocd = TRUE;
}
if (pcpath)
{
LPCTSTR pszPath = Atom_GetName(atomPath);
ASSERT(pszPath);
DEBUG_CODE( TRACE_MSG(TF_CACHE, TEXT("CPATH Adding known Briefcase %s"), pszPath); )
pcpath->atomPath = atomPath;
if (bJustAllocd)
{
if (!Cache_AddItem(&g_cacheCPATH, atomPath, (LPVOID)pcpath))
{
// Cache_AddItem failed here
//
SharedFree(&pcpath);
}
}
else
Cache_DeleteItem(&g_cacheCPATH, atomPath, FALSE, NULL, CPATH_Free); // Decrement count
}
}
CPATH_LeaveCS();
return pcpath;
}
/*----------------------------------------------------------
Purpose: Search for the given path in the cache. If the path
exists, its locality will be returned.
If it is not found, its locality is not known (but
PL_FALSE is returned).
Returns: path locality (PL_) value
Cond: --
*/
UINT PUBLIC CPATH_GetLocality(
LPCTSTR pszPath,
LPTSTR pszBuf, // Can be NULL, or must be of size MAXPATHLEN
int cchMax) // Can be NULL, or must be MAXPATHLEN
{
UINT uRet = PL_FALSE;
LPCTSTR pszBrf;
int atom;
ASSERT(pszPath);
CPATH_EnterCS();
{
atom = Cache_FindFirstKey(&g_cacheCPATH);
while (atom != ATOM_ERR)
{
pszBrf = Atom_GetName(atom);
ASSERT(pszBrf);
if (IsSzEqual(pszBrf, pszPath))
{
uRet = PL_ROOT;
break;
}
else if (PathIsPrefix(pszBrf, pszPath))
{
uRet = PL_INSIDE;
break;
}
atom = Cache_FindNextKey(&g_cacheCPATH, atom);
}
if (uRet != PL_FALSE && pszBuf)
lstrcpyn(pszBuf, pszBrf, cchMax);
}
CPATH_LeaveCS();
return uRet;
}