Windows2003-3790/admin/snapin/schmmgmt/dataobj.cpp
2020-09-30 16:53:55 +02:00

159 lines
4.5 KiB
C++

// DataObj.cpp : Implementation of data object classes
#include "stdafx.h"
#include "stdutils.h"
#include "macros.h"
USE_HANDLE_MACROS("SCHMMGMT(dataobj.cpp)")
#include "dataobj.h"
#include "compdata.h"
#include "resource.h"
#include "stddtobj.cpp"
//
// IDataObject interface implementation.
//
HRESULT
CSchmMgmtDataObject::GetDataHere(
FORMATETC __RPC_FAR *pFormatEtcIn,
STGMEDIUM __RPC_FAR *pMedium
)
{
MFC_TRY;
const CLIPFORMAT cf=pFormatEtcIn->cfFormat;
if (cf == m_CFNodeType)
{
const GUID* pguid = GetObjectTypeGUID( m_pcookie->m_objecttype );
stream_ptr s(pMedium);
return s.Write(pguid, sizeof(GUID));
}
else if (cf == m_CFSnapInCLSID)
{
const GUID* pguid = &CLSID_SchmMgmt;
stream_ptr s(pMedium);
return s.Write(pguid, sizeof(GUID));
}
else if (cf == m_CFNodeTypeString)
{
const BSTR strGUID = GetObjectTypeString( m_pcookie->m_objecttype );
stream_ptr s(pMedium);
return s.Write(strGUID);
}
else if (cf == m_CFDisplayName)
{
return PutDisplayName(pMedium);
}
else if (cf == m_CFDataObjectType)
{
stream_ptr s(pMedium);
return s.Write(&m_dataobjecttype, sizeof(m_dataobjecttype));
}
else if (cf == m_CFMachineName)
{
stream_ptr s(pMedium);
return s.Write(m_pcookie->QueryNonNULLMachineName());
}
else if (cf == m_CFRawCookie)
{
stream_ptr s(pMedium);
// CODEWORK This cast ensures that the data format is
// always a CCookie*, even for derived subclasses
CCookie* pcookie = (CCookie*)m_pcookie;
return s.Write(reinterpret_cast<PBYTE>(&pcookie), sizeof(m_pcookie));
}
return DV_E_FORMATETC;
MFC_CATCH;
}
HRESULT CSchmMgmtDataObject::Initialize( Cookie* pcookie, DATA_OBJECT_TYPES type )
{
if (NULL == pcookie || NULL != m_pcookie)
{
ASSERT(FALSE);
return E_UNEXPECTED;
}
m_dataobjecttype = type;
m_pcookie = pcookie;
((CRefcountedObject*)m_pcookie)->AddRef();
return S_OK;
}
CSchmMgmtDataObject::~CSchmMgmtDataObject()
{
if (NULL != m_pcookie)
{
((CRefcountedObject*)m_pcookie)->Release();
}
else
{
ASSERT(FALSE);
}
}
HRESULT CSchmMgmtDataObject::PutDisplayName(STGMEDIUM* pMedium)
// Writes the "friendly name" to the provided storage medium
// Returns the result of the write operation
{
CString strDisplayName;
LPCTSTR pszTarget = m_pcookie->QueryTargetServer();
if ( NULL != pszTarget )
{
if ( pszTarget[0] == _T('\\') && pszTarget[1] == _T('\\') )
pszTarget += 2;
strDisplayName = pszTarget;
}
else
{
VERIFY( strDisplayName.LoadString(IDS_SCOPE_SCHMMGMT) );
}
stream_ptr s(pMedium);
return s.Write(strDisplayName);
}
// Register the clipboard formats
CLIPFORMAT CSchmMgmtDataObject::m_CFDisplayName =
(CLIPFORMAT)RegisterClipboardFormat(CCF_DISPLAY_NAME);
CLIPFORMAT CSchmMgmtDataObject::m_CFMachineName =
(CLIPFORMAT)RegisterClipboardFormat(L"MMC_SNAPIN_MACHINE_NAME");
CLIPFORMAT CDataObject::m_CFRawCookie =
(CLIPFORMAT)RegisterClipboardFormat(L"MYCOMPUT_SNAPIN_RAW_COOKIE");
STDMETHODIMP ComponentData::QueryDataObject(MMC_COOKIE cookie, DATA_OBJECT_TYPES type, LPDATAOBJECT* ppDataObject)
{
MFC_TRY;
Cookie* pUseThisCookie =
(Cookie*) ActiveBaseCookie(reinterpret_cast<CCookie*>(cookie));
CComObject<CSchmMgmtDataObject>* pDataObject = NULL;
HRESULT hRes = CComObject<CSchmMgmtDataObject>::CreateInstance(&pDataObject);
if ( FAILED(hRes) )
return hRes;
HRESULT hr = pDataObject->Initialize( pUseThisCookie, type );
if ( SUCCEEDED(hr) )
{
hr = pDataObject->QueryInterface(IID_IDataObject,
reinterpret_cast<void**>(ppDataObject));
}
if ( FAILED(hr) )
{
delete pDataObject;
return hr;
}
return hr;
MFC_CATCH;
}