Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

174 lines
4.3 KiB

//
// Copyright (c) 1997-2001 Microsoft Corporation, All Rights Reserved
//
// ***************************************************************************
//
// Original Author: Rajesh Rao
//
// $Author: rajeshr $
// $Date: 6/11/98 4:43p $
// $Workfile:wbemcach.h $
//
// $Modtime: 6/11/98 11:21a $
// $Revision: 1 $
// $Nokeywords: $
//
//
// Description: Cache for WBEM Class objects
//
//***************************************************************************
#ifndef WBEM_CACHE_H
#define WBEM_CACHE_H
// This encapsulates a WBEM Class object
class CWbemClass : public CRefCountedObject
{
private:
IWbemClassObject *m_pWbemClass;
public:
static DWORD dwCWbemClassCount;
CWbemClass(LPCWSTR pszWbemClassName, IWbemClassObject *pWbemClass)
: CRefCountedObject(pszWbemClassName)
{
dwCWbemClassCount++;
m_pWbemClass = pWbemClass;
m_pWbemClass->AddRef();
}
~CWbemClass()
{
dwCWbemClassCount--;
m_pWbemClass->Release();
}
IWbemClassObject *GetWbemClass()
{
m_pWbemClass->AddRef();
return m_pWbemClass;
}
};
// This encapsulates subclass enumeration (deep) of a WBEM class
class CEnumInfo : public CRefCountedObject
{
private:
CNamesList *m_pClassNameList;
public:
static DWORD dwCEnumInfoCount;
CEnumInfo(LPCWSTR pszWbemSuperClassName, CNamesList *pClassNameList)
: CRefCountedObject(pszWbemSuperClassName)
{
dwCEnumInfoCount++;
m_pClassNameList = pClassNameList;
}
~CEnumInfo()
{
dwCEnumInfoCount--;
delete m_pClassNameList;
}
CNamesList *GetSubClassNames()
{
return m_pClassNameList;
}
};
class CWbemCache
{
private:
// The storage for cached classes
CObjectTree m_objectTree;
// The storage for enumeration information
CObjectTree m_EnumTree;
// Cache configuration parameters
static const __int64 MAX_CACHE_AGE; // In seconds
static const DWORD MAX_CACHE_SIZE;
static DWORD dwWBEMCacheCount;
public:
//***************************************************************************
//
// CWbemCache::CLDAPCache
//
// Purpose : Constructor. Creates an empty cache
//
// Parameters:
//***************************************************************************
CWbemCache();
//***************************************************************************
//
// CWbemCache::GetClass
//
// Purpose : Retreives the IDirectory interface of an LDAP Class
//
// Parameters:
// lpszClassName : The WBEM name of the Class to be retreived.
// ppWbemClass : The address of the pointer where the CWbemClass object will be placed
//
// Return value:
// The COM value representing the return status. The user should release the WBEM cclass
// when done.
//
//***************************************************************************
HRESULT GetClass(LPCWSTR lpszWbemClassName, CWbemClass **ppWbemClass );
//***************************************************************************
//
// CWbemCache::AddClass
//
// Purpose : Adds the CWbemClass object to the cache
//
// Parameters:
// ppWbemClass : The CWbemClass pointer of the object to be added
//
// Return value:
// The COM value representing the return status.
// when done.
//
//***************************************************************************
HRESULT AddClass(CWbemClass *pWbemClass );
//***************************************************************************
//
// CEnumCache::GetEnumInfo
//
// Purpose : Retreives the CEnumInfo object of a WBEM class
//
// Parameters:
// lpszWbemClassName : The WBEM name of the Class to be retreived.
// ppEnumInfo : The address of the pointer where the CEnumInfo object will be placed
//
// Return value:
// The COM value representing the return status. The user should release the WBEM cclass
// when done.
//
//***************************************************************************
HRESULT GetEnumInfo(LPCWSTR lpszWbemClassName, CEnumInfo **ppEnumInfo );
//***************************************************************************
//
// CEnumCache::AddEnumInfo
//
// Purpose : Adds the CEnumInfo object to the cache
//
// Parameters:
// ppWbemClass : The CEnumInfo pointer of the object to be added
//
// Return value:
// The COM value representing the return status.
// when done.
//
//***************************************************************************
HRESULT AddEnumInfo(CEnumInfo *pEnumInfo);
};
#endif /* WBEM_CACHE_H */