|
|
//==============================================================;
//
// This source code is only intended as a supplement to existing Microsoft documentation.
//
//
//
//
// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
// KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
// IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
// PURPOSE.
//
// Copyright (C) 1999 Microsoft Corporation. All Rights Reserved.
//
//
//
//==============================================================;
#include "Comp.h"
#include "CompData.h"
#include "DataObj.h"
#include "resource.h"
#include <crtdbg.h>
CComponentData::CComponentData() : m_cref(0), m_ipConsoleNameSpace(NULL), m_ipConsole(NULL) { OBJECT_CREATED m_pStaticNode = new CStaticNode; }
CComponentData::~CComponentData() { if (m_pStaticNode) { delete m_pStaticNode; } OBJECT_DESTROYED }
///////////////////////
// IUnknown implementation
///////////////////////
STDMETHODIMP CComponentData::QueryInterface(REFIID riid, LPVOID *ppv) { if (!ppv) return E_FAIL; *ppv = NULL; if (IsEqualIID(riid, IID_IUnknown)) *ppv = static_cast<IComponentData *>(this); else if (IsEqualIID(riid, IID_IComponentData)) *ppv = static_cast<IComponentData *>(this); else if (IsEqualIID(riid, IID_IPersistStream)) *ppv = static_cast<IPersistStream *>(this); if (*ppv) { reinterpret_cast<IUnknown *>(*ppv)->AddRef(); return S_OK; } return E_NOINTERFACE; }
STDMETHODIMP_(ULONG) CComponentData::AddRef() { return InterlockedIncrement((LONG *)&m_cref); }
STDMETHODIMP_(ULONG) CComponentData::Release() { if (InterlockedDecrement((LONG *)&m_cref) == 0) { // we need to decrement our object count in the DLL
delete this; return 0; } return m_cref; }
///////////////////////////////
// Interface IComponentData
///////////////////////////////
HRESULT CComponentData::Initialize( /* [in] */ LPUNKNOWN pUnknown) { HRESULT hr = S_FALSE; //
// Get pointer to namespace interface
// First try to get pointer to IConsoleNameSpace2. If that fails, we are in
// MMC1.0, so get pointer to IConsoleNameSpace instead
//
hr = pUnknown->QueryInterface(IID_IConsoleNameSpace2, (void **)&m_ipConsoleNameSpace);
if (S_OK == hr) { //We are in MMC 1.1 or higher. QI for IConsole2
hr = pUnknown->QueryInterface(IID_IConsole2, (void **)&m_ipConsole); } else //We are in MMC 1.0
{ hr = pUnknown->QueryInterface(IID_IConsoleNameSpace, (void **)&m_ipConsoleNameSpace); if (FAILED(hr)) return hr;
hr = pUnknown->QueryInterface(IID_IConsole, (void **)&m_ipConsole); }
return hr; }
HRESULT CComponentData::CreateComponent( /* [out] */ LPCOMPONENT __RPC_FAR *ppComponent) { *ppComponent = NULL; CComponent *pComponent = new CComponent(this); if (NULL == pComponent) return E_OUTOFMEMORY; return pComponent->QueryInterface(IID_IComponent, (void **)ppComponent); }
HRESULT CComponentData::Notify( /* [in] */ LPDATAOBJECT lpDataObject, /* [in] */ MMC_NOTIFY_TYPE event, /* [in] */ LPARAM arg, /* [in] */ LPARAM param) { MMCN_Crack(TRUE, lpDataObject, this, NULL, event, arg, param);
//Notify doesn't handle any notifications from MMC, so return E_NOTIMPL
return E_NOTIMPL; }
HRESULT CComponentData::Destroy( void) { // Free interfaces
if (m_ipConsoleNameSpace) { m_ipConsoleNameSpace->Release(); m_ipConsoleNameSpace = NULL; } if (m_ipConsole) { m_ipConsole->Release(); m_ipConsole = NULL; } return S_OK; }
HRESULT CComponentData::QueryDataObject( /* [in] */ MMC_COOKIE cookie, /* [in] */ DATA_OBJECT_TYPES type, /* [out] */ LPDATAOBJECT *ppDataObject) { CDataObject *pObj = NULL; if (cookie == 0) pObj = new CDataObject((MMC_COOKIE)m_pStaticNode, type); else pObj = new CDataObject(cookie, type); if (!pObj) return E_OUTOFMEMORY; pObj->QueryInterface(IID_IDataObject, (void **)ppDataObject); return S_OK; }
HRESULT CComponentData::GetDisplayInfo( /* [out][in] */ SCOPEDATAITEM *pScopeDataItem) { HRESULT hr = S_FALSE; // if they are asking for the SDI_STR we have one of those to give
if (pScopeDataItem->lParam) { CDelegationBase *base = (CDelegationBase *)pScopeDataItem->lParam; if (pScopeDataItem->mask & SDI_STR) { LPCTSTR pszT = base->GetDisplayName(); MAKE_WIDEPTR_FROMTSTR_ALLOC(pszW, pszT); pScopeDataItem->displayname = pszW; }
if (pScopeDataItem->mask & SDI_IMAGE) { pScopeDataItem->nImage = base->GetBitmapIndex(); } } return hr; }
HRESULT CComponentData::CompareObjects( /* [in] */ LPDATAOBJECT lpDataObjectA, /* [in] */ LPDATAOBJECT lpDataObjectB) { CDelegationBase *baseA = GetOurDataObject(lpDataObjectA)->GetBaseNodeObject(); CDelegationBase *baseB = GetOurDataObject(lpDataObjectB)->GetBaseNodeObject(); // compare the object pointers
if (baseA->GetCookie() == baseB->GetCookie()) return S_OK; return S_FALSE; }
///////////////////////////////
// Interface IPersistStream
///////////////////////////////
HRESULT CComponentData::GetClassID( /* [out] */ CLSID __RPC_FAR *pClassID) { *pClassID = m_pStaticNode->getNodeType(); return S_OK; }
HRESULT CComponentData::IsDirty( void) { return m_pStaticNode->isDirty() == true ? S_OK : S_FALSE; }
HRESULT CComponentData::Load( /* [unique][in] */ IStream __RPC_FAR *pStm) { void *snapInData = m_pStaticNode->getData(); ULONG dataSize = m_pStaticNode->getDataSize(); return pStm->Read(snapInData, dataSize, NULL); }
HRESULT CComponentData::Save( /* [unique][in] */ IStream __RPC_FAR *pStm, /* [in] */ BOOL fClearDirty) { void *snapInData = m_pStaticNode->getData(); ULONG dataSize = m_pStaticNode->getDataSize(); if (fClearDirty) m_pStaticNode->clearDirty(); return pStm->Write(snapInData, dataSize, NULL); }
HRESULT CComponentData::GetSizeMax( /* [out] */ ULARGE_INTEGER __RPC_FAR *pcbSize) { return m_pStaticNode->getDataSize(); }
|