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.
|
|
/*++
Copyright (c) 1996 Microsoft Corporation
Module Name:
metafact.cpp
Abstract:
The CMetabaseFactory class.
Author:
Magnus Hedlund (MagnusH) --
Revision History:
--*/
#include "stdafx.h"
#include "oleutil.h"
#include "metautil.h"
#include "metafact.h"
CMetabaseFactory::CMetabaseFactory ( ) : m_wszServerName ( NULL ), m_pMetabase ( NULL ) { }
CMetabaseFactory::~CMetabaseFactory () { if ( m_wszServerName ) { delete m_wszServerName; m_wszServerName = NULL; }
DestroyMetabaseObject ( ); }
//$-------------------------------------------------------------------
//
// CMetabaseFactory::DestroyMetabaseObject
//
// Description:
//
// Destroys the current metabase object. This includes calling
// the terminate routine on the metabase.
//
//--------------------------------------------------------------------
void CMetabaseFactory::DestroyMetabaseObject ( ) { TraceQuietEnter ( "CMetabaseFactory::DestroyMetabaseObject" ); if ( m_pMetabase ) { _VERIFY ( m_pMetabase->Release () == 0 ); m_pMetabase = NULL; } }
//$-------------------------------------------------------------------
//
// CMetabaseFactory::GetMetabaseObject
//
// Description:
//
// Returns an interface to the metabase. If the metabase object
// hasn't been created on the same machine, it is created.
//
// Parameters:
//
// wszServer - remote machine to create object on, or NULL for local machine.
// ppMetabaseResult - returns the interface pointer if successful.
// client has the responsibility to Release this pointer.
//
// Returns:
//
// hresult.
//
//--------------------------------------------------------------------
HRESULT CMetabaseFactory::GetMetabaseObject ( LPCWSTR wszServer, IMSAdminBase ** ppMetabaseResult ) { TraceFunctEnter ( "CMetabaseFactory::GetMetabaseObject" );
// Validate parameters:
_ASSERT ( ppMetabaseResult != NULL ); _ASSERT ( IS_VALID_OUT_PARAM ( ppMetabaseResult ) );
if ( ppMetabaseResult == NULL ) { FatalTrace ( (LPARAM) this, "Bad Return Pointer" );
TraceFunctLeave (); return E_POINTER; } // Variables:
HRESULT hr = NOERROR; CComPtr<IMSAdminBase> pNewMetabase;
// Zero the out parameter:
*ppMetabaseResult = NULL;
// A server name of "" should be NULL:
if ( wszServer && (*wszServer == NULL || !lstrcmpi(wszServer, _T("localhost")) ) ) { wszServer = NULL; }
if ( IsCachedMetabase ( wszServer ) ) { // We've already got this metabase pointer. Just return it.
DebugTrace ( (LPARAM) this, "Returning Cached metabase" ); _ASSERT ( m_pMetabase );
*ppMetabaseResult = m_pMetabase; m_pMetabase->AddRef ();
hr = NOERROR; goto Exit; }
// We have to create the metabase object:
StateTrace ( (LPARAM) this, "Creating new metabase" );
// Destroy the old metabase object:
DestroyMetabaseObject ( );
// Setup the server name field:
if ( !SetServerName ( wszServer ) ) { hr = E_OUTOFMEMORY; goto Exit; }
// m_wszServer = NULL is valid, it means the local machine.
hr = CreateMetabaseObject ( m_wszServerName, &pNewMetabase ); if ( FAILED(hr) ) { goto Exit; }
// Save the metabase pointer:
m_pMetabase = pNewMetabase; pNewMetabase.p->AddRef ();
// Return the interface pointer:
*ppMetabaseResult = pNewMetabase; pNewMetabase.p->AddRef ();
Exit: TraceFunctLeave (); return hr;
// pMetabase will be released automatically.
}
//$-------------------------------------------------------------------
//
// CMetabaseFactory::IsCachedMetabase
//
// Description:
//
// Returns TRUE if we have a metabase for the given server
//
// Parameters:
//
// wszServer - remote machine or NULL
//
// Returns:
//
// TRUE if we have a pointer already, FALSE otherwise.
//
//--------------------------------------------------------------------
BOOL CMetabaseFactory::IsCachedMetabase ( LPCWSTR wszServer ) { if ( !m_pMetabase ) { // We don't even have a cached metabase object.
return FALSE; }
if ( // Both are the local machine OR
( m_wszServerName == NULL && wszServer == NULL ) || // Both are the same remote machine
( m_wszServerName && wszServer && !lstrcmpi ( m_wszServerName, wszServer ) ) ) {
// It's a match
return TRUE; }
// No dice...
return FALSE; }
//$-------------------------------------------------------------------
//
// CMetabaseFactory::SetServerName
//
// Description:
//
// Sets the m_wszServerName string.
//
// Parameters:
//
// wszServer - The new servername. Can be NULL.
//
// Returns:
//
// FALSE on failure due to lack of memory.
//
//--------------------------------------------------------------------
BOOL CMetabaseFactory::SetServerName ( LPCWSTR wszServer ) { TraceQuietEnter ( "CMetabaseFactory::SetServerName" );
delete m_wszServerName; m_wszServerName = NULL;
if ( wszServer != NULL ) { _ASSERT ( IS_VALID_STRING ( wszServer ) );
m_wszServerName = new WCHAR [ lstrlen ( wszServer ) + 1 ];
if ( m_wszServerName == NULL ) { FatalTrace ( (LPARAM) this, "Out of Memory" ); return FALSE; }
lstrcpy ( m_wszServerName, wszServer ); } return TRUE; }
|